# Flash Memory Volume 1

Synchronous and DRAM-Interface Components

 $FlashFile^{TM}$ Components

Boot Block Components

Bulk-Erase Components



intel

SANTA CLARA DIVISION 3000 Bowers Avenue Santa Clara, CA 95051-0919 (408) 727-2500 • (800) 866-9953



# 24-HOUR AUTOMATED TECHNICAL SUPPORT\*

Intel's Application Bulletin Board System (BBS) and FaxBack System are at your service, 24-hours a day, at no charge, and the information is updated frequently.

## FaxBack SYSTEM

Technical and product information are available 24-hours a day! Order documents containing:

- · Product Announcements
- Product Literature
- Intel Device Characteristics

- Design/Application Recommendations
- Stepping/Change Notifications
- Quality and Reliability Information

Information on the following subjects is also available:

- Microcontroller and Flash
- · OEM Branded Systems
- · Multibus/BBS Listing
- Multimedia

- · Development Tools
- · Quality and Reliability/Change Notification
- Microprocessor/PCI/Peripheral
- Intel Architecture Lab

To use FaxBack for Intel components and systems, dial (800) 628-2283 or (916) 356-3105 (U.S. and Canada) or +44{0} 1793-496646 (Europe) and follow the automated voice-prompt menu. Document orders will be faxed to the fax number you specify. Catalogs are updated twice a month, so call for the latest information!

## **BULLETIN BOARD SYSTEM**

Intel's Application Bulletin Board System (BBS) enables file retrieval 24-hours a day. The following can be located on the BBS:

- Software Drivers
- Tool Information
- · Software/Application Utilities

- Product/Technical Documentation
- · Firmware Upgrades
- · Quality and Reliability Data

To use the Intel Application BBS (components and systems), dial (916) 356-3600 for download access (U.S. and Canada) or +44{0} 1793-496340 (Europe). The BBS will support 1200–19200 baud rate modem. Typical modem configuration: 9600 baud rate, No Parity, 8 Data Bits, 1 Stop Bit. A directory listing of BBS files is also available through FaxBack or our 800 BBS (800-897-2536).

## **Retail Products**

Information on Intel's retail products (Coprocessors and wireless, video, personal conferencing and network products) is available through the following services:

Internet :

ftp.intel.com (143.185.65.2)

CompuServe : GO

GO INTELFORUM (modem settings: E-7-1, up to 14.4 Kbps)

| Country       | BBS (N-8-1, up to 14.4 Kbps) | FaxBack                             |
|---------------|------------------------------|-------------------------------------|
| North America | (503) 264-7999               | (800) 525-3019 or<br>(503) 264-6835 |
| Europe        | +44 1 793-432955             | +44 1 793-432509                    |
| Australia     | +61 2 975-3066               | +61 2 975-3922                      |
| Taiwan        | +886 2 718-6422              | +886 2 514-0815                     |
| Singapore     | +65 256-4776                 | +65 256-5350                        |
| Hong Kong     | +852 530-4116                | +852 844-4448                       |
| Korea         | +822 784-3430                | +822 767-2594                       |

<sup>\*</sup>Support services provided courtesy of Intel Application Support



# **LITERATURE**

For additional information on Intel products in the U.S. or Canada, call Intel's Literature Center at (800) 548-4725 or write to:

Intel Literature P.O. Box 7641 Mt. Prospect, II 60056-7641

To order literature outside of the U.S. and Canada contact your local international sales office.

# **CURRENT DATABOOKS**

Product line databooks contain datasheets, application notes, article reprints, and other design information. Databooks can be ordered in the U.S. and Canada by calling TAB/McGraw-Hill at 1-800-822-8158; outside of the U.S. and Canada contact your local international sales office.

| Title                                          | Intel Order Number | ISBN          |
|------------------------------------------------|--------------------|---------------|
| Automotive Products                            | 231792             | N/A           |
| Embedded Applications (2 vol. set)             | 270648             | 1-55512-242-6 |
| Embedded Microcontrollers                      | 270646             | 1-55512-230-2 |
| Embedded Microprocessors                       | 272396             | 1-55512-231-0 |
| Flash Memory (2 vol. set)                      | 210830             | 1-55512-232-9 |
| Intel486™ Microprocessors and Related Products | 241731             | 1-55512-235-3 |
| i960® Processors and Related Products          | 272084             | 1-55512-234-5 |
| Military and Special Products                  | 210461             | N/A           |
| Networking                                     | 297360             | 1-55512-236-1 |
| OEM Boards, Systems and Software               | 280407             | 1-55512-237-X |
| Packaging                                      | 240800             | 1-55512-238-8 |
| Pentium™ Processors and Related Products       | 241732             | 1-55512-239-6 |
| Peripheral Components                          | 296467             | 1-55512-240-X |

A complete set of this information is available on CD-ROM through Intel's Data on Demand program, order number 240897. For information about Intel's Data on Demand ask for item number 240952.



# Flash Memory Volume 1

Synchronous and DRAM-Interface Components, FlashFile TM Components, Boot Block Components, Bulk-Erase Components

Information in this document is provided solely to enable use of Intel products. Intel assumes no liability whatsoever, including infringement of any patent or copyright, for sale and use of Intel products except as provided in Intel's Terms and Conditions of Sale for such products.

Intel Corporation makes no warranty for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

Intel retains the right to make changes to these specifications at any time, without notice.

Contact your local Intel sales office or your distributor to obtain the latest specifications before placing your product order.

MDS is an ordering code only and is not used as a product name or trademark of Intel Corporation.

Intel Corporation and Intel's FASTPATH are not affiliated with Kinetics, a division of Excelan, Inc. or its FASTPATH trademark or products.

\*Other brands and names are the property of their respective owners.

Additional copies of this document or other Intel literature may be obtained from:

Intel Corporation Literature Sales P.O. Box 7641 Mt. Prospect, IL 60056-7641 or call 1-800-879-4683

©INTEL CORPORATION, 1995



# **DATASHEET DESIGNATIONS**

Intel uses various datasheet markings to designate each phase of the document as it relates to the product. The markings appear in the lower inside corner of each datasheet page. Following are the definitions of each marking:

| <b>Datasheet Marking</b> | Description                                                                                                                                                                                   |  |  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Product Preview          | Contains information on products in the design phase of development. Do not finalize a design with the information. Revised information will be published when the product becomes available. |  |  |
| Advanced Information     | Contains information on products being sampled or in the initial production phase of development.*                                                                                            |  |  |
| Preliminary              | Contains preliminary information on new products in production.*                                                                                                                              |  |  |
| No Marking               | Contains information on products in full production.*                                                                                                                                         |  |  |

<sup>\*</sup> Specifications within these datasheets are subject to change without notice. Verify with your local Intel sales office that you have the latest datasheet before finalizing a design.





| <b>Memory Overview</b>                                                        | 1   |
|-------------------------------------------------------------------------------|-----|
| Flash Memory Overview and Support Tools                                       | 2   |
| Synchronous & DRAM-Interface Flash Memory Components and FlashFile Components | 3   |
| <b>Boot Block Components</b>                                                  | 4   |
| Bulk-Erase Components                                                         | 5   |
| PCMCIA Flash Memory Cards                                                     | 6   |
| PCMCIA-ATA Flash Memory<br>Drives                                             | 7   |
| Flash Automotive Components                                                   | 8   |
| Process Engineering Reports                                                   | 9 ; |





Flash Memory SmartDie<sup>TM</sup> Products

Article Reprints

10

11





# **Table of Contents**

| Alphanumeric Index                                                             | χV             |
|--------------------------------------------------------------------------------|----------------|
| CHAPTER 1                                                                      |                |
| Memory Overview                                                                |                |
| Intel Memory Technologies                                                      | 1-1            |
| CHAPTER 2                                                                      |                |
| Flash Memory Overview and Support Tools                                        |                |
| Flash Memory Overview                                                          | 2-1            |
| SUPPORT TOOLS                                                                  |                |
| Flash Memory Customer Support                                                  | 2-7            |
| Sprint PLUS48/Intel Support Version                                            | 2-9            |
| Multi-APRO Programmer/Intel Support Version                                    | 2-13           |
| Flash Memory Card and Flash Drive Evaluation Kit Product Brief                 | 2-16           |
| Small Outline Package Guide Overview                                           | 2-18           |
| Intel FLASHBuilder Software Product Brief                                      | 2-20           |
| APPLICATION NOTES                                                              |                |
| AP-357 Power Supply Solutions for Flash Memory                                 | 2-22           |
| AP-374 Flash Memory Write Protection Techniques                                | 2-64<br>2-71   |
| AB-29 Flash Memory Applications in Laser Printers TECHNICAL PAPER              | 2-71           |
| Small and Low Cost Power Supply Solution for Intel's Flash Memory Products     | 2-78           |
|                                                                                | 2-70           |
| CHAPTER 3                                                                      |                |
| Synchronous and DRAM-Interface Flash Memory Components                         |                |
| PRODUCT BRIEFS Intel 28F016XS Embedded Flash RAM Product Brief                 | 0.4            |
| Intel 28F016XS Embedded Flash RAM Product Brief                                | 3-1<br>3-2     |
| DATA SHEETS                                                                    | 3-2            |
| 28F016XS 16-Mbit (1-Mbit x 16, 2-Mbit x 8) Synchronous Flash Memory            | 3-3            |
| 28F016XD 16-Mbit (1-Mbit x 16) DRAM - Interface Flash Memory                   | 3-50           |
| APPLICATION NOTES                                                              | 0 00           |
| AB-58 28F016XD - Based SIMM Designs                                            | 3-104          |
| AP-398 Designing with the 28F016XS                                             | 3-112          |
| AP-384 Designing with the 28F016XD                                             | 3-142          |
| AP-600 Performance Benefits and Power/Energy Savings of 28F016XS-Based         |                |
| System Designs                                                                 | 3-172          |
| TECHNICAL PAPERS                                                               |                |
| Interfacing the 28F016XS to the i960® Microprocessor Family                    |                |
| Interfacing the 28F016XS to the Intel486™ Microprocessor Family                | 3-238          |
| FlashFile <sup>TM</sup> Components                                             |                |
| DATA SHEETS  DD0050000A 00 Mhit (0 Mhit v 16 A Mhit v 0) FloobFile Memory      | 0.057          |
| DD28F032SA 32-Mbit (2-Mbit x 16, 4-Mbit x 8) FlashFile Memory                  | 3-257<br>3-303 |
| 28F016SA 16-Mbit (1-Mbit x 16, 2-Mbit x 8) FlashFile Memory                    | 3-359          |
| Extended Temperature 28F016SA 16-Mbit (1-Mbit x 16, 2-Mbit x 8) FlashFile      | 0-009          |
| Memory                                                                         | 3-403          |
| 28F008SA 8-Mbit (1-Mbit x 8) FlashFile Memory (Extended Temperature            | 0 100          |
| Specifications Included)                                                       | 3-443          |
| 28F008SA-L 8 Mbit (1Mbit x 8) Flash Memory                                     | 3-476          |
| APPLICATION NOTES                                                              |                |
| AP-607 Multi-Site Layout Planning with Intel's FlashFile Components, Including |                |
| ROM Compatibility                                                              | 3-504          |



# Table of Contents (Continued)

| AP-393 28F016SV Compatibility with 28F016SA                                | 3-533   |
|----------------------------------------------------------------------------|---------|
| AP-359 28F008SA Hardware Interfacing                                       | 3-551   |
| AP-360 28F008SA Software Drivers                                           | 3-562   |
| AP-362 Implementing Mobile PC Designs Using High Density FlashFile         |         |
| Components                                                                 | 3-585   |
| AP-364 28F008SA Automation and Algorithms                                  | 3-640   |
| AP-375 Upgrade Considerations from the 28F008SA to the 28F016SA            | 3-654   |
| AP-377 16-Mbit Flash Product Family Software Drivers 28F016SA, 28F016SV,   |         |
| 28F016XS, 28F016XD                                                         | 3-667   |
| AP-378 System Optimization Using the Enhanced Features of the 28F016SA     | 3-722   |
| AP-399 Implementing Mobile Intel486 SX Microprocessor PC Designs Using     |         |
| FlashFile™ Components                                                      | 3-743   |
| ENGINEERING REPORT                                                         | 0 , ,0  |
| ER-27 The Intel 28F008SA Flash Memory                                      | 3-783   |
|                                                                            | 0 , 00  |
| CHAPTER 4                                                                  |         |
| Boot Block Components                                                      |         |
| DATA SHEETS                                                                |         |
| 8-Mbit (512K x 16, 1-Mbit x 8) SmartVoltage Boot Block Flash Memory Family | 4-1     |
| 4-Mbit (256K x 16, 512K x 8) SmartVoltage Boot Block Flash Memory Family   |         |
| (Extended Temperature Specifications Included)                             | 4-13    |
| 2-Mbit (128K x 16, 256K x 8) SmartVoltage Boot Block Flash Memory Family   |         |
| (Extended Temperature Specifications Included)                             | 4-68    |
| 28F400BX-T/B, 28F004BX-T/B 4 Mbit (256K x 16, 512K x 8) Boot Block Flash   |         |
| Memory Family                                                              | 4-124   |
| 28F400BL-T/B, 28F004BL-T/B 4-Mbit (256K x 16, 512K x 8) Low Power Boot     |         |
| Block Flash Memory Family                                                  | 4-174   |
| 28F200BX-T/B, 28F002BX-T/B 2 Mbit (128K x 16, 256K x 8) Boot Block Flash   | 7-1/7   |
| Memory Family                                                              | 4-218   |
| 28F200BL-T/B, 28F002BL-T/B 2-Mbit (128K x 16, 256K x 8) Low Power Boot     | 4-210   |
| Block Flash Memory Family                                                  | 4-265   |
| 28F001BX-T/28F001BX-B 1M (128K x 8) CMOS Flash Memory                      | 4-307   |
| APPLICATION NOTES                                                          | 4-307   |
|                                                                            |         |
| AP-604 Using Intel's Boot Block Flash Memory Parameter Blocks to Replace   | 4 0 4 4 |
| EEPROM                                                                     | 4-341   |
| AB-60 2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family Overview      | 4-349   |
| AP-341 Designing an Updatable BIOS Using Flash Memory                      | 4-357   |
| AP-363 Extended Flash Bios Concepts for Portable Computers                 | 4-400   |
| ENGINEERING REPORTS                                                        |         |
| ER-26 The Intel 28F001BX-T and 28F001BX-B Flash Memories                   | 4-422   |
| ER-29 The Intel 2/4-Mbit Boot Block Flash Memory Family                    | 4-437   |
| TECHNICAL PAPER                                                            |         |
| Boot Block Flash: The Next Generation White Paper                          | 4-466   |
| CHAPTER 5                                                                  |         |
| Bulk-Erase Components                                                      |         |
| DATA SHEETS                                                                |         |
| 28F020 2048K (256K x 8) CMOS Flash Memory                                  | 5-1     |
| 28F010 1024K (128K x 8) CMOS Flash Memory                                  |         |
|                                                                            | 5-64    |
| 28F512 512K (64K x 8) CMOS Flash Memory                                    | 5-04    |



# **Table of Contents (Continued)**

| 28F256A 256K (32K x 8) CMOS Flash Memory                                                                                                                | 5-92           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| AP-316 Using Flash Memory for In-System Reprogrammable Nonvolatile Storage . AP-325 Guide to First Generation Flash Memory Programming                  | 5-117<br>5-162 |
| ER-24 Intel Flash Memory 28F256A, 28F512, 28F010, 28F020                                                                                                | 5-184          |
| CHAPTER 6                                                                                                                                               |                |
| PCMCIA Flash Memory Cards                                                                                                                               |                |
| Series 2+ Flash Memory Card User's Manual OverviewDATA SHEETS                                                                                           | 6-1            |
| Series 2 + Flash Memory Cards 4-, 8-, 20- and 40-Megabyte                                                                                               | 6-2            |
| iMC020FLSA (Extended Temperature Specifications Included)                                                                                               | 6-42           |
| iMC004FLKA 4-Megabyte Flash Memory CardiMC002FLKA 2-Mbyte Flash Memory Card                                                                             | 6-80<br>6-110  |
| iMC001FLKA 1-Megabyte Flash Memory CardiMC001FLKA 1-Megabyte Flash Memory Card                                                                          | 6-140          |
| APPLICATION NOTES                                                                                                                                       | 0-140          |
| AP-606 Interchangeability of Series 1, Series 2 and Series 2+ Flash Memory                                                                              |                |
| Cards                                                                                                                                                   | 6-170          |
| AP-343 Solutions for High Density Applications Using Intel Flash Memory AP-361 Implementing the Integrated Registers of the Series 2 Flash Memory Card. | 6-185<br>6-215 |
| SUPPORT TOOLS                                                                                                                                           |                |
| Flash Memory Card and Flash Drive Evaluation Kit Product Brief                                                                                          | 6-232          |
| TECHNICAL PAPER Intel FlashFile Memory-The Key to Diskless Mobile PCs                                                                                   | 6.004          |
|                                                                                                                                                         | 6-234          |
| CHAPTER 7                                                                                                                                               |                |
| PCMCIA-ATA Flash Memory Drives                                                                                                                          |                |
| DATA SHEET iFD005P2SA/iFD010P2SA Flash Drive                                                                                                            | 7-1            |
| DESIGN GUIDE                                                                                                                                            | 7-1            |
| Flash Drive Design Guide (for iFD005P2SA/iFD010P2SA)                                                                                                    | 7-46           |
| SUPPORT TOOLS                                                                                                                                           |                |
| Flash Memory Card and Flash Drive Evaluation Kit Product Brief                                                                                          | 7-118          |
| CHAPTER 8                                                                                                                                               |                |
| Flash Automotive Components                                                                                                                             |                |
| DATA SHEETS  ACCEPTAGE TO A Maria (OFC) ( ) 40 F10 ( ) Constant ( ) It and Block Floor                                                                  |                |
| A28F400BR-T/B 4-Mbit (256K x 16, 512K x 8) SmartVoltage Boot Block Flash Memory Family                                                                  | 8-1            |
| A28F400BX-T/B 4-Mbit (256K x 16, 512K x 8) Boot Block Flash Memory Family                                                                               | 8-35           |
| A28F200BR-T/B 2-Mbit (128K x 16, 256K x 8) SmartVoltage Boot Block Flash                                                                                | 0 00           |
| Memory Family                                                                                                                                           | 8-69           |
| A28F200BX-T/B 2-Mbit (128K x 16, 256K x 8) Boot Block Flash Memory Family                                                                               | 8-102          |
| A28F010 1024K (128K x 8) CMOS Flash Memory                                                                                                              |                |
| A28F512 512K (64K x 8) CMOS Flash Memory                                                                                                                | 8-158<br>8-182 |
| CHAPTER 9                                                                                                                                               | 0-102          |
|                                                                                                                                                         |                |
| Process Engineering Reports ER-20 ETOX II Flash Memory Technology                                                                                       | 9-1            |
| ER-28 ETOX III Flash Memory Technology                                                                                                                  | 9-6            |



# Table of Contents (Continued)

| ER-33 ETOX IV Flash Memory Technology: Insight to Intel's Fourth Generation Process Innovation | 9-19  |
|------------------------------------------------------------------------------------------------|-------|
| CHAPTER 10                                                                                     |       |
| Flash Memory SmartDie™ Products                                                                |       |
| DATA SHEETS                                                                                    |       |
| 28F010 1024K (128K x 8) Flash Memory                                                           | 10-1  |
| 28F020 2048K (256K x 8) Flash Memory                                                           | 10-9  |
| 28F008SA 8 Mbit (1 Mbit x 8) Flash Memory                                                      | 10-17 |
| 28F400BX-T 4 Mbit (256K x 16, 512K x 8) Boot Block Flash Memory                                | 10-25 |
| 28F001BX-T/B 1M (128K x 8) CMOS Flash Memory                                                   | 10-33 |
| CHAPTER 11                                                                                     |       |
| Article Reprints                                                                               | 1     |
| AR-710 Flash Solid-State Drive with 6 MBs Read/Write Channel and Data                          |       |
| Compression                                                                                    | 11-1  |
| AR-711 Flash: Big New in Storage?                                                              | 11-4  |
| AR-715 Flash Memory: Meeting the Needs of Mobile Computing                                     | 11-8  |
| AR-716 Flash Memory for Top Speeds in Mobile Computing Applications                            | 11-16 |
| AR-717 The Many Facts of Flash Memory                                                          | 11-18 |
| · · · · · · · · · · · · · · · · · · ·                                                          | 11-28 |
| AR-723 Interfacing BootBlock Flash Memories to the MCS 96 Family                               | 11-32 |



# Alphanumeric Index

| OREOUT DY TYPOCOUT DY DIAM (4 00)/ VION CHOCK Flock Marrian                         | 4 007 |
|-------------------------------------------------------------------------------------|-------|
| 28F001BX-T/28F001BX-B 1M (128K x 8) CMOS Flash Memory                               | 4-307 |
| 28F001BX-T/B 1M (128K x 8) CMOS Flash Memory                                        | 10-33 |
| 28F008SA 8 Mbit (1 Mbit x 8) Flash Memory                                           | 10-17 |
| 28F008SA 8-Mbit (1-Mbit x 8) FlashFile™ Memory (Extended Temperature Specifications |       |
| Included)                                                                           | 3-443 |
| 28F008SA-L 8 Mbit (1Mbit x 8) Flash Memory                                          | 3-476 |
| 28F010 1024K (128K x 8) CMOS Flash Memory                                           | 5-33  |
| 28F010 1024K (128K x 8) Flash Memory                                                | 10-1  |
| 28F016SA 16-Mbit (1-Mbit x 16, 2-Mbit x 8) FlashFile Memory                         | 3-359 |
| 28F016SV 16-Mbit (1-Mbit x 16, 2-Mbit x 8) FlashFile Memory                         |       |
| 20F0103VD 10-Mibit (1-Mibit X 10, 2-Mibit X 0) Flashfille Methods                   | 3-303 |
| 28F016XD 16-Mbit (1-Mbit x 16) DRAM - Interface Flash Memory                        | 3-50  |
| 28F016XS 16-Mbit (1-Mbit x 16, 2-Mbit x 8) Synchronous Flash Memory                 | 3-3   |
| 28F020 2048K (256K x 8) CMOS Flash Memory                                           | 5-1   |
| 28F020 2048K (256K x 8) Flash Memory                                                | 10-9  |
| 28F200BL-T/B, 28F002BL-T/B 2-Mbit (128K x 16, 256K x 8) Low Power Boot Block Flash  |       |
| Memory Family                                                                       | 4-265 |
| 28F200BX-T/B, 28F002BX-T/B 2 Mbit (128K x 16, 256K x 8) Boot Block Flash Memory     |       |
| Family                                                                              | 4-218 |
| 28F256A 256K (32K x 8) CMOS Flash Memory                                            | 5-92  |
| 28F400BL-T/B, 28F004BL-T/B 4-Mbit (256K x 16, 512K x 8) Low Power Boot Block Flash  | 3-32  |
|                                                                                     | 4 474 |
| Memory Family                                                                       | 4-174 |
| 28F400BX-T 4 Mbit (256K x 16, 512K x 8) Boot Block Flash Memory                     | 10-25 |
| 28F400BX-T/B, 28F004BX-T/B 4 Mbit (256K x 16, 512K x 8) Boot Block Flash Memory     |       |
| Family                                                                              | 4-124 |
| 28F512 512K (64K x 8) CMOS Flash Memory                                             | 5-64  |
| 2-Mbit (128K x 16, 256K x 8) SmartVoltage Boot Block Flash Memory Family (Extended  |       |
| Temperature Specifications Included)                                                | 4-68  |
| 4-Mbit (256K x 16, 512K x 8) SmartVoltage Boot Block Flash Memory Family (Extended  | •     |
| Temperature Specifications Included)                                                | 4-13  |
| 8-Mbit (512K x 16, 1-Mbit x 8) SmartVoltage Boot Block Flash Memory Family          | 4-1   |
| A28F010 1024K (128K x 8) CMOS Flash Memory                                          | 8-135 |
| A28F200BR-T/B 2-Mbit (128K x 16, 256K x 8) SmartVoltage Boot Block Flash Memory     | 0-100 |
|                                                                                     | 8-69  |
| Family                                                                              |       |
|                                                                                     | 8-102 |
| A28F256A 256K (32K x 8) CMOS Flash Memory                                           | 8-182 |
| A28F400BR-T/B 4-Mbit (256K x 16, 512K x 8) SmartVoltage Boot Block Flash Memory     |       |
| Family                                                                              | 8-1   |
| A28F400BX-T/B 4-Mbit (256K x 16, 512K x 8) Boot Block Flash Memory Family           | 8-35  |
| A28F512 512K (64K x 8) CMOS Flash Memory                                            | 8-158 |
| AB-29 Flash Memory Applications in Laser Printers                                   | 2-71  |
| AB-58 28F016XD - Based SIMM Designs                                                 | 3-104 |
| AB-60 2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family Overview               | 4-349 |
| AP-316 Using Flash Memory for In-System Reprogrammable Nonvolatile Storage          | 5-117 |
| AP-325 Guide to First Generation Flash Memory Programming                           | 5-162 |
| AP 244 Designing on Undertable PLOS Height Floor Manner                             |       |
| AP-341 Designing an Updatable BIOS Using Flash Memory                               | 4-357 |
| AP-343 Solutions for High Density Applications Using Intel Flash Memory             | 6-185 |
| AP-357 Power Supply Solutions for Flash Memory                                      | 2-22  |
| AP-359 28F008SA Hardware Interfacing                                                | 3-551 |
| AP-360 28F008SA Software Drivers                                                    | 3-562 |
| AP-361 Implementing the Integrated Registers of the Series 2 Flash Memory Card      | 6-215 |
| AP-362 Implementing Mobile PC Designs Using High Density FlashFile Components       | 3-585 |
| AP-363 Extended Flash Bios Concepts for Portable Computers                          | 4-400 |



# Alphanumeric Index (Continued)

| AP-364 28F008SA Automation and Algorithms                                           | 3-640<br>2-64 |
|-------------------------------------------------------------------------------------|---------------|
| AP-375 Upgrade Considerations from the 28F008SA to the 28F016SA                     | 3-654         |
| AP-375 Opgrade Considerations from the 2010/08A to the 2010/08A                     | 3-054         |
| AP-377 16-Mbit Flash Product Family Software Drivers 28F016SA, 28F016SV, 28F016XS,  | 0.007         |
| 28F016XD                                                                            | 3-667         |
| AP-378 System Optimization Using the Enhanced Features of the 28F016SA              | 3-722         |
| AP-384 Designing with the 28F016XD                                                  | 3-142         |
| AP-393 28F016SV Compatibility with 28F016SA                                         | 3-533         |
| AP-398 Designing with the 28F016XS                                                  | 3-112         |
| AP-399 Implementing Mobile Intel486™ SX Microprocessor PC Designs Using FlashFile   |               |
| Components                                                                          | 3-743         |
| AP-600 Performance Benefits and Power/Energy Savings of 28F016XS-Based System       |               |
| Designs                                                                             | 3-172         |
| AP-604 Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM     | 4-341         |
| AP-606 Interchangeability of Series 1, Series 2 and Series 2+ Flash Memory Cards    | 6-170         |
| AP-607 Multi-Site Layout Planning with Intel's FlashFile Components, Including ROM  |               |
| Compatibility                                                                       | 3-504         |
| AR-710 Flash Solid-State Drive with 6 MBs Read/Write Channel and Data Compression   | 11-1          |
| AR-711 Flash: Big New in Storage?                                                   | 11-4          |
| AR-715 Flash Memory: Meeting the Needs of Mobile Computing                          | 11-8          |
| AR-716 Flash Memory for Top Speeds in Mobile Computing Applications                 | 11-16         |
| AR-717 The Many Facts of Flash Memory                                               | 11-18         |
| AR-718 Standardizing on a Flash File System                                         | 11-28         |
| AR-723 Interfacing BootBlock Flash Memories to the MCS 96 Family                    | 11-32         |
| Boot Block Flash: The Next Generation White Paper                                   | 4-466         |
| DD28F032SA 32-Mbit (2-Mbit x 16, 4-Mbit x 8) FlashFile Memory                       | 3-257         |
|                                                                                     | 3-257<br>9-1  |
| ER-20 ETOX II Flash Memory Technology                                               |               |
| ER-24 Intel Flash Memory 28F256A, 28F512, 28F010, 28F020                            | 5-184         |
| ER-26 The Intel 28F001BX-T and 28F001BX-B Flash Memories                            | 4-422         |
| ER-27 The Intel 28F008SA Flash Memory                                               | 3-783         |
| ER-28 ETOX III Flash Memory Technology                                              | 9-6           |
| ER-29 The Intel 2/4-Mbit Boot Block Flash Memory Family                             | 4-437         |
| ER-33 ETOX IV Flash Memory Technology: Insight to Intel's Fourth Generation Process |               |
| Innovation                                                                          | 9-19          |
| Extended Temperature 28F016SA 16-Mbit (1-Mbit x 16, 2-Mbit x 8) FlashFile Memory    | 3-403         |
| Flash Drive Design Guide (for iFD005P2SA/iFD010P2SA)                                | 7-46          |
| Flash Memory Card and Flash Drive Evaluation Kit Product Brief                      | 7-118         |
| Flash Memory Card and Flash Drive Evaluation Kit Product Brief                      | 6-232         |
| Flash Memory Card and Flash Drive Evaluation Kit Product Brief                      | 2-16          |
| Flash Memory Customer Support                                                       | 2-7           |
| Flash Memory Overview                                                               | 2-1           |
| iFD005P2SA/iFD010P2SA Flash Drive                                                   | 7-1           |
| iMC001FLKA 1-Megabyte Flash Memory Card                                             | 6-140         |
| iMC002FLKA 2-Mbyte Flash Memory Card                                                | 6-110         |
| iMC004FLKA 4-Megabyte Flash Memory Card                                             | 6-80          |
| Intel 28F016XD Embedded Flash RAM Product Brief                                     | 3-2           |
| Intel 28F016XS Embedded Flash RAM Product Brief                                     | 3-1           |
| Intel FLASHBuilder Software Product Brief                                           | 2-20          |
| Intel FlashFile Memory-The Key to Diskless Mobile PCs                               | 6-234         |
|                                                                                     | 1-1           |
| Intel Memory Technologies                                                           | 3-238         |
| Interfacing the 20F016VS to the interface wildroprocessor Family                    |               |
| Interfacing the 28F016XS to the i960® Microprocessor Family                         | 3-196         |

### ALPHANUMERIC INDEX



# Alphanumeric Index (Continued)

| Multi-APRO Programmer/Intel Support Version                                | 2-13 |
|----------------------------------------------------------------------------|------|
| Series 2 Flash Memory Cards iMC002FLSA/iMC004FLSA/iMC010FLSA/iMC020FLSA    |      |
| (Extended Temperature Specifications Included)                             | 6-42 |
| Series 2+ Flash Memory Card User's Manual Overview                         |      |
| Series 2+ Flash Memory Cards 4-, 8-, 20- and 40-Megabyte                   | 6-2  |
| Small and Low Cost Power Supply Solution for Intel's Flash Memory Products | 2-78 |
| Small Outline Package Guide Overview                                       | 2-18 |
| Sprint PLUS48/Intel Support Version                                        | 2-9  |



intel<sub>®</sub>.

1

**Memory Overview** 





Most of this handbook is devoted to techniques and information to help you design and implement semi-conductor memory in your application or system. In this section, however, the memory chip itself will be examined and the processing technology required to turn a bare slice of silicon into high performance memory devices is described. The discussion has been limited to the basics of MOS (Metal Oxide Semiconductor) technologies as they are responsible for the majority of memory devices manufactured at Intel.

There are three major MOS technology families—PMOS, NMOS, and CMOS (Figure 1). They refer to the channel type of the MOS transistors made with the technology. PMOS technologies implement p-channel transistors by diffusing p-type dopants (usually boron) into an n-type silicon substrate to form the source and drain. P-channel is so named because the channel is comprised of positively charged carriers. NMOS technologies are similar, but use n-type dopants (normally phosphorus or arsenic) to make n-channel transistors in p-type silicon substrates. N-channel is so named because the

channel is comprised of negatively charged carriers. CMOS or Complementary MOS technologies combine both p-channel and n-channel devices on the same silicon. Either p- or n-type silicon substrates can be used, however, deep areas of the opposite doping type (called wells) must be defined to allow fabrication of the complementary transistor type.

Most of the early semiconductor memory devices, like Intel's pioneering 1103 dynamic RAM and 1702 EPROM were made with PMOS technologies. As higher speeds and greater densities were needed, most new devices were implemented with NMOS. This was due to the inherently higher speed of n-channel charge carriers (electrons) in silicon along with improved process margins. CMOS technology has begun to see widespread commercial use in memory devices. It allows for very low power devices used for battery operated or battery back-up applications. Historically, CMOS has been slower than any NMOS device. Today, CMOS technology has been improved to produce higher speed devices.



**Figure 1. MOS Process Cross-sections** 



In the following section, the basic fabrication sequence for an HMOS circuit will be described. HMOS is a high performance n-channel MOS process developed by Intel for 5V single supply circuits. HMOS, and CHMOS, CHMOS-E (EPROM) and ETOX (Flash Memory), along with their evolutionary counterparts comprise the process family responsible for most of the memory components produced by Intel today.

The MOS IC fabrication process begins with a slice (or wafer) of single crystal silicon. Typically, it's 150 or 200 millimeter in diameter, about a half millimeter thick, and uniformly doped p-type. The wafer is then oxidized in a furnace at around 1000°C to grow a thin layer of silicon dioxide (SiO2) on the surface. Silicon nitride is then deposited on the oxidized wafer in a gas phase chemical reactor. The wafer is now ready to receive the first pattern of what is to become a many layered complex circuit. The pattern is etched into the silicon nitride using a process known as photolithography, which will be described in a later section. This first pattern (Figure 2) defines the boundaries of the active regions of the IC, where transistors, capacitors, diffused resistors, and first level interconnects will be made.



Figure 2. First Mask

The patterned and etched wafer is then implanted with additional boron atoms accelerated at high energy. The boron will only reach the silicon substrate where the nitride and oxide was etched away, providing areas doped strongly p-type that will electrically separate active areas. After implanting, the wafers are oxidized again and this time a thick oxide is grown. The oxide only grows in the etched areas due to silicon nitride's properties as an oxidation barrier. When the oxide is grown, some of the silicon substrate is consumed and this gives a physical as well as electrical isolation for adjacent devices as can be seen in Figure 3.



Figure 3. Post Field Oxidation

Having fulfilled its purpose, the remaining silicon nitride layer is removed. A light oxide etch follows taking with it the underlying first oxide but leaving the thick (field) oxide.

Now that the areas for active transistors have been defined and isolated, the transistor types needed can be determined. The wafer is again patterned and then if special characteristics (such as depletion mode operation) are required, it is implanted with dopant atoms. The energy and dose at which the dopant atoms are implanted determines much of the transistor's characteristics. The type of the dopant provides for depletion mode (n-type) or enhancement mode (p-type) operation.

The transistor types defined, the gate oxide of the active transistors are grown in a high temperature furnace. Special care must be taken to prevent contamination or inclusion of defects in the oxide and to ensure uniform consistent thickness. This is important to provide precise, reliable device characteristics. The gate oxide layer is then masked and holes are etched to provide for direct gate to diffusion ("buried") contacts where needed.

The wafers are now deposited with a layer of gate material. This is typically poly crystaline silicon ("poly") which is deposited in a gas phase chemical reactor similar to that used for silicon nitride. The poly is then doped (usually with phosphorus) to bring the sheet resistance down to  $10-20~\Omega/\mathrm{square}$ . This layer is also used for circuit interconnects and if a lower resistance is required, a refractory metal/poly-silicon composite or refractory metal silicide can be used instead. The gate layer is then patterned to define the actual transistor gates and interconnect paths (Figure 4).



Figure 4. Post Gate Mask

The wafer is next diffused with n-type dopant (typically arsenic or phosphorus) to form the source and drain junctions. The transistor gate material acts as a barrier to the dopant providing an undiffused channel self-aligned to the two junctions. The wafer is then oxidized to seal the junctions from contamination with a layer of SiO<sub>2</sub> (Figure 5).





Figure 5. Post Oxidation

A thick layer glass is then deposited over the wafer to provide for insulation and sufficiently low capacitance between the underlying layers and the metal interconnect signals. (The lower the capacitance, the higher the inherent speed of the device.) The glass layer is then patterned with contact holes and placed in a high temperature furnace. This furnace step smooths the class surface and rounds the contact edges to provide uniform metal coverage. Metal (usually aluminum or aluminum/silicon) is then deposited on the wafer and the interconnect patterns and external bonding pads are defined and etched (Figure 6). The wafers then receive a low temperature (approximately 500°C) alloy that insures good ohmic contact between the aluminum and diffusion or poly.



Figure 6. Complete Circuit (without passivation)

At this point the circuit is fully operational, however, the top metal layer is very soft and easily damaged by handling. The device is also susceptible to contamination or attack from moisture. To prevent this the wafers are sealed with a passivation layer of silicon nitride or a silicon and phosphorus oxide composite. Patterning is done for the last time opening up windows only over the bond pads where external connections will be made.

This completes basic fabrication sequence for a single poly layer process. Double poly processes such as those used for high density Dynamic RAMs, EPROMs, flash memories, and EEPROMs follow the same general process flow with the addition of gate, poly deposition, doping, and interlayer dielectric process modules required for the additional poly layer (Figure 7). These steps are performed right after the active areas have been defined (Figure 3) providing the capacitor or floating gate storage nodes on those devices.



Figure 7. Double Poly Structure

After fabrication is complete, the wafers are sent for testing. Each circuit is tested individually under conditions designed to determine which circuits will operate properly both at low temperature and at conditions found in actual operation. Circuits that fail these tests are noted to distinguish them from good circuits. From here the wafers are sent for assembly where they are sawed into individual circuits with a paper-thin diamond blade. The noted circuits are then separated out and the good circuits are sent on for packaging.

Packages fall into two categories—hermetic and non-hermetic. Hermetic packages are Cerdip, where two ceramic halves are sealed with a glass fritt, or ceramic with soldered metal lids. An example of hermetic package assembly is shown in Table 1. Non-hermetic packages are molded plastics.

The ceramic package has two parts, the base, which has the leads and die (or circuit) cavity, and the metal lid. The base is placed on a heater block and a metal alloy preform is inserted. The die is placed on top of the preform which bonds it to the package. Once attached, wires are bonded to the circuit and then connected to the leads. Finally the package is placed in a dry inert atmosphere and the lid is soldered on.

The cerdip package consists of a base, lead frame, and lid. The base is placed on a heater block and the lead frame placed on top. This sets the lead frame in glass attached to the base. The die is then attached and bonded to the leads. Finally the lid is placed on the package and it is inserted in a seal furnace where the glass on the two halves melt together making a hermetic package.

In a plastic package, the key component is the lead frame. The die is attached to a pad on the lead frame and bonded out to the leads with gold wires. The frame then goes to an injection molding machine and the package is formed around the lead frame. After mold the excess plastic is removed and the leads trimmed.



After assembly, the individual circuits are retested at an elevated operating temperature to assure critical operating parameters and separated according to speed and power consumption into individual specification groups. The finished circuits are marked and then readied for shipment.

The basic process flow described above may make VLSI device fabrication sound straightforward, however, there are actually hundreds of individual operations that must be performed correctly to complete a working circuit. It usually takes well over two months to complete all these operations and the many tests and measurements involved throughout the manufacturing process. Many of these details are responsible for ensuring the performance, quality, and reliability you expect from Intel products. The following sections will discuss the technology underlying each of the major process elements mentioned in the basic process flow.

## **PHOTOLITHOGRAPHY**

The photo or masking technology is the most important part of the manufacturing flow if for no other reason than the number of times it is applied to each wafer. The manufacturing process gets more complex in order to make smaller and higher performance circuits. As this happens the number of masking steps increases, the features get smaller, and the tolerance required becomes tighter. This is largely because the minimum size of individual pattern elements determine the size of the whole circuit, effecting its cost and limiting its potential complexity. Early MOS IC's used minimum geometries (lines or spaces) of 8-10 microns (1 micron =  $10^{-6}$ meter  $\approx 1/25.000$  inch). The n-channel processes of the mid 1970's brought this down to approximately 5 microns, and today minimum geometries of 0.8 and even 0.6 microns are in production. This dra-

**Table 1. Typical Hermetic Package Assembly** 

| Flow               | Process/Materials                   | Typical Item                                                                               | Frequency                                | Criteria                             |
|--------------------|-------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------------|
| Ŷ                  | Wafer                               |                                                                                            |                                          |                                      |
| ) þ                | Die saw, wafer break                | ·                                                                                          |                                          |                                      |
| <b> </b>           | Die wash and plate                  |                                                                                            |                                          |                                      |
| ļ ģ                | Die visual inspection               | Passivation, metal                                                                         | 100% of die                              |                                      |
|                    | QA gate                             |                                                                                            | Every lot                                | 0/76, LTPD = 5%                      |
|                    | Die attach<br>(Process monitor)     | Wet out                                                                                    | 4 × /operator/shift                      | 0/11 LTPD = 20%                      |
| ) · •              | Post die attach visual              |                                                                                            | 100% of devices                          |                                      |
|                    | Wire bond<br>(Process monitor)      | Orientation, lead dressing, etc.                                                           | 4 × /operator/<br>machine/shift          |                                      |
| ļģ                 | Post bond inspection                |                                                                                            | 100% devices                             |                                      |
|                    | QA gate                             | All previous items                                                                         | every lot                                | 1/129, LTPD = 3%                     |
|                    | Seal and Mark<br>(Process monitor)  | Cap align, glass<br>integrity, moisture                                                    | 4 x /furnace/shift                       | 0/15, LTPD = 15%                     |
| • •                | Temp cycle                          | '                                                                                          | 10 × to mil std.<br>883 cond. C          | 1/11, LTPD = 20%                     |
|                    | Hermeticity check (Process monitor) | F/G leak                                                                                   | 100% devices                             |                                      |
|                    | Lead Trim<br>(Process monitor)      | Burrs, etc. (visual)<br>Fine leak                                                          | 4 × /station/shift<br>2 × /station/shift | 0/15, LTPD = 15%<br>1/129, LTPD = 3% |
|                    | External visual                     | Solder voids, cap alignment, etc.                                                          | 100% devices                             |                                      |
| <del>-   -</del> > | QA gate                             | All previous items                                                                         | All lots                                 | 1/129, LTPD=3%                       |
|                    | Class test<br>(Process monitor)     | Run standards<br>(good and reject)<br>Calibrate every<br>system using<br>"autover" program | Every 48 hrs.                            | *                                    |
| امیا               | Mark and Pack                       |                                                                                            |                                          |                                      |
| 2.                 | Final QA                            | (See attached)                                                                             |                                          |                                      |

296102-11

#### NOTES:

- 1. Units for assembly reliability monitor.
- 2. Units for product reliability monitor.



matic reduction in feature size was achieved using the newer high resolution photo resists and optimizing their processing to match improved optical printing systems.

A second major factor in determining the size of the circuit is the registration or overlay error. This is how accurately one pattern can be aligned to a previous one. Design rules require that space be left in all directions according to the overlay error so that unrelated patterns do not overlap or interfere with one another. As the error space increases the circuit size increases dramatically. Only a few years ago standard alignment tolerances were  $\geq \pm 2$  microns; now advanced Intel processes have reduced this dramatically due mostly to the use of advanced projection and step and repeat exposure equipment.

The wafer that is ready for patterning must go through many individual steps before that pattern is complete. First the wafer is baked to remove moisture from its surface and is then treated with chemicals that ensure good resist adhesion. The thick photoresist liquid is then applied and the wafer is spun flat to give a uniform coating, critical for high resolution. The wafer is baked at a low temperature to solidify the resist into gel. It is then exposed with a machine that aligns a mask with the new pattern on it to a previously defined layer. The photo-resist will replicate this pattern on the wafer.

Negative working resists are polymerized by the light and the unexposed resist can be rinsed off with solvents. Positive working resists use photosensitive polymerization inhibitors that allow a chemically reactive developer to remove the exposed areas. The positive resists require much tighter control of exposure and development but yield higher resolution patterns than negative resistance systems.

The wafer is now ready to have its pattern etched. The etch procedure is specialized for each layer to be etched. Wet chemical etchants such as hydrofluoric acid for silicon oxide or phosphoric acid for aluminum are often used for this. The need for smaller features and tighter control of etched dimensions is increasing the use of plasma etching in fabrication. Here a reactor is run with a partial vacuum into which etchant gases are introduced and an electrical field is applied. This yields a reactive plasma which etches the required layer.

The wafer is now ready for the next process step. Its single journey through the masking process required the careful engineering of mechanics, optics, organic chemistry, inorganic chemistry, plasma chemistry, physics, and electronics.

### DIFFUSION

The picture of clean room garbed operators tending furnace tubes glowing cherry red is the one most often associated with IC fabrication. These furnace operations are referred to collectively as diffusion because they employ the principle of sold state diffusion of matter to accomplish their results. In MOS processing, there are three main types of diffusion operations: predeps, drives, and oxidations.

Predeposition, or "predep," is an operation where a dopant is introduced into the furnace from a solid, liquid, or gaseous source and at the furnace temperature (usually 900°C-1200°C) a saturated solution is formed at the silicon surface. The temperature of the furnace, the dopant atom, and rate of introduction are all engineered to give a specific dose of the dopant on the wafer. Once this is completed the wafer is given a drive cycle where the dopant left at the surface by the predep is driven into the wafer by high temperatures. These are generally at different temperatures than the predeps and are designed to give the required junction depth and concentration profile

Oxidation, the third category, is used at many steps of the process as was shown in the process flow. The temperature and oxidizing ambient can range from 800°C to 1200°C and from pure oxygen to mixtures of oxygen and other gases to steam depending on the type of oxide required. Gate oxides require high dielectric breakdown strength for thin layers (between 0.01 and 0.1 micron) and very tight control over thickness (typically  $\pm\,0.005$  micron or less than  $\pm\,1/5,000,000$  inch), while isolation oxides need to be quite thick and because of this their dielectric breakdown strength per unit thickness is much less important.

The properties of the diffused junctions and oxides are key to the performance and reliability of the finished device so the diffusion operations must be extremely well controlled for accuracy, consistency and purity.

## ION IMPLANT

Intel's high performance products require such high accuracy and repeatability of dopant control that even the high degree of control provided by diffusion operations is inadequate. However, this limitation has been overcome by replacing critical predeps with ion implantation. In ion implantation, ionized dopant atoms are accelerated by an electric field

## INTEL MEMORY TECHNOLOGIES



and implanted directly into the wafer. The acceleration potential determines the depth to which the dopant is implanted.

The charged ions can be counted electrically during implantation giving very tight control over dose. The ion implanters used to perform this are a combination of high vacuum system, ion source, mass spectrometer, linear accelerator, ultra high resolution current integrator, and ion beam scanner. You can see that this important technique requires a host of sophisticated technologies to support it.

## THIN FILMS

Thin film depositions make up most of the features on the completed circuit. They include the silicon nitride for defining isolation, polysilicon for the gate and interconnections, the glass for interlayer dielectric, metal for interconnection and external connections, and passivation layers. Thin film depositions are done by two main methods: physical deposition and chemical vapor deposition. Physical deposition is most common for deposition metal. Physical depositions are performed in a vacuum and are accomplished by vaporizing the metal with a high energy electron beam and redepositing it on the wafer or by sputtering it from a target to the wafer under an electric field.

Chemical vapor deposition can be done at atmospheric pressure or under a moderate vacuum. This type of deposition is performed when chemical gas-

es react at the wafer surface and deposit a solid film of the reaction product. These reactors, unlike their general industrial counterparts, must be controlled on a microscale to provide exact chemical and physical properties for thin films such as silicon dioxide, silicon nitride, and polysilicon.

The fabrication of modern memory devices is a long, complex process where each step must be monitored, measured and verified. Developing a totally new manufacturing process for each new product or even product line takes a long time and involves significant risk. Because of this, Intel has developed process families, such as HMOS, on which a wide variety of devices can be made. These families are scalable so that circuits need not be totally redesigned to meet your needs for higher performance.(1) They are evolutionary so that development time of new processes and products can be reduced without compromising Intel's commitment to consistency, quality, and reliability.

The manufacture of today's MOS memory devices requires a tremendous variety of technologies and manufacturing techniques, many more than could be mentioned here. Each requires a team of experts to design, optimize, control and maintain it. All these people and thousands of others involved in engineering, design, testing and production stand behind Intel's products.

(1)R. Pashley, K. Kokkonen, E. Boleky, R. Jecmen, S. Liu, and W. Owen, "H-MOS Scales Traditional Devices to Higher Performance Level," *Electronics*, August 18, 1977.

intel<sub>®</sub>

2

# Flash Memory Overview and Support Tools

2





# Flash Memory Overview

The ideal memory system optimizes density, nonvolatility, fast readability and cost effectiveness. While traditional memory technologies may individually exhibit one or more of these desired characteristics, no single memory technology has achieved all of them without major tradeoffs—until the introduction of Intel Flash Memory.

## WHAT IS FLASH MEMORY?

Introduced by Intel in 1988, ETOX flash memory is a high-density, truly nonvolatile and high performance read-write memory solution also characterized by low power consumption and extreme ruggedness and high reliability. The cost trend of Intel Flash Memory components continues to decline sharply due to: (1) manufacturing economies inherent in ETOX, Intel's industry-standard EPROM-based flash technology, (2) increases in memory density, and (3) rapid growth in production volume.

A comparison between Intel Flash Memory and other solid-state memory technologies underscores the fact that flash offers a design solution with distinct advantages. These advantages are key to future product differentiation for many applications requiring firmware updates or compact mass storage (Figure 1).

— ROM (read-only memory) is a mature, high density, nonvolatile, reliable and low cost memory technology widely used in PC and embedded applications. Once it is manufactured however, the contents of a ROM can never be altered. Additionally, initial ROM programming involves a time-consuming mask development process that requires stable code and is most cost-effective in high volumes.

Easy updatability makes flash memory clearly more flexible than ROM in most applications.

— SRAM (static random-access memory) is a high-speed, reprogrammable memory technology which is limited by its volatility and relatively low density. As a volatile memory technology, SRAM requires constant power to retain its contents. Built-in battery backup is therefore required when the main power source is turned off. Since battery failure is an inevitable fact of life, SRAM data loss is an everpresent danger. Additionally, SRAM requires four to six transistors to store one bit of information. This becomes a significant limitation in developing higher densities—effectively keeping SRAM cost relatively high.

Figure 1. Intel Flash Memory vs Traditional Memory Technologies

| Memory         | Inherently<br>Non-<br>Volatile | High<br>Density | Low<br>Power | One<br>Transistor<br>Cell | In-System<br>Re-<br>Writable | and Data | Alteranie | Blocking | Hands<br>off<br>Updates |
|----------------|--------------------------------|-----------------|--------------|---------------------------|------------------------------|----------|-----------|----------|-------------------------|
| Flash          | · 1                            | <u> </u>        | -            | <i>u</i>                  | 10                           | <i>u</i> |           | 10       | 10                      |
| SRAM + Battery |                                |                 |              |                           | ~                            | -        | ~         | <i>u</i> | <i>u</i>                |
| DRAM + Disk    |                                | <i>u</i>        |              |                           | -                            | <i>u</i> | <i>u</i>  | <i>u</i> | "                       |
| EEPROM         | ~                              |                 | "            |                           | "                            | -        | -         | -        | <i>u</i>                |
| OTP/EPROM      | ~                              | <i>u</i>        | <u></u>      | "                         |                              |          |           |          |                         |
| Masked ROM     | ~                              | "               | 1            | -                         |                              |          |           |          |                         |

### **FLASH MEMORY OVERVIEW**



In contrast, Intel flash memory is inherently nonvolatile, and the single transistor cell design of Intel's ETOX manufacturing process is extremely scalable, allowing the development of continuously higher densities and steady cost improvement over SRAM (Figure 2).



Figure 2

— EPROM (electrically programmable read-only memory) is a mature, high-density, nonvolatile technology which provides a degree of updatability not found in ROM. An OEM may program EPROM as needed to accommodate code changes or varying manufacturing unit quantities. Once programmed, however, the EPROM may only be erased by removing it from the system and then exposing the memory component to ultraviolet light—an impractical and time-consuming procedure for many OEMs and a virtually impossible task for end-users.

Unlike EPROM, flash memory is electrically re-writable within the host system, making it a much more flexible and easier to use alternative. Flash memory offers OEMs not only high density and nonvolatility, but higher functionality and the ability to differentiate their systems.

— EEPROM (electrically erasable programmable read-only memory) is nonvolatile and electrically byte-erasable. Such byte-alterability is needed in certain applications but involves a more complex cell structure, and significant trade-offs in terms of limited density, lower reliability and higher cost, making it unsuitable as a mainstream memory.

Unlike EEPROM, Intel flash memory technology utilizes a one-transistor cell, allowing higher densities, scalability, lower cost, and higher reliability, while taking advantage of in-system, electrical erasability (Figure 3).

| ·                                  | Intel<br>ETOX Flash | EEPROM |
|------------------------------------|---------------------|--------|
| Transistors                        | 1                   | 2      |
| Cell Size<br>(1-Micro Lithogrpahy) | 15μ                 | 38μ    |
| Cycling Features                   | 0.1%                | 5%     |

Figure 3

— DRAM (dynamic random access memory) is a volatile memory known for its density and low cost. Because of its volatility, however, it requires not only a constant power supply to retain data, but also an archival storage technology, such as disk, to back it up.

Partnered with hard disks for permanent mass storage, DRAM technology has provided a low-cost, yet space and power-hungry solution for today's PCs.

With ETOX process technology, Intel manufactures a flash memory cell that is 30% smaller than equivalent DRAM cells. Flash memory's scalability offers a price advantage as well, keeping price parity with DRAM, and also becoming more attractive as a hard disk replacement in portable systems as densities grow and costs decline.

Intel flash memory combines advantages from each of these memory technologies. In embedded memory applications, flash memory provides higher-performance and more flexibility than ROM and EPROM, while providing higher density and better cost effectiveness than battery-backed SRAM and EEPROM. Moreover, the true nonvolatility and low power consumption characteristics of flash memory make it a compelling alternative to DRAM in many applications.

## **ETOX III TECHNOLOGY**

Unlike other approaches to flash memory, Intel ETOX is a proven technology. As its name suggests, ETOX (or "EPROM tunnel oxide") technology evolved from EPROM. With 95% process compatibility with EPROM, ETOX taps experience gained from a mature high-volume manufacturing base pioneered by Intel in the 1970s.

Data retention and lifetime reliability statistics for ETOX III flash are equivalent to those of EPROM. Representing the third generation of Intel flash memory technology, the ETOX III O.8µ process provides <100 FITS (failures in time) @ 55°C in a specification that delivers 100,000 write cycles per block. This capability significantly exceeds the cycling requirements of even the most demanding applications.



For example, code storage for embedded control programs used in standard computer applications is infrequently updated. Twenty-year system lifetimes may require fewer than 100 rewrites. Even routinely-changed data tables (used in navigational computers and black box controllers) only require about 1,000 write cycles over a 20-year period. The most demanding flash memory application of all, archival data storage in PC applications, typically requires about 5,000 write cycles in 20 years.

ETOX flash memory's simple single-transistor cell structure makes it smaller than other flash cells, allowing designers to create highly integrated systems which are more reliable and cost-effective than those based on more complex and less mature flash technologies. The inherent scalability of ETOX III Flash Memory and high-volume manufacturing is enabling a corresponding downtrend in flash cost.

Flash memory has added a new dimension to nonvolatile memory applications. Embedded systems, such as PC BIOS, hard disk drive controllers and cellular telephone applications take advantage of the easy update capability, high density and high performance of Intel Flash Memory. Today's new generation of portable computers require the optimum combination of performance, size, weight, low power and shock resistance. Whether implemented in memory cards, solid state disks or at the component level, Intel's Flash Memories are also enabling a whole new generation of mobile computers.

# IMPLEMENTING INTEL FLASH MEMORY

Today, Intel continues to serve both updatable nonvolatile memory applications as well as the rapidly emerging solid-state mass storage applications with flash memory solutions tailored to meet the needs of these markets.

# **Updatable Code Storage**

Code and data storage comprise the updatable nonvolatile memory applications that require high performance, high density, and easy update capability. Because these applications are not updated as frequently as solid-state mass storage applications, erase/write cycles are not as critical as integration and performance requirements. This application segment is served effectively with full chip-erase or Boot Block products.

Intel's 28F001BX 1 Mbit Boot Block flash component. featuring a sectored architecture, has been widely accepted in embedded code storage applications, particularly in PC BIOS and cellular communications. By adopting Boot Block for their products, over 20 PC manufacturers have gained added flexibility and the ability to differentiate in a highly competitive market. End users also benefit from the ability to upgrade BIOS software quickly and securely. The blocked architecture allows the OEM to store critical system code securely in the lockable "boot block" of the device that can minimally bring up the system and download to other locations of the device to initialize the system. The hardware boot locking feature guarantees that even if the power is disrupted during a BIOS update, the system will be able to recover immediately.

In response to customer requests for speed, density, low power, surface-mount options and an industry-standard upgrade path for portable computing and telecommunications, Intel more recently introduced the 2 Mbit 28F200BX and 4 Mbit 28F400BX Boot Block products

These products offer 60 ns performance; two surface mount packages: 40-lead TSOP (X8 only) and 44-lead PSOP; and a proprietary Boot Block architecture similar to the 1 Mbit Boot Block device. The Boot Block stores the code necessary to initialize the system, while parameter blocks can be used to store manufacturing product code, setup parameters, and frequently updated code such as system diagnostics. The main operating code is stored in the main blocks. Both devices are available in a x16/x8 ROM-compatible pin-out in 44-lead PSOP surface mount packaging. These pinouts and packages allow an easy upgrade from 2 Mb to 4 Mb, since only one address is added to the 4 Mb device.

# Solid-State Mass Storage

This major application segment requires very high density memory, automated programming and high-performance erase/write capability at a very low cost per bit. Erasing and writing portions of the code or data is much more frequent in solid-state mass storage than in updatable firmware applications.

Intel's symmetrically blocked 8 Mbit 28F008SA Flash-File<sup>TM</sup> memory is the highest density nonvolatile read/ write solution for solid-state mass storage. What's more, it is the first flash memory device optimized for solid-state storage of software and data files.

The 28F008SA is packaged in an advanced 40-lead TSOP (thin, small outline package) or 44-lead PSOP (plastic SOP) to provide the extremely small form factor required for today's handheld, pen-based and sub-

<sup>\*</sup>Based on 10 MB card design, 5,000 cycle yields 50,000 MB of stored data, which far exceeds most usage environments and file system methodologies.

### **FLASH MEMORY OVERVIEW**



notebook portable computers. The compactness of an 8 Mbit device in a TSOP package allows for high-density flash arrays to be included both on a system mother-board for direct execution of user programs or operating systems, as well as memory cards for transportable program and file storage.

# **Memory Cards**

Intel's family of flash memory cards provides the most reliable and rugged form of removable memory media. High density, true nonvolatility, rewrite flexibility, and proven cost effectiveness make Intel Series 1 Flash Memory Cards the ideal medium for storing and updating application code as well as capturing data.

For file storage applications that require high performance, ruggedness, long battery life, small size and light weight, Intel's Series 2 Flash Memory Cards in 4-Mbyte, 10-Mbyte and 20-Mbyte densities provide the best solution. Based on Intel's 8-Mbit FlashFile memory components, the Series 2 card's block-erase functionality and high density take full advantage of flash filing systems like Microsoft\*'s Flash File System software to provide full disk emulation in the form of removable, nonvolatile storage. The cards conform to the PCMCIA 2.0/JEIDA 4.1 68-pin standards and are compatible with Intel's Exchangeable Card Architecture (ExcA<sup>TM</sup>) to ensure system-to-system interoperability.

## THE IMPETUS BEHIND THE "SOLID-STATE" DISK

Because the disk-based PC is so prevalent and eminently familiar to both designers and end-users, many of today's portable systems still rely on it as their primary medium. At the same time, disk drive manufacturers have made great strides toward improving the reliabili-

ty, size and performance of their systems, as well as the disk media themselves.

Yet the disk drive is an electro-mechanical system with inherent limitations. Any mechanical hardware is much more vulnerable than solid state semiconductor technology to the shock, vibration, and impurities that portable PCs encounter during normal use. Hard disk drives can typically withstand up to 10Gs of operating shock; Intel FlashFile memory, with no moving parts, can withstand as much as 1000Gs. Additionally, Intel's Series 2 Memory Cards feature approximately 1.6 million hours mean time between failure (MTBF). Such endurance and reliability is essential for many of today's truly mobile handheld palmtop and notebook sized PCs, particularly within applications requiring extreme data integrity.

Power consumption is another major consideration for today's mobile PC designer and user. The drive typically requires anywhere from 3 watts to as many as 8 watts of power to run—which means rapid drain of the system's batteries. Compare this to flash memory in a hard disk configuration. It consumes less than one two-hundredth the average power of a comparable magnetic disk drive based on the typical user model. At the chip level, the 8 Mbit FlashFile Memory component has a DEEP POWERDOWN mode that reduces power consumption to less than 0.2  $\mu$ A.

Additional shortcomings of disk drives are their size, weight and floor costs. Magnetic drives do not scale well, that is, it becomes increasingly difficult to improve or even retain density as platter size shrinks. Thus, every reduction in drive size requires complete retooling and costly learning. Also, the complex controller circuitry provides a price floor under which magnetic drives cannot drop. Since flash is scalable, at some point in the near future, small magnetic drives are likely to become more expensive per Mbyte than flash cards and are certain to have less capacity.

|                                       | Disk/DRAM                                         | Flash                                                      |
|---------------------------------------|---------------------------------------------------|------------------------------------------------------------|
| Average Seek Time                     | 28.0 ms                                           | . 0                                                        |
| Latency                               | 8.3 ms                                            | 0                                                          |
| Data Transfer Rate<br>Read:<br>Write: | 8 Mbits/sec.<br>8 Mbits/sec.<br>Now Read from RAM | 106.7 Mbits/sec.<br>1 Mbit/sec.<br>Direct Processor Access |
| Total Time to Access (1 Kbyte File)   | 37.3 ms                                           | 0.077 ms                                                   |

Figure 4



From a performance standpoint, disk-based systems still require some form of supplementary memory that is directly executable. Typically, DRAM is used for executable code storage and data manipulation. Data from the disk is downloadable into the DRAM cache before users can access the information. Then when a "save" operation is desired, the data is uploaded from DRAM back into the disk. This download/upload process slows down system throughput while the redundant memory media produce even more system overhead in the form of added space, power consumption and weight (Figure 4).

Today's PCs are typically configured with 4 Mbytes-8 Mbytes of DRAM backed up by at least a 40-Mbyte disk. FlashFile memory fully supports this system configuration when used simply as a magnetic drive replacement. Instructions and data are still swapped to DRAM, but at a faster rate. Plus execution speed can be enhanced if the DRAM is replaced with SRAM.

In the solid-state computer, the "DRAM + magnetic hard drive" is replaced by a "flash memory + SRAM". The key to this architecture is the ability to eXecute-In-Place (XIP). Program instructions stored in flash memory are read directly by the processor. Results are written directly to the flash memory. Compute-intensive operations that require the fastest memory access and byte-alterability can use high-speed SRAM or pseudo SRAM. Some of the system DRAM can be replaced by low-cost flash and a small part of the DRAM can be replaced by SRAM. The flash memory space is made even more storage efficient through the use of compression techniques which may offer up to 2:1 compression.

# SOFTWARE DEVELOPMENTS POSITION FLASH FOR PORTABLE APPLICATIONS

The majority of today's portable computers and supporting software programmers are designed to run using Microsoft's MS-DOS\* disk operating system. MS-DOS was developed to allow broad-based compatibility between systems and software and to optimize the sectoring scheme inherent to disk technology.

Intel's Flash Memory, based on a block-erase architecture, divides the flash memory into segments that are loosely analogous to the zones recognized in MS-DOS. Thanks to recent software developments, flash memory can effectively serve as the main memory within portable computers, providing user functions virtually identical to, and even improved over, those of disk-based systems.

Specifically, two recent developments allow this achievement: DOS in ROM-executable form (DOS was formerly designed to be stored on disk and then downloaded to/executed out of RAM); and a file system designed for flash memory technology that allows the devices to erase blocks of memory instead of the whole chip.

ROM-executable DOS provides several benefits to both system manufacturers and ultimately end users. First, since most of the operating system is composed of fixed code, the amount of system RAM required to execute DOS is reduced from 50K to 15K, thereby conserving system space and power. Secondly, DOS can now be permanently stored in and executed from a single ROM-type of device—flash memory—so systems come ready to run. Lastly, users enjoy "instant on" performance since the traditional disk-to-DRAM boot function and software downloading steps are eliminated.

For example, by storing application software and operating system code in a Resident Flash Array (RFA), users enjoy virtually instant-on performance and rapid in-place code execution. An RFA also protects against software obsolescence because it is in-system updatable. Resident software, stored in flash rather than disk, extends battery life and increases system reliability.

Since erasing and writing data to flash memory is a distinctly different operation than rewriting information to a disk, new software techniques were necessary to allow flash to emulate disk functionality. File management software like Microsoft\*'s Flash File System (FFS) allows Intel's Flash Memory components and flash cards to emulate the file storage capabilities of disk. Microsoft's FFS transparently handles data swaps between flash blocks similar to the way MS-DOS handles swaps between disk sectors. Under FFS, the user may input a MS-DOS or Windows\* command without regard for whether a flash memory or magnetic disk is installed in the system. The FFS also employs wear-leveling algorithms that prevent any block from being cycled excessively, thus assuring millions of hours of reliability. Flash filing systems make the management of flash memory devices completely transparent to the user.

### CONCLUSION

Intel Flash Memory presents an entirely new memory technology alternative. As a high-density, nonvolatile read/write technology, it is exceptionally well-suited to serve as a solid-state disk or a cost-effective and highly reliable replacement for DRAMs and battery-backed static RAMs. Its inherent advantages over these technologies make it particularly useful in portable systems that require the utmost in low power, compact size, and ruggedness while maintaining high performance and full functionality.

### **FLASH MEMORY OVERVIEW**



Intel Flash Memory offers:

- Inherent Nonvolatility: Unlike static RAMs, no backup battery is required to ensure data retention. In contrast to DRAMs, flash requires no disk to provide backup storage of data, programs or files.
- Cost-Effective High Density: Today, Intel flash memories cost about the same as DRAMs and about one fourth of SRAMs on a per-bit basis. The broad acceptance of flash is driving manufacturing volumes up and costs down at an unprecedented rate, allowing flash to soon compete on a cost basis even with disk drive within the notebook, sub-notebook and palmtop markets.
- Solid-State Performance: Because it is a semiconductor technology, flash memory consumes much less power, is much lighter in weight and is smaller and more shock-resistant and reliable than disk drives. Mobile computers no longer have to drain the battery to run a disk drive motor or accommodate the disk assembly's added bulk and weight. Now users no longer have to be threatened with the possibility of losing their data after a disk crash when conditions become unusually rough.
- Direct Execution: Since no disk-to-DRAM download step, seek or latency times are incurred with

- flash memory, users enjoy significantly higher speed program and file access, as well as systems that turn on instantly to wherever the user left off.
- Easy Updatability: Unlike other nonvolatile memory technologies—ROM that can never be altered after it is manufactured or EPROM that can only be erased by removing it from the system and exposing it to ultraviolet light—flash can be erased and reprogrammed electrically while resident in the host system
- Software Compatibility: With Flash File System software and ROM-executable versions of the disk operating system (DOS), complete software compatibility between a user's desktop and portable system is ensured.
- Exchangeable Card Architecture (ExCATM):
   Through Intel's ExCA card interface standard, Intel's flash memory cards meet all specifications of PCMCIA 2.0, ensuring interchangeability between a host of PCMCIA-compatible systems.
- Family of Products: Intel Flash Memory products are currently available in component densities up to 8 Mbits, and in 4-Mbyte, 10-Mbyte and 20-Mbyte memory cards. Additionally, Intel offers Boot Block devices in densities up to 4 Mbits.



# FLASH MEMORY CUSTOMER SUPPORT

## **New/Updated Technical Literature**

By the time you receive this databook, new information may be available for Intel's Flash Memory products. This could include advanced information on new devices or important new applications information or datasheet addendums for those described in this databook. Call 1-800-548-4725 (US and Canada) for the newest information on Intel Flash Memories. This service is available from 7am to 7pm Central Standard Time. Contact your local distributor or sales office if outside US or Canada.

# **Applications Support Hotline**

The Technical Hotline is staffed by applications personnel during normal business hours—5am to 5pm Pacific Standard Time. Toll free number 1-800-628-8686 is available for US and Canada; 916-356-7599 is also available for those who cannot access the toll free number.

Additionally, assistance can be obtained through your local Intel/distributor sales office. You can leave a message during off hours or when applications personnel are already handling calls.

# Intel's Application Bulletin Board System (BBS)

Intel's Application Support BBS provides the designer, developer or OEM using or contemplating the use of Intel components, systems or software with the latest information on Intel's product line.

The Intel Application Support BBS is duplicated at two sites worldwide, and can be accessed at 916-356-3600 (Folsom, California USA) or 44-793-496340 (Swindon, England UK). Upon calling your are prompted through an automatic registration process. You then have immediate access to the downloadable files area. For non-urgent requests or technical assistance you may leave a message to one of our System Operators (SysOps). Online forums among users are not supported. In North America you may also call our tollfree line

at 1-800-897-2536. This limited access allows you to download the current BBS master file list (generated nightly), FaxBACK\* catalogs, our Windows-based FaxFind keyword search utility and the BBS user's guide. The BBS supports baud rates up to 19.2 Baud; settings are 8 data bits, No parity and 1 stop bit.

### \*NOTE:

Other brands and names are the property of their respective owners.

The eight flash memory file areas are:

- Bulk Erase
- · Boot Block
- FlashFileTM
- Flash Card
- Flash Drive
- Tools
- FlashFile<sup>TM</sup> Layout: 8/16/32 Mbit
- Boot Block Layout: 2/4 Mbit

These file areas include the following types of support:

- Software drivers
- 3rd-party programming support, tools, adapters and vendor information
- Reader/Writer support for Flash Memory Cards and ATA Flash Drives
- Orcad and Workview schematic symbols
- Timing Designer files
- FLASHBuilder 16-Mb FlashFile Memory Windows-based design/help file
- Information (document) navigator utility
- Design recommendations
- Component flexible layout files
- Presentations
- Socket information
- Data sheet addendums
- Errata notifications

### **FLASH MEMORY CUSTOMER SUPPORT**



### FaxBACK System

Available 24 hours a day. Order documents by phone for prompt delivery to your fax machine.

Dial toll free number 1-800-628-2283 if inside US or Canada (or 916-356-3105, which also supports users not having tollfree access), and the user-friendly system will prompt you along. In Europe, dial 44793-49-6646. Have your fax number ready.

Each document is assigned an order number. All documents for a particular product group (e.g., Flash Memory, Multimedia, PCI...) are listed in their subject catalog. First time users should order the appropriate catalog(s) for a complete reference of available information; this is down by following the automated system's voice prompts and selecting catalog order. Document orders are made by selecting document order at the voice prompt; you are allowed up to five documents per call.

Rely on FaxBACK for the following types of information about flash memory products:

- Product briefs and literature references
- Press releases and new product announcements
- Datasheet addendums
- Technical support material and references
- · Product evaluation kits
- 3rd-party programming support, tools, adapters and vendor information

- System/compatibility validation reports
- Application articles
- Design recommendations
- · Errata notifications

Document Highlight: #2204 is the all-inclusive "Flash Memory Technical Support Summary". This document summarizes available literature and order numbers, FaxBACK and BBS references, evaluation kits and support tools/information, programmer and reader/writer support and vendor contact references, programming adapter information and vendors, prototyping and burn-in/test socket vendors and information, 12V-convertor vendors, PCMCIA development tools/compliance testing/general support contacts, PCMCIA card-connector vendors, FFS vendors, disk emulator vendors and BIOS vendors.

### **FaxFind**

A Windows-based utility to search all FaxBACK documents and BBS files via keyword entry. Available on the Applications BBS under the Bulletins menu or in the FaxBACK area selected via File Locator. Also available via the dedicated FaxFind number: 1-800-897-2536.



### SPRINT PLUS48 Intel Support Version

# Universal Device Programmer

### **General Description**

The PLUS48 is the newest Universal Device Programmer in the Sprint family. Complete with 48 universal pin drivers, it sets a new standard for low-cost programmers in this class. A specially-configured version supports all Intel Flash, Microcontroller, PLD, EPROM and EEPROM devices at a very attractive price. Controllable lockout of standard software libraries allow you to purchase the Intel support you need today, with the capability to switch to full industry support later.

Full custom ASIC pin drivers were developed enabling the programming and testing of new high-speed CMOS devices. A compact design is achieved because of these analog/digital ASICs, allowing pin drivers and  $V_{\rm CC}$  and GND relays to be as close to device pins as possible. This technology virtually eliminates ground bounce, greatly improving programming yields.

As a peripheral attachment, the PLUS48 utilizes your PCs RAM, CPU and Hard Disk Drive. Key to this approach, the PLUS48's cost is extremely competitive while providing lots of programming power.

Additionally, file download times of stand-alone programmers is eliminated.



PC Interface is through the standard parallel port. With included software installed, the PLUS48 automatically interrogates LPT ports to determine where it is attached—then configures itself. Ant LPT port, such as that on a Notebook PC, can be used to control the PLUS48 giving you the freedom to take your support on the road.

### **Specifications**

### STANDARD FEATURES

- INTEL device support.
- Standard 48-pin DIP/ZIF socket.
- Larger pin-count and non-DIP devices supported via adapters.
- Precise digital and analog signals on every pin.
- PC peripheral—Uses computer's existing RAM, CPU and HDD to provide maximum price performance.
- Portable—Connects to any standard LPT port.
- Compact design eliminates yield loss due to ground bounce.
- An internal crystal-controlled state machine insures accurate waveform generation—independent of the PC.
- Intuitive full screen menus make the PLUS48 simple to learn and easy to use.
- Batch mode operation—All commands can be executed from a batch file.



### **Available Versions**

### INTEL SUPPORT VERSION

- · Programs Intel devices only.
- · Reads all manufacturer's devices.

### **UNLIMITED VERSIONS**

• Supports all devices from SPRINT device list.

PLUS48 is easily upgraded from Intel Support Version to Full Support via KEYFAX.

### **PC Requirements**

- DOS-based PC, Laptop or Notebook (tested to 486).
- 512 KB free RAM.
- 3 MB free space on HDD.
- CGA, EGA, VGA or LCD.
- Centronics Parallel port.

### **System Operations**

- Read, Blank check, Program and Verify.
- Sum check, ID test, Illegal bit and Continuity check.
- Address range, Change device, Execute DOS, Input file.
- Edit data, List memory and Write file.

### **Translation Formats**

- INTEL 8/16/32-bit
- 286/386 OMF.
- Motorola 8/16/32 bit.
- TEK HEX, ASCII HEX, MOS Tech.
- JEDEC, POF, Binary.

### **Standard Accessories**

- 48-pin DIP/ZIF socket.
- User's manual.
- System Software.
- Power supply.
- Line cord.

# **Electrical Requirements/ Physical Specifications**

• Operating voltages: 100 to 250 VAC

• Frequency range: 47 to 63 Hz

• Power consumption: 25W

• Operating temperature: 10°C to 40°C

• Dimensions: 2.56 x 17.9 x 20.5 cm

• Operational weight: 2.61 kg

## Safety Standards

UL, CSA and GS

The PLUS48 comes with a standard 48-pin DIP/ZIF socket. Affordable adapters are available for larger pincount DIP devices or other package types. Please contact SMS or one of the SMS distributors from the following distribution list for availability.

### **SMS Service Centers**

USA

SMS North America Inc. P.O. Box 3159 Redmond, WA 98073-3159 Phone: (206) 883-8847 FAX: (206) 883-8601

Japan

Micron Inc. 4-26-16, Koenji-Minami Suginami Tokyo 166 Phone: +81 3 3796 1860 FAX: +81 3 3796 1866

• Europe

SMS GmbH Im Grund 15 88239 Wangen, Germany Phone: +49 7522 9728 0 FAX: +49 7522 9728 50



# International Distributors for SMS SPRINT products:

### Austria

Memo ELECTRONICS Muchlberg str. 22 A-1140 Vienna (Wien) Phone: +(43) 1 975 626 FAX: +(43) 1 975 627

### Belgium

Sonetech BELGIUM de Limburg Stirumlaan 243, Bus 3 B-1780 Wemmel Phone: +(32) 2 460 07 07 FAX: +(32) 2 460 12 00

#### Denmark

sd Elektronik & Data Rejnstrupvej 11 DK - 4640 Faskse Phone: +(45) 56 71 41 51 FAX: +(45) 56 71 41 51

#### **Finland**

Computer 2000 Finland OY P.O. Box 44 Pyyntitie 3 02231 Espoo Phone: +(358) 0887 331 FAX: +(358) 0887 33 343

### France

Emulations Chemin de Gizy Parc Burospace A13 F-91572 Bievres Cedex Phone: + (33) 1-69.41.28.01 FAX: + (33) 1-60.19.29.50

Newtek 8 rue de l'Esterel-SILIC 583 F-94663 Rungis Cedex Phone: +(33) 1-46.87.22.00 FAX: +(33) 1-46.87.80.49

### Germany

Logic Design Riepacker str. 65 D-31 691 Helpsen Phone: +(49) 5721 9714 0 FAX: +(49) 5721 9714 97 MSC Vertriebs GmbH Industrie str. 16 D-76297 Stutensee Phone: +(49) 7249 910 175 FAX: +(49) 7249 910 221 SE Spezial Electronic Kreuzbreite 15

D-31675 Buckeburg Phone: +(49) 5722 203 0 FAX: +(49) 5722 203 120

Synatron
Bretonischer Ring 13
D-85630 Grasbrunn
Phone: +(49) 89 460 20 71
FAX: +(49) 89 460 56 61

Trias Zur Eibe 11 D-47802 Krefeld Phone: +(49) 2151 47 67 01 FAX: +(49) 2151 47 47 15

#### **Great Britain**

Concentrated Programming Ltd.
Unit 3A The Maltings
Station Rd., Sawbridgeworth
Herts, CM21 9JX
Phone: + (44) 279 600 313
FAX: + (44) 279 600 322
Pronto Electronic Systems Ltd.
City Gate House

City Gate House 399-425 Eastern Ave., Gants Hill Illford, Essex IG2 6LR Phone + (44) 81 554 5700 FAX: + (44) 81 518 3222

### Hong Kong

Int'l Technology Enterprise Co. 5 Long Yuet St. 6th Floor F2, Kowloon Phone: +(852) 3622309 FAX: +(852) 3620886

### Israel

Talviton Electronics Ltd.
9, Biltmor str., P.O. Box 21104
Tel Aviv 61216
Phone: + (972) 3 54 42 430
FAX: + (972) 3 54 42 085

### Italy

De Mico Viale Vittorio Veneto, 8 20060 Cassina De'Pecchi-Milano Phone: +(39) 2 95 343 600 FAX: +(39) 2 95 219 12 Silverstar Viale Fulvio Testi, 280 20126 Milano

#### Japan

Micron Inc. 4-26-16, Koenji-Minami Suginami, Tokyo 166 Phone: +(81) 3 3317 9911 FAX: +(81) 3 3317 9917

Phone: +(39) 2-66 12 51 FAX: +(39) 2-66101359

### Korea

Logicom Corporation 1634-9 Bongchum-Dong Kwanak-Ku, Seoul Korea 151-061 Phone: +(82) 2 888 2858 FAX: +(82) 2 888 7040

### Netherland

Sonetech Netherland by Gulberg 33 NL-5674 TE Nuenen Phone: +(31) 40 83 80 09 FAX: +(31) 40 83 92 71

### Norway

Kjell G. Knutsen A.S. P.O. Box 113 N-4520 SOR-AUDNEDAL Phone: +(47) 38 25 62 05 FAX: +(47) 38 25 68 18

#### Poland

Cadel sp.z.o.o. UL, Tamka 38 00355 Warszawa Phone: +(48) 2 227 50 61 FAX: +(48) 2 635 52 62

### **SPRINT PLUS48**



### Singapore

WesTech Electronics Pte Ltd.
12, Lorong Bakar Batu, #05-07
Kolam Ayer Industrial Park
Singapure 1334
Phone: ±(55) 743 6355

Phone: +(65) 743 6355 FAX: +(65) 746 1396

### Spain

ADM Electronica SA Tomas Breton, 50 3i 2 E-28045 Madrid Phone: +(34) 1 530 41 21

FAX: +(34) 1 530 41 21

### Suisse

Redacom AG Gurzelenstrasse 6 CH-2502 Biel/Bienne Phone: +(41) 32 410 111 FAX: +(41) 32 41 49 49

### Sweden

Gordia Elektronik Box 12 40 S-221 05 LUND Phone: +(46) 46 120211 FAX: +(46) 46 138 156

### Taiwan

Prospect Technology Corp. 5F, No. 348, Sec. 7 Cheng Teh Rd. Taipei, Taiwan ROC Phone: +(886) 2 820 5353 FAX: +(886) 2 820 5731

### USA

SMS North America Inc. P.O. Box 3159 Redmond, WA 98073-3159 Phone: +(206) 883-8447 FAX: +(206) 883-8601





297541-2

# Multi-APRO Programmer Intel Support Version

### **General Description**

The new System General Multi-APRO is a revolutionary concept in device programmers. Based on 48 Universal pin driver design, it can support virtually any programmable device. The *Intel Support Version* of Multi-APRO programs all Intel Flash, Microcontroller, FLEX-logic, EPLD and E(E)PROM devices at significant discount off our standard version. Additionally, all other manufacturer's devices can be read into buffer memory.

This unit comes with full standalone control, but can be PC driven for added flexibility. Expansion is possible in two ways:

- 1. Full Universal (programs all manufacturer's devices) by swapping signature keys, or
- 2. Production (gang) programmer by adding modules.

Different package types are supported via our own proprietary adapters or DIP converters. With adapter method, the device sits as close to the pin drivers as possible. This virtually eliminates any noiserelated problems due to ground bounce. When adapters are unavailable, quality third-party converters will be specified by System General.



Multi-APRO comes standard with 1 megabyte of user RAM, upgradable to 16 megabytes. The device driver and related file can be downloaded via parallel or RS232 (up to 115.2K baud) or read in from a master, then stored in RAM. Programming therefore is done stand-alone which improves throughput time and yield because clock control issues are not present. When expanded to a gang programmer, Multi-APRO is the most efficient production tool on the market. Since each socket is independent, programming proceeds continuously from one device to the next, minimizing insertion overhead.

Support for Intel devices is provided via normal distribution media (Intel Flash Memory Card) or BBS (Downloaded to Flash). New devices are supported prior to their introduction, handled via secure methods on a customer-by-customer basis.

In addition to the best device support available, upgrades are free for the life of the programmer via our 24-hour BBS line.

### **Specifications**

- Supports full range of INTEL programmable devices.
- Standard 48-pin DIP/ZIF socket.
- Optional adapters or converters available for different package configurations.
- Universally pin-driven.
- On-board RAM means programming is done directly to chip, providing highest yield and throughput.
- Easy to use PC-assisted SW included.
- Full Batch-mode capabilities.



### **Available Versions**

### INTEL SUPPORT VERSION

#### Features:

- · Programs all Intel devices.
- · Reads any master device.
- Expandable to full Universal version via field-installable signature key.
- Expandable to production model.

### **FULL UNIVERSAL VERSION**

#### Features:

- Supports virtually all programmable device technologies.
- Expandable to production model.

### GANG/PRODUCTION VERSION

#### Features:

- Up to eight programming modules.
- Each independent from the others—allows continuous programming for highest throughput.
- No future constraints!

### **PC Requirements**

- DOS-based PC, Laptop or Notebook.
- 512KB free RAM.
- CGA, EGA, VGA, SVGA or LCD.
- Remote control and data transfer via PC parallel port.
- Remote control and data transfer via RS232, Baudrate Max 115.2K bps.

### **System Operations**

- Read, insertion check, illegal bit check, erase, blank check, program, continuity check and verify.
- Auto-SenseTM, ID test.
- Even/Odd programming.
- Special on-screen editor.
- Sum check, Pass/Fail counter.
- EPROM Auto-Identify.
- · Address range modification.
- Current sense, boot-block secure.
- Functional Test, Margin Verify.
- PLD JEDEC fuse screen editor.
- Upload/Download functions.
- Context-sensitive help screen.
- · Stand-alone and remote control.
- Connects to IBM PC, compatible or non-IBM PC via RS232.

### **Translation Formats**

- Intel-HEX (32, 24, 16)
- Tektronix-HEX
- Motorola S (3,2,1)
- Signetics-HEX
- Extended Tekhex
- HP 64000 Absolute
- ASCII-HEX()
- ASCII-HEX(%)
- ASCII-HEX(")
- ASCII-HEX(,)
- ASCII-HEX SMS
- ASCII-OCT()
- ASCII-OCT(%)
- ASCII-OCT(")
- ASCII-OCT SMS
- B10F
- BHLF
- BPNF
- JEDEC
- Binary (no format, no header)

### **Standard Accessories**

- 48-pin DIP/ZIF socket adapter (Intel Support Version)
- System software (IBM PC or compatible)
- Power Supply
- All neccessary cabling
- User's manual

### **Adapter Options**

- PLCC 20, 28, 32, 44, 52, 68 or 84 pins
- OFP100

# Electrical Requirements/Physical Specifications

- Operation Voltages: 90 to 250 VAC
- Frequency range: 47 to 63 Hz
- Power consumption: 30W max
- Operation Temperature: 0° to 45°C
- Dimensions:

Controller—350mm x 200mm Module—350mm x 155mm

- Safety Standards: UL, CSA, VDE
- EMI: FCC class B, VDE 0871 B



# INTERNATIONAL CONTACTS FOR SYSTEM GENERAL

### US

System General Corp. 1603-A South Main St. Milpitas, CA 95035 TEL: (408) 263-6667 FAX: (408) 262-9220 SALES: (800) 967-4776

### Japan

Nippon System General TEL: 81-3-34411510

#### Korea

Wooyoung Tech. Co., Ltd. TEL: 82-2-3697099

Dasan Technology TEL: 82-2-5018276

### Hong Kong

Twin-Star Trading Company, Ltd. TEL: 852-3469085

### Singapore

WesTech Electronics Pte., Ltd.

TEL: 65-7436355

EPE Computronics Pte., Ltd.

TEL: 65-7468182

### Taiwan

System General Corp. 3F, No. 1, Alley 8, Lane 45 Bao Shing Rd., Shin Dian Taipei, Taiwan R.O.C. TEL: 886-2-917-3005 FAX: 886-2-911-1283

#### Switzerland

Novitas Elektronik AG TEL: 41-1-9450300

### Belgium

Eurodis Inelco NV/SA TEL: 32-2-2442924

### France

Micropross TEL: 33-20479040

### Norway

Tormatic A/S TEL: 47-34-25011

#### Australia

Macro Dynamics Pty., Ltd. TEL: 61-3-7202399

### South Africa

Specitec Pty., Ltd. TEL: 27-11-7891743

CONTACT YOUR LOCAL DISTRIBUTOR FOR PRICING AND AVAILABILITY.

# Flash Memory Card and Flash Drive Evaluation Kit **Product Brief**

# Highlights

- Product Complete kit for adding a PCMCIA socket to an AT-based
  - The Flash Drive Kit (iATAKIT) includes a 5MB Flash Drive
  - The Flash Card Kit (S2S2PLUSKIT) includes both a 4MB Series 2+ and a 2MB Series 2 Flash Card
  - **■** Includes ISA-based PCMCIA Reader/Writer that fits into an empty floppy disk slot on your system
  - Created for ×86 DOS- or Windows\*-based systems
  - Includes source code for non-DOS system development
  - Includes SystemSoft's\* CardSoft\* suite of software
  - Contains industry-standard PCMCIA software, including SystemSoft Flash File System (FFS) software
  - Contains a 68-pin PCMCIA-ATA to 40/44-pin IDE adapter for easy conversion (iATAKIT only)
  - Excellent for evaluating Flash Card or Flash Drive performance with multiple software configurations



### **Product Description**

The Flash Drive (iATAKIT) and the Flash Card (S2S2PLUSKIT) evaluation kits are designed to make DOS-based AT systems Intel Flash Card or Flash Drive-ready - quickly and simply. Each kit provides everything necessary to add a PCMCIA socket to a desktop system.

The Flash Drive and Flash Card kits are ideally suited for designers creating PDAlike products; designers of mobile, handheld and sub-notebook products; designers who want to evaluate Flash Card and/or Flash Drive products for embedded applications; and ISVs who write software for Flash Card or Flash Drive products.

To shorten time to market, both kits contain all necessary tools in a single box. Thus eliminating the time-consuming task of seeking and obtaining separate

Each kit includes SystemSoft's CardSoft suite utilizing industry-standard PCMCIA software - as well as SystemSoft's Flash File System (FFS) software. Additionally, each kit includes low-level driver and MTD source code, enabling modification for your specific requirements or product differentiation. For easy conversion of PCMCIA-ATA to IDE pinouts a 68-pin to 40/44-pin adapter is included.



| Features                                      | Benefits                                                                                |
|-----------------------------------------------|-----------------------------------------------------------------------------------------|
| — All-in-one kit                              | Contains everything needed to develop Intel     Flash Card or Flash Drive-ready systems |
| Includes low-level driver and MTD source code | - Enables code modification for specific requirements                                   |
| - SystemSoft CardSoft                         | Industry-standard PCMCIA software suite                                                 |
| Flash File System (FFS) software              | Industry-standard file system from SystemSoft                                           |
| — 68-pin ATA to 40/44-pin IDE adapter         | — Easily converts PCMCIA-ATA pinout to IDE                                              |

The Intel logo is a registered trademark of Intel Corporation.

Other brands and names are the property of their respective owners.

Printed in USA/0694/40K/ASI/LK © 1994 Intel Corporation

Order Number: 297506-001



# SMALL OUTLINE PACKAGE GUIDE OVERVIEW

This overview provides a quick reference for the Small Outline Package Guide, Intel literature

order number 296514.

Intent

Contents The table below details, in outline form, the type of information that can be found in the guide.

How to Order Phone: (800) 548-4725 in US and Canada

Outside US/Canada, contact local Intel or distributor sales office

or write to: Intel Corporation Literature Sales P.O. Box 7641

Mt. Prospect, IL 60056-7641

| Chapter                                    | Contents                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Package<br>Description                     | <ul> <li>Small-Form-Factor/Fine-Pitch Introduction</li> <li>TSOP, SSOP and PSOP Key Features</li> <li>Device/Package Offerings</li> </ul>                                                                                                                                                                                                                   |
| SOP Layout<br>Features and<br>Applications | Space-Saving Features     Device Pinouts     SOP Applications                                                                                                                                                                                                                                                                                               |
| SOP Physical<br>Dimensions                 | <ul> <li>Package Drawings and Specifications</li> <li>PCB Land-Pad Layout Diagrams</li> <li>Component Volume and Weight</li> </ul>                                                                                                                                                                                                                          |
| SOP Package<br>Characteristics             | Electrical Characteristics     Thermal Data                                                                                                                                                                                                                                                                                                                 |
| SOP Manufacturing                          | Assembly Process Flow     Package Materials     Cross-Section Diagrams     Electrical and Solderability Test     Mechanical Inspection                                                                                                                                                                                                                      |
| SOP Reliability<br>Stresses                | Temperature Cycling via Convection Thermal Shock, Liquid-to-Liquid Stress Steam, Accelerated Moisture Penetration Stress S5°C/85% Relative Humidity, Alternate Pins Biased (+5V and GND) High-Temperature Dynamic Life Test Solder-Joint Reliability Surface Mount Process Considerations Use Condition Considerations Solder-Joint Life Predictions Curves |
| SOP Handling                               | SOP Shipping Formats     Tray Diagrams and Dimensions     Tray Recycling     Tape and Reel Carrier Diagrams and Dimensions     Tube Diagrams and Dimensions     Moisture Considerations and Data     Plastic Package Aggressive Preconditioning Flow     Reliability Data                                                                                   |



| Chapter                                     | Contents                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SOP SMT Assembly<br>Considerations          | Storage and Handling Screen Printing — Solder Paste — Solder Volume — Solder Mask — Stencil — Vision System — Squeegee Placement Equipment Cleaning IR Furnace PCB Design Considerations Lead Placement — Good Placement — Misaligned — Lifting                                                                     |
| SOP Ordering<br>Information                 | Production/Package Identification                                                                                                                                                                                                                                                                                   |
| References and<br>Additional<br>Information | Other Reference Material                                                                                                                                                                                                                                                                                            |
| SOP 3rd-Party<br>Equipment<br>Suppliers     | SOP Suction Wand Suppliers     SOP Programming Adapter Suppliers     SOP Programming Vendors     SOP Socket Suppliers     — Prototyping Sockets     — Burn-In/Test Sockets     SOP Handler Equipment Suppliers     SOP Manufacturing Equipment Suppliers     SOP Custom Board Manufacturing and Interposer Mounting |
| SOP Standards<br>Bodies                     | EIA/JEDEC     ANSI     IPC     EIAJ                                                                                                                                                                                                                                                                                 |

# Intel FLASHBuilder Software **Product Brief**

# Highlights

- Product Supports 16-Mbit 28F016SA FlashFile™ memory
  - Text highlights for quick access to information about device functional blocks
  - On-line documentation
  - Toolbar for fast access to information resources
  - FLASHText window for tips on using FLASHBuilder



### **Product Description**

FLASHBuilder is a Windows\*-based software tool developed to facilitate the understanding of and designing with Intel Flash Memory components. Its user interface provides a graphical representation of device functional blocks within the flash memory architecture.

FLASHBuilder also features dialog boxes in the toolbar for quick access to information about 28F016SA operations, commands, algorithms and registers. For example, the command dialog box displays on a single screen the 28F016SA command set and corresponding hexadecimal values, bus-cycle counts for each command, and status register output indicating a successful operation.

Currently supporting the 16-Mbit 28F016SA FlashFile memory, FLASHBuilder contains the associated user's manual, application notes and datasheet specifications in an easy-to-use, on-line Hypertext format for point-and-click access. Documentation embedded in the software includes:

- 28F016SA User's Manual
- 28F016SA Application Notes:
  - AP-357 "Power Supply Solutions for Flash Memory"
  - AP-359 "28F008SA Hardware Interfacing"
  - AP-375 "Upgrade Considerations from the 28F008SA to the 28F016SA"
  - AP-377 "28F016SA Software Drivers"
  - AP-378 "System Optimization Using the Enhanced Features of the 28F016SA"
- 28F016SA timing and waveform specifications
- 28F016SA Qs and As Frequently asked questions and answers regarding 28F016SA FlashFile memory
- Flash Memory Overview A high level description of flash technology and product applications.



Future updates to FLASHBuilder will provide support for multiple devices and chip architectures. To speed decision making and reduce user resource requirements, options allowing minimal or partial install will be added. With minimal install selected, a subset of available information can be installed, allowing the designer to quickly decide which device best suits the application need. Partial install minimizes disk consumption by installing only the necessary files for the selected device(s).

| Features                        | Benefits                                                                                                     |
|---------------------------------|--------------------------------------------------------------------------------------------------------------|
| Graphical user interface        | — Easy-to-use point and click access                                                                         |
| — On-line documentation         | <ul> <li>Quick reference to technical specifications and<br/>product applications notes</li> </ul>           |
| Integrated toolbar dialog boxes | Intuitive resource for operations, registers, commands, algorithms, documentation, help                      |
| Enhancement path                | <ul> <li>Variable install options will meet application needs<br/>(minimal/partial installations)</li> </ul> |

### System Requirements — Version 1.0a

- Intel386™ microprocessor or higher
- 2-MB RAM
- 4-MB free hard disk space
- VGA display (SVGA recommended)
- 31/2" floppy disk drive
- Windows 3.1 or above

To order FLASHBuilder or additional literature, call 1 (800) 548-4725.

FLASHBuilder order number: 297508.

For technical assistance and/or the name of your local distributor call 1 (800) 628-8686.

FLASHBuilder is also available through Intel's Bulletin Board Service (BBS): in North/South America and Asia Pacific dial (916) 356-3600; in Europe dial +44 (0) 793-496340

\*Other brands and names are the trademarks of their respective owners. Printed in USA/1094/10K/ASI/TC/MCD. © 1994 Intel Corporation

Order Number: 297536-001



# APPLICATION NOTE

# **Power Supply Solutions for Flash Memory**

MICHAEL EVANS
ANIL SAMA
BRIAN DIPERT
APPLICATIONS ENGINEERING
INTEL CORPORATION

August 1994

# **Power Supply Solutions for Flash Memory**

| CONTENTS PAGE                                                    | CONTENTS                                                              | PAGE           |
|------------------------------------------------------------------|-----------------------------------------------------------------------|----------------|
| 1.0 INTRODUCTION 2-24                                            | 5.0 5V V <sub>CC</sub> SOLUTIONS: CONV<br>UP FROM 3V                  | ERTING 2.22    |
| 2.0 FLASH MEMORY POWER REQUIREMENTS2-24                          | 5.1 Maxim MAX756                                                      | 2-39           |
| V <sub>CC</sub> Characteristics 2-24                             | 5.2 Linear Tech L 11301                                               | 2-41           |
| V <sub>PP</sub> Characteristics                                  | 6.0 12V V <sub>PP</sub> SOLUTIONS: DOW CONVERTING FROM A HIGH VOLTAGE | ER             |
| 2.2 Choice of a DC-DC Converter 2-25                             | 6.1 Maxim MAX667                                                      | 2-42           |
| The Modular Solution 2-25                                        | 6.2 Linear Technology LT1111                                          | -12 2-44       |
| The Discrete Switching Regulator Solution                        | 6.3 National Semiconductor LM2940CT-12                                | 2-45           |
| The Discrete Charge-Pump Solution                                | 7.0 12V V <sub>PP</sub> FROM 12V<br>UNREGULATED                       | 2-46           |
| Attributes of a DC-DC Converter 2-26 2.3 Summary                 | 8.0 SUMMARY                                                           | 2-46           |
| 3.0 12V V <sub>PP</sub> SOLUTIONS:<br>CONVERTING UP FROM 5V 2-26 | APPENDIX A: MODULAR SOLUTIONS                                         | 2-47           |
| 3.1 Maxim MAX734 2-27 3.2 Maxim MAX761 2-28                      | APPENDIX B: SURVEY OF SOL PRESENTED                                   | UTIONS<br>2-48 |
| 3.3 Maxim MAX662                                                 | APPENDIX C: SOURCES FOR D<br>CONVERTERS                               | OC-DC<br>2-49  |
| 3.5 Linear Technology LT1301 2-33                                | APPENDIX D: SOURCES FOR                                               |                |
| 3.6 Motorola MC34063A 2-34                                       | DISCRETE COMPONENTS                                                   | 2-52           |
| 4.0 12V V <sub>PP</sub> SOLUTIONS:<br>CONVERTING UP FROM 3V 2-36 | APPENDIX E: OTHER DESIGN CONSIDERATIONS                               | 2-54           |
| 4.1 Maxim MAX761 2-36                                            | APPENDIX F: PC LAYOUTS FO RECOMMENDED SOLUTIONS                       |                |
| 4.2 Linear Technology LT1301 2-37                                | HECOMMENDED SOLUTIONS                                                 | <b>5</b> 2-58  |



### 1.0 INTRODUCTION

Intel flash memory is rapidly being incorporated into a wide range of applications, adding enhanced capability to existing "traditional" memory markets, and creating new markets that exploit its benefits. Sometimes the design platforms may not possess the low powered 12V supply for writing flash memory. The system design engineer then needs to identify a power conversion solution with features and capabilities matching the needs of the application. For example, portable equipment requires a power supply converter that minimizes size and weight, maximizes efficiency to extend battery life, and can be switched into a standby mode to conserve power.

The following pages present some state of the art DC-DC converter solutions. These new solutions are smaller and more efficient than those typically seen in the past. Each of these solutions optimizes a subset of all possible power converter features. The choice of an optimal solution for a given application will be a tradeoff between several attributes. The solutions shown should meet the conversion needs of the majority of applications involving flash memory. Specifically, the solutions that follow encompass the following five categories:

- 5V to 12V conversion
- 3V (2 alkaline/NiCd cells) to 12V conversion
- 3V (2 Alkaline/NiCd cells) to 5V conversion
- Downconverting to 12V from a higher voltage
- Converting 12V unregulated to 12V regulated

More than one solution is presented within each of these categories. These different solutions have distinct optimal features/advantages. The optimal attributes of each solution are outlined. In addition, the appendix contains a survey of all solutions presented here, and provides a basis for comparing their features. The readers should reference it to choose an optimal solution for his/her application.

### NOTE:

Solutions were selected from products offered by over thirty DC-DC converter vendors. Since this industry develops many new solutions each year, Intel recommends that designers contact vendors for latest products. Intel will continue to work with the industry to develop optimum solutions for power conversion. Intel Corporation assumes no responsibility for circuitry other than circuitry embodied in Intel products. No other circuit patent licenses are implied.

# 2.0 INTEL FLASH MEMORY POWER REQUIREMENTS

Intel flash memory is powered by two sources; a 5V  $V_{CC}$  line and a 12V  $V_{PP}$  line.  $V_{CC}$  is the primary power source and the only power source needed to read the memory.  $V_{PP}$  is required when writing or erasing the memory.

### **V<sub>CC</sub>** Characteristics

 $V_{\rm CC}$  supplies power to the flash device during all operational modes. Maximum  $V_{\rm CC}$  current is demanded by the device during the read operation. The data sheets for specific Intel flash memory devices should be consulted to determine the maximum read current ( $I_{\rm CC}$ ) for the device. If multiple components are read simultaneously, the  $V_{\rm CC}$  current requirement increases proportionately.  $V_{\rm CC}$  tolerance must be maintained to within specification limits at all times for proper functioning of the device.

### **VPP** Characteristics

The supplemental V<sub>PP</sub> source provides the higher voltages needed to carry out the erase, erase verify, program, and program verify operations. Maximum Vpp current is typically demanded during the program and erase modes. The data sheets for specific Intel Flash Memory devices should be consulted to determine the V<sub>PP</sub> voltage and maximum V<sub>PP</sub> write/erase current (IPP) for the device. If multiple components are programmed/erased simultaneously, the current requirement increases proportionately. VPP must be maintained to within specification limits at all times during device program, and erase. The tolerance specification on V<sub>PP</sub> must be strictly maintained. Over-voltage can damage the device, and under-voltage can decrease specified device reliability. Although the VPP supply must meet these worst case specifications, power usage will typically be much lower. The lower typical values seen in the data sheets should be used in calculating typical battery life.



# 2.1 Supplies for Battery Powered Applications

In applications where batteries are the primary source of power, the power supplies providing V<sub>CC</sub> and V<sub>PP</sub> need to be selected very carefully. Optimized operating efficiency of these supplies is important to extend battery life. Another attractive feature is the capability of these supplies to be switched into a very low power shutdown mode. It is important to minimize this shutdown current consumption as well since flash memory V<sub>PP</sub> generators will often be in this state for extended periods of time. Moreover, since these supplies are used in equipment that is physically small and space-constrained, size and height of the supply need to be minimized.

Where two alkaline/NiCd batteries are used as the primary source of power, the primary voltage varies depending on the type and the state of discharge of the batteries. For example, alkaline batteries start life off at 1.5V, but may still retain a significant amount of energy when the voltage falls to 1.0V with use, and will work all the way down to 0.8V. On the other hand, NiCd cells maintain a near constant voltage of 1.25V throughout most of their discharge cycle, and work down to 1.0V. A solution that derives V<sub>CC</sub> or V<sub>PP</sub> from 2 AA batteries must hence be capable of doing so from an input voltage that lies in the range of 1.6V to 3.0V.

It is best to directly convert the primary battery voltage into the various voltages needed throughout the system. A step conversion (e.g. a 3V to 5V converter for V<sub>CC</sub>, followed by a 5V to 12V converter for V<sub>PP</sub>) is not recommended, since the inefficiency involved in each conversion step combines into one large inefficiency for the sum 3V to 12V conversion. Section 4 presents appropriate 3V battery to 12V converter solutions. Most of the solutions presented in this application note, while specifically designed for battery powered applications, are also viewed as ideal for other applications that incorporate flash memory.

### 2.2 Choice of a DC-DC Converter

The solution to finding the right power supply for flash memory lies in picking the right DC-DC converter for the job. Three broad categories of DC-DC converters available in the market today can be applied towards this purpose. These are the low power hybrid DC-DC converter module (or modular solution), the low power discrete switching regulator IC solution, and the low power discrete charge-pump solution.

### The Modular Solution

The modular solution generally consists of a push-pull (Royer type) oscillator built around an isolation transformer, and in some cases followed by a linear regulator; all of which is encapsulated within a module. This hybrid module includes all components that are required by the DC-DC converter, and so no additional design effort is needed. The input and output voltages are fixed, and the input and output are almost always isolated via the isolation transformer. The main advantage of these solutions is that no design effort and/or external components are involved. They simply plug into a socket on a PC board. Disadvantages include lower efficiency (generally 60%), larger size/height (in most cases), and higher cost (generally 3x to 10x the cost of discrete solutions).

It would seem that the integration inherent in these solutions contributes towards system reliability, however the type and quality of the discrete components used internal to these hybrid devices is open to question. The isolation offered between the input and output is viewed as overkill for flash applications, since the total power required is typically less than 1W. Note also that the isolation transformer is often the main reason for the lower efficiencies.

# The Discrete Switching Regulator Solution

The discrete switching regulator IC solution consists of a DC-DC converter IC (containing a switching regulator controller and an output power switch), along with a few discrete external components (inductor, diode, capacitors, resistors, etc.). The layout of the power supply system in this case is mostly left up to the user. However, application notes and data sheets explain the design process, and provide recommended circuits for commonly used solutions. The design can be tailored to deliver different output voltages and current levels depending on the characteristics of the input voltage and the external components.

Some vendors offer fixed output voltage versions, further simplifying the design process. The newer generation of high frequency low power switching regulator ICs are specifically targeted at battery powered operation, and most can be switched into a low quiescent current shutdown mode to extend battery life. These have typical efficiencies in the 75% to 90% range. Furthermore, the higher switching frequencies of these new parts (typically 100 KHz to 200 KHz) allow the use of smaller external components, which are available in surface mount varieties. As a consequence, these newer solutions are overall much smaller than what was typically seen just a year ago.



### The Discrete Charge-Pump Solution

The discrete charge-pump solution is similar to the discrete switching regulator IC solution in that it also consists of a DC-DC converter IC and a few discrete external components (capacitors). The charge-pump, however, operates in a significantly different fashion (see Appendix E), and as a result does not require inductors and diodes as a discrete switching regulator solution does, which means that a charge-pump solution is generally smaller and cheaper. On the down side, charge-pump solutions generally have lower efficiencies and lower output current capabilities than discrete switching regulator solutions.

### Attributes of a DC-DC Converter

Several attributes of a power supply converter must be evaluated and prioritized when choosing the best solution for a given application. These attributes include:

- Input Voltage Range
- Output Voltage and Tolerance
- Output Current Capability
- Efficiency of Conversion
- Printed Circuit Area
- Height
- Total Cost
- Shutdown Capability
- Quiescent Current Consumed in Shutdown Mode
- · Rise Time from Shutdown
- Surface Mountability

### 2.3 Summary

The reader is referred to Appendix B, which provides a survey of all the solutions that are presented in this application note, in order to compare their attributes.

This application note primarily presents state of the art discrete switching regulator IC solutions (and one charge-pump solution) which have been carefully designed for operation with flash memory. Included along with schematics are component values and sources/contacts for obtaining components. Actual layouts have also been included where possible. These are provided in Appendix F.

### NOTE:

External components recommended in the designs should be used. These components (inductors, capacitors, resistors) were chosen based on recommendations by the converter IC vendors and provide the necessary quality for a clean design. Alternate "equivalent" parts should be chosen with care as their resistive and inductive elements can affect the operation of the solution. Please contact the respective converter IC companies for assistance if you select an alternate value/ source for passive components.

# 3.0 V<sub>PP</sub> SOLUTIONS: CONVERTING UP FROM 5V

Most computer systems have available a 5V  $V_{\rm CC}$  line that is used for the majority of system power. Frequently, this 5V supply is used to generate 12V for flash memory. This section presents some of the new state of the art solutions that can achieve this function. These are all discrete switching regulators that optimize different attributes, mentioned along with the main features section of each example. Refer to Appendix B for a more detailed comparison of the attributes of these solutions.



### 3.1 Maxim Integrated Products—MAX734: Vpp @ 120 mA



Figure 3-1. Maxim MAX734 5V to 12V Converter

### **Optimal Attributes**

- High Efficiency
- Low Shutdown Current
- Small Size: 0.3 sq. in. Total Board Area (Single Sided)
- All Surface Mount

### **Main Features**

- Input Voltage Range: 4V to 7V
- Output Voltage: 12V ±5%
- Output Current Capability:
   Up to 120 mA @ V<sub>IN</sub> = 5V
- Typical Efficiency: 83%@  $I_{LOAD} = 120 \text{ mA}$ ,  $V_{IN} = 5V$
- 170 KHz Switching Frequency
- Shutdown Feature on Chip
- Low Quiescent Current at Shutdown: 70 μA typical
- Low Operating Quiescent Current: 1.3 mA typical
- Rise Time from Shutdown: 1.5 ms typical
- Soft-start Capability

The MAX734 is a 12V-output step-up converter which uses 6 small external surface mount components to implement a small 5V to 12V converter solution. It is available in a small 8-pin surface mount package. The MAX734 design as shown is capable of providing up to 120 mA of Vpp current at an efficiency of 83%. The supply can be switched into a shutdown mode where the output voltage falls to approximately V<sub>IN</sub> 100 mV and the quiescent input current falls to below 70 µA. The rise time from shutdown mode is typically 1.5 ms. The MAX734 also has a Soft-start feature which allows the designer to limit surge currents at start-up by adding a capacitor between the MAX734's SS pin and ground. The high switching frequency of the MAX734 allows the use of very small external capacitors and contributes to the small size of the supply circuit. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PCboard layout or by using the optional filter circuit shown in the design. Applications assistance and a surface mount evaluation board are available from Maxim.



Table 3-1. Parts List for the MAX734 5V to 12V Converter

| Ref          | Part #              | Value/Type            | Source                        | Cost*  |
|--------------|---------------------|-----------------------|-------------------------------|--------|
| U1           | MAX734CSA           | SMPS IC               | Maxim<br>(408) 737-7600       | \$1.83 |
| C1, C5       | 267M1602-336-MR-720 | 33 μF/16V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.48 |
| C2           | GRM40Z5U104M050AD   | 0.1 μF                | Murata Erie<br>(404) 436-1300 | \$0.05 |
| C3 (opt)     | GRM40Z5U103M050AD   | 0.01 μF               | Murata Erie<br>(404) 436-1300 | \$0.03 |
| C4           | GRM40Z5U102M050AD   | 0.001 μF              | Murata Erie<br>(404) 436-1300 | \$0.03 |
| C6 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | EC15QS02L           | 1N5817 Diode          | Nihon<br>(805) 867-2555       | \$0.30 |
| L1           | CD43-180            | 18 μΗ                 | Sumida<br>(708) 956-0666      | \$0.55 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     | ·                     | Total Cost                    | \$3.35 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.

# 3.2 Maxim Integrated Products—MAX761: V<sub>PP</sub> @ 150 mA



Figure 3-2. Maxim MAX761 5V to 12V Converter



### **Optimal Attributes**

- High Efficiency
- Lowest Shutdown Current
- Low Quiescent Supply Current
- All Surface Mount

### **Main Features**

- Input Voltage Range: 4.75V to 12V
- Output Voltage: 12V ±4%
- Output Current Capability:
   Up to 150 mA @ V<sub>IN</sub> = 5V
- Typical Efficiency: 86% @ I<sub>LOAD</sub> = 150 mA,
   V<sub>IN</sub> = 5V
- 300 KHz Switching Frequency
- Shutdown Feature on Chip
- Low Quiescent Current at Shutdown: 5 μA max
- Low Operating Quiescent Current: 250 μA typical
- Rise Time from Shutdown: 1 ms typical

The MAX761 is a 12V-output step-up converter which uses pulse-frequency-modulated (PFM) control to offer high efficiency over a wide range of loads. It is available in a small 8-pin surface mount package and uses only 6 small external surface mount components to provide a 12V  $\pm 5\%$  supply. The MAX761 design as shown is capable of providing up to 150 mA of VPP current at an efficiency of 86%. The supply can be switched into a shutdown mode where the output voltage falls to approximately V<sub>IN</sub> and the quiescent supply current falls to below 5 µA. The rise time from shutdown mode is typically 1 ms. The high switching frequency of the MAX761 allows the use of very small external capacitors and contributes to the small size of the supply circuit. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PCboard layout or by using the optional filter circuit shown in the design. Applications assistance and a surface mount evaluation board are available from Maxim.

Table 3-2. Parts List for the MAX761 5V to 12V Converter

| Ref          | Part #              | Value/Type            | Source                        | Cost*  |
|--------------|---------------------|-----------------------|-------------------------------|--------|
| U1           | MAX761CSA           | SMPS IC               | Maxim<br>(408) 737-7600       | \$2.02 |
| C1, C2       | 267M1602-226-MR-720 | 22 μF/16V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.48 |
| C3, C5       | GRM40Z5U104M050AD   | 0.1μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| C4 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | EC10QS02L           | 1N5817 Diode          | Nihon<br>(805) 867-2555       | \$0.22 |
| L1           | CD43-180MC          | 18 μΗ                 | Sumida<br>(708) 956-0666      | \$0.53 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     | ·                     | Total Cost                    | \$3.38 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.



### 3.3 Maxim Integrated Products—MAX662: Vpp @ 30 mA



Figure 3-3. Maxim MAX662 5V to 12V Converter

### **Optimal Attributes**

- Lowest Cost
- Low Shutdown Current
- Low Quiescent Supply Current
- Fast Rise Time from Shutdown
- No Inductors Necessary
- Small Size: 0.2 sq. in. Total Board Area (Single Sided)
- All Surface Mount

### **Main Features**

- Input Voltage Range: 4.75V to 5.5V
- Output Voltage: 12V ±5%
- Output Current Capability: Up to 30 mA @ V<sub>IN</sub> = 5V
- Typical Efficiency: 74% @ I<sub>LOAD</sub> = 30 mA,
   V<sub>IN</sub> = 5V
- 400 KHz Switching Frequency
- Shutdown Feature on Chip

- Low Quiescent Current at Shutdown: 70 μA typical
- Low Operating Quiescent Current: 320 µA typical
- Rise Time from Shutdown: 600 µs typical

The MAX662 is a 12V-output boost converter. It uses internal charge pumps and 5 small external surface mount capacitors to generate Vpp, with no need for inductors. It is available in a small 8-pin narrow surface mount package. The MAX662 design as shown is capable of providing up to 30 mA of Vpp current at an efficiency of 74%. The supply can be switched into a shutdown mode where the output voltage falls to VIN and the quiescent supply current falls to below 70 µA. The rise time from shutdown mode is typically 600 µs. The high switching frequency of the MAX662 allows the use of very small external capacitors and contributes to the small size of the supply circuit. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PC-board layout or by using the optional filter circuit shown in the design. Applications assistance and a surface mount evaluation board are available from Maxim.



| Table 3-3  | Darte I ie  | t for the | MAYGG2 5V     | to 12V Converter |  |
|------------|-------------|-----------|---------------|------------------|--|
| Table 3-3. | . Paris Lis | i ior ine | V C 200 A ANI | to izv Converter |  |

| Ref          | Part #              | Value/Type             | Source                        | Cost*  |
|--------------|---------------------|------------------------|-------------------------------|--------|
| U1           | MAX662CSA           | SMPS IC                | Maxim<br>(408) 737-7600       | \$1.69 |
| C1, C2       | GRM40Y5V224Z025AD   | 0.22 μF                | Murata Erie<br>(404) 436-1300 | \$0.15 |
| C3           | GRM40Z5U104M050AD   | 0.1 μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| C4, C5       | 267M1602-475-MR-533 | 4.7 μF/16V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.21 |
| C6 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                 | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     |                        | Total Cost                    | \$2.18 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.

## 3.4 Linear Technology LT1109-12: V<sub>PP</sub> @ 60 mA



Figure 3.4 Linear Technology LT1109-12 5V to 12V Converter



### **Optimal Attributes**

- Low Quiescent Supply Current
- Small Size
- All Surface Mount

#### **Main Features**

• Input Voltage Range: 4.5V to 5.5V

 Output Voltage: 12V ±5%
 Output Current Capability: Up to 60 mA, @ V<sub>IN</sub> = 5V

• Typical Efficiency: 84% @  $I_{LOAD} = 60 \text{ mA}$ ,  $V_{IN} = 5V$ 

• 120 KHz Switching Frequency

• Shutdown Feature on Chip

 Low Quiescent Current at Shutdown: 320 μA typical Low Operating Quiescent Current: 320 μA typical

• Rise Time from Shutdown: 800 us typical

The LT1109-12 is a fixed 12V-output part which is well suited to flash memory applications. It is available in a small 8-pin surface mount package and uses only 4 small external components to implement a very small size 5V to 12V converter solution. The LT1109-12 design as shown is capable of providing up to 60 mA of V<sub>PP</sub> current at an efficiency of 84%. The supply can be switched into a shutdown mode where the output voltage falls to approximately V<sub>IN</sub>-550 mV. Quiescent supply current at shutdown remains at approximately 320 µA. The rise time from shutdown mode is typically 800 µs. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PC-board layout or by using the optional filter circuit shown in the design. Applications assistance is available from Linear Technology Corporation.

Table 3-4. Parts List for the LT1109-12 5V to 12V Converter

| Ref          | Part#               | Value/Type            | Source                        | Cost*  |
|--------------|---------------------|-----------------------|-------------------------------|--------|
| U1           | LT1109CS8-12        | SMPS IC               | Linear Tech<br>(408) 432-1900 | \$2.16 |
| C1           | 267M1002-226-MR-720 | 22 μF/10V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.16 |
| C2           | 267M2502-106-MR-720 | 10 μF/25V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.24 |
| C3 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | MBRS120T3           | Schottky Diode        | Motorola<br>(800) 521-6274    | \$0.37 |
| L1           | CD54-330LC          | 3 μΗ                  | Sumida<br>(708) 956-0666      | \$0.55 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     |                       | Total Cost                    | \$3.56 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.



### 3.5 Linear Technology LT1301: Vpp @ 200 mA



Figure 3-5. Linear Technology LT1301 5V to 12V Converter

### **Optimal Attributes**

- High Efficiency
- High Output Current Capability
- Low Shutdown Current
- Low Quiescent Supply Current
- Small Size

### **Main Features**

- Input Voltage Range: 3V to 10V
- Output Voltage: 12V ±5%
- Output Current Capability: Over 200 mA @ V<sub>IN</sub> = 5V
- Typical Efficiency: 88% @ I<sub>LOAD</sub> = 200 mA,
   V<sub>IN</sub> = 5V
- 155 KHz Switching Frequency
- Shutdown Feature on Chip
- Low Quiescent Current at Shutdown: 15 µA max
- Low Operating Quiescent Current: 120 µA typical
- Rise Time from Shutdown: 1.2 ms typical

The LT1301 is a micropower step-up DC-DC converter. It is available in a small 8-pin surface mount package and uses only 4 small external surface mount components. The LT1301 design as shown is capable of providing over 200 mA of Vpp current at an efficiency of 88%. The supply can be switched into a shutdown mode where the output voltage falls to approximately V<sub>IN</sub> - 550 mV and the quiescent supply current falls to below 15 µA. The LT1301 also has an input which selects between a 5V and 12V output, for flexibility in migration to Smart Voltage flash memory. The high switching frequency of the MAX761 allows the use of very small external capacitors and contributes to the small size of the supply circuit. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PC-board layout or by using the optional filter circuit shown in the design. Applications assistance is available from Linear Technology Corporation.



Table 3-5. Parts List for the LT1301 5V to 12V Converter

| Ref          | Part #              | Value/Type             | Source                        | Cost*  |
|--------------|---------------------|------------------------|-------------------------------|--------|
| U1           | LT1301CS8           | SMPS IC                | Linear Tech<br>(408) 432-1900 | \$2.40 |
| C1           | 267M1002-107-MR-720 | 100 μF/10V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.35 |
| C2           | 267M1602-476-MR-720 | 4 μF/16V<br>Tantalum   | Matsuo<br>(714) 969-2491      | \$0.35 |
| C3 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | EC10QS02L           | 1N5817 Diode           | Nihon<br>(805) 867-2555       | \$0.22 |
| L1           | CD75-220KC          | 22 μΗ                  | Sumida<br>(708) 956-0666      | \$0.63 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                 | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     |                        | Total Cost                    | \$4.03 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.

# 3.6 Motorola MC34063A: V<sub>PP</sub> @ 120 mA



Figure 3-6. Motorola MC34063A 5V to 12V Converter



### **Optimal Attributes**

- Low Cost
- Low Shutdown Current
- All Surface Mount

### **Main Features**

• Input Voltage Range: 4.5V to 5.5V

• Output Voltage: 12V ±5%

 Output Current Capability: Up to 120 mA @ V<sub>IN</sub> = 5V

Typical Efficiency: 80% @ I<sub>LOAD</sub> = 120 mA,
 V<sub>IN</sub> = 5V

• 100 KHz Switching Frequency

• Shutdown Feature using External Components

Low Quiescent Current at Shutdown: 25 μA typical

• Rise Time from Shutdown: 2 ms typical

The MC34063A solution presented uses 11 small sized external components to implement a low cost surface mount 5V to 12V converter solution. Three external components (U2, R4, R5) are used to shut down supply to the part when Vpp is not needed. These could be eliminated to further lower the cost if power consumption is not important. The quiescent current in shutdown state is 25  $\mu$ A. The output voltage in shutdown is approximately V<sub>IN</sub>-550 mV. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PC-board layout or by using the optional filter circuit shown in the design. Applications assistance is available from Motorola.

Table 3-6. Parts List for the MC34063A 5V to 12V Converter

| Ref          | Part #              | Value/Type            | Source                        | Cost*  |
|--------------|---------------------|-----------------------|-------------------------------|--------|
| U1           | MC34063A            | SMPS IC               | Motorola<br>(800) 521-6274    | \$0.85 |
| U2           | MMBT4403LT1         | PNP Transistor        | Motorola<br>(800) 521-6274    | \$0.10 |
| C1           | 267M1002-336-MR-720 | 33 μF/10V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.24 |
| C2           | 267M1602-336-MR-720 | 33 μF/16V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.24 |
| C3           | GRM40X7R330M050AD   | 330 pF                | Murata Erie<br>(404) 436-1300 | \$0.08 |
| C4 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | MBRS120T3           | Schottky Diode        | Motorola<br>(800) 521-6274    | \$0.37 |
| L1           | CD54-470LC          | 47 μΗ                 | Sumida<br>(708) 956-0666      | \$0.55 |
| R1 .         | 9C08052A9100JLR     | 91Ω, 5%               | Philips<br>(817) 325-7871     | \$0.02 |
| R2           | 9B08053A1723FCB     | 172 ΚΩ, 1%            | Philips<br>(817) 325-7871     | \$0.03 |
| R3           | 9B08053A2002FCB     | 20 ΚΩ, 1%             | Philips<br>(817) 325-7871     | \$0.03 |
| R4           | 9C08052A3001JLR     | 3 ΚΩ, 5%              | Philips<br>(817) 325-7871     | \$0.02 |
| R5           | 9C08052A1002JLR     | 10 ΚΩ, 5%             | Philips<br>(817) 325-7871     | \$0.02 |
| R6, R7 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     |                       | Total Cost                    | \$2.63 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.



# 4.0 V<sub>PP</sub> SOLUTIONS: CONVERTING UP FROM 2 NICd/ALKALINE CELLS

Palmtop computers that use 2 alkaline/NiCd batteries require that the system work even when the battery

voltage is down near 1.8V. Currently there exist two good solutions that achieve a 12V output with inputs as low as 1.8V, and yet supply at least 30 mA of current. These are the LT1301 from Linear Technology Corporation, and the MAX761 from Maxim Integrated Products.

## 4.1 Maxim Integrated Products—MAX761: VPP @ 75 mA



Figure 4-1. Maxim MAX761 3V to 12V Converter

### **Optimal Attributes**

- High Efficiency
- Lowest Shutdown Current
- Low Quiescent Supply Current
- All Surface Mount

### **Main Features**

- Input Voltage Range: 1.7V to 12V
- Output Voltage: 12V ±5%
- Output Current Capability:
   Up to 75 mA @ V<sub>IN</sub> = 3.3V
- Typical Efficiency: 79% @  $I_{LOAD} = 75 \text{ mA}$ ,  $V_{IN} = 3.3V$
- 300 KHz Switching Frequency
- Shutdown Feature on Chip
- Low Quiescent Current at Shutdown: 5 µA max
- Low Operating Quiescent Current: 500 μA typical
- Rise Time from Shutdown: 1 ms typical

The MAX761 is a 12V-output step-up converter which uses pulse-frequency-modulated (PFM) control to offer high efficiency over a wide range of loads. It is available in a small 8-pin surface mount package and uses only 6 small external surface mount components to provide a 12V  $\pm$ 5% supply. This design is identical to the 5V to 12V converter design shown in Section 3.2, but with different characteristics when operating with a 3.3V input. The MAX761 design as shown is capable of providing up to 75 mA of  $V_{PP}$  current at an efficiency of 79% with a  $V_{IN}$  of 3.3V. The supply can be switched into a shutdown mode where the output voltage falls to approximately  $V_{IN}$  and the quiescent supply current falls to below 5  $\mu$ A. The rise time from shutdown mode is typically 1 ms. The high switching frequency of the MAX761 allows the use of very small external capacitors and contributes to the small size of the supply circuit. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PCboard layout or by using the optional filter circuit shown in the design. Applications assistance and a surface mount evaluation board are available from Maxim.



Table 4-1. Parts List for the MAX761 3.3V to 12C Converter

| Ref          | Part#               | Value/Type            | Source                        | Cost*  |
|--------------|---------------------|-----------------------|-------------------------------|--------|
| U1           | MAX761CSA           | SMPS IC               | Maxim<br>(408) 737-7600       | \$2.02 |
| C1, C2       | 267M1602-226-MR-720 | 22 μF/16V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.48 |
| C3, C5       | GRM40Z5U104M050AD   | 0.1 μF                | Murata Erie<br>(404) 436-1300 | \$0.05 |
| C4 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | EC10QS02L           | 1N5817 Diode          | Nihon<br>(805) 867-2555       | \$0.22 |
| L1 .         | CD43-180MC          | 18 μΗ                 | Sumida<br>(708) 956-0666      | \$0.53 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     |                       | Total Cost                    | \$3.38 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.

# 4.2 Linear Technology LT1301: V<sub>PP</sub> @ 120 mA



Figure 4-2. Linear Technology LT1301 3V to 12V Converter



### **Optimal Attributes**

- High Efficiency
- High Output Current Capability
- Low Shutdown Current
- Low Quiescent Supply Current
- Small Size

### **Main Features**

- Input Voltage Range: 1.8V to 10V
- Output Voltage: 12V ± 5%
- Output Current Capability: Up to 120 mA @ V<sub>IN</sub> = 3.3V
- Typical Efficiency: 86% @ I<sub>LOAD</sub> = 120 mA,
   V<sub>IN</sub> = 3.3V
- 155 KHz Switching Frequency
- Shutdown Feature on Chip
- Low Quiescent Current at Shutdown: 15 μA max
- Low Operating Quiescent Current: 120 μA typical
- Rise Time from Shutdown: 1.2 ms typical

The LT1301 is a micropower step-up DC-DC converter. It is available in a small 8-pin surface mount package and uses only 4 small external surface mount components. This design is identical to the 5V to 12V converter design shown in Section 3.5, but with different characteristics when operating with a 3.3V input. The LT1301 design as shown is capable of providing 120 mA of V<sub>PP</sub> current at an efficiency of 86%. The supply can be switched into a shutdown mode where the output voltage falls to approximately V<sub>IN</sub> -550 mV and the quiescent supply current falls to below 15 µA. The LT1301 also has an input which selects between a 5V and 12V output, for flexibility in migration to a Smart Voltage flash memory. The high switching frequency of the MAX761 allows the use of very small external capacitors and contributes to the small size of the supply circuit. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PC-board layout or by using the optional filter circuit shown in the design. Applications assistance is available from Linear Technology Corpo-

Table 4-2. Parts List for the LT1301 3.3V to 12V Converter

| Ref          | Part#               | Value/Type             | Source                        | Cost*  |
|--------------|---------------------|------------------------|-------------------------------|--------|
| U1           | LT1301CS8           | SMPS IC                | Linear Tech<br>(408) 432-1900 | \$2.40 |
| C1           | 267M1002-107-MR-720 | 100 μF/10V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.35 |
| C2           | 267M1602-476-MR-720 | 47 μF/16V<br>Tantalum  | Matsuo<br>(714) 969-2491      | \$0.35 |
| C3 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | EC10QS02L           | 1N5817 Diode           | Nihon<br>(805) 867-2555       | \$0.22 |
| L1           | CD75-220KC          | 22 μΗ                  | Sumida<br>(708) 956-0666      | \$0.63 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                 | Philips<br>(817) 325-7871     | \$0.03 |
|              | Total Cost          |                        |                               |        |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.



# 5.0 V<sub>CC</sub> SOLUTIONS: CONVERTING UP FROM TWO NICd/ALKALINE CELLS

Palmtop and hand-held computers that use two AA size NiCd or alkaline batteries need a converter solu-

tion to provide the  $V_{\rm CC}$  supply for the system as well as flash memory. Two good solutions are offered currently for this purpose, the MAX756 from Maxim Integrated Products and the LT1301 from Linear Technology Corporation.

## 5.1 Maxim Integrated Products—MAX756: V<sub>CC</sub> @ 400 mA



Figure 5-1. Maxim MAX756 3V to 5V Converter



### **Optimal Attributes**

- High Output Current Capability
- Low Quiescent Supply Current
- Low Shutdown Current
- High Efficiency

### **Main Features**

- Input Voltage Range: 0.9V to 5V
- Output Voltage: 5V ±4%
- Output Current Capability: Up to 400 mA @  $V_{IN} = 3V$
- Typical Efficiency:
   87% @ I<sub>LOAD</sub> = 200 mA, V<sub>IN</sub> = 3.3V
- 0.5 MHz Switching Frequency
- Shutdown Feature on Chip

- Low Quiescent Current at Shutdown: 20 μA max
- Low Operating Quiescent Current: 140 μA typical
- Rise Time from Shutdown: 2 ms typical

The MAX756 is a high-current solution for obtaining  $V_{\rm CC}$  from a pair of NiCd/alkaline cells. The supply can be switched into a shutdown mode where the output voltage falls to approximately  $V_{\rm IN}$  and the quiescent supply current falls to below 20  $\mu$ A. The high switching frequency of the MAX756 allows the use of very small external capacitors and inductors and contributes to the small size of the supply circuit. Series inductance in the filter capacitor and diode switching transients may cause high-frequency noise which appears as sharp voltage spikes in the output. Such spikes can be eliminated by practicing good PC-board layout or by using the optional filter circuit shown in the design. Applications assistance and an evaluation kit are available from Maxim.

Table 5-1. Parts List for the MAX756 3V to 5V Converter

| Ref          | Part #              | Value/Type             | Source                        | Cost*  |
|--------------|---------------------|------------------------|-------------------------------|--------|
| U1           | MAX756              | SMPS IC                | Maxim<br>(408) 737-7600       | \$1.97 |
| C1           | 267M1002-107-MR-720 | 100 μF/10V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.35 |
| C2           | 267M1602-476-MR-720 | 47 μF/16V<br>Tantalum  | Matsuo<br>(714) 969-2491      | \$0.35 |
| СЗ           | GRM40Z5U104M050AD   | 0.1 μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| C4 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | EC10QS02L           | 1N5817 Diode           | Nihon<br>(805) 867-2555       | \$0.22 |
| <b>L1</b>    | CD54-220KC          | 22 μΗ                  | Sumida<br>(708) 956-0666      | \$0.55 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                 | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     |                        | Total Cost                    | \$3.57 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written.



## 5.2 Linear Technology LT1301: V<sub>CC</sub> @ 120 mA



Figure 5-2. Linear Technology LT1301 3V to 5V Converter

### **Optimal Attributes**

- Low Shutdown Current
- Low Quiescent Supply Current
- Small Size

### **Main Features**

- Input Voltage Range: 1.8V to 5V
- Output Voltage: 5V ±5%

- Output Current Capability:
   Up to 120 mA @ V<sub>IN</sub> = 3.3V
- Typical Efficiency: 86% @ I<sub>LOAD</sub> = 120 mA, V<sub>IN</sub> = 3.3V
- 155 KHz Switching Frequency
- Shutdown Feature on Chip
- Low Quiescent Current at Shutdown: 15 μA max
- Low Operating Quiescent Current: 120 μA typical
- Rise Time from Shutdown: 1.2 ms typical

The LT1301 3V-to-5V converter design is the same as the LT1301 12V converter designs shown in sections 3.4 and 4.2, with the output selected as 5V instead of 12V using the select pin.



Table 5-2. Parts List for the LT1301 3.3V to 5V Converter

| Ref          | Part #              | Value/Type             | Source                        | Cost*  |
|--------------|---------------------|------------------------|-------------------------------|--------|
| U1           | LT1301CS8           | SMPS IC                | Linear Tech<br>(408) 432-1900 | \$2.40 |
| C1           | 267M1002-107-MR-720 | 100 μF/10V<br>Tantalum | Matsuo<br>(714) 969-2491      | \$0.35 |
| C2           | 267M1602-476-MR-720 | 47 μF/16V<br>Tantalum  | Matsuo<br>(714) 969-2491      | \$0.35 |
| C3 (opt)     | GRM40Z5U104M050AD   | 0.1 μF                 | Murata Erie<br>(404) 436-1300 | \$0.05 |
| D1           | EC10QS02L           | 1N5817 Diode           | Nihon<br>(805) 867-2555       | \$0.22 |
| L1           | CD75-220KC          | 22 μΗ                  | Sumida<br>(708) 956-0666      | \$0.63 |
| R1, R2 (opt) | 9C08052A1R00JLR     | 1Ω, 5%                 | Philips<br>(817) 325-7871     | \$0.03 |
|              |                     |                        | Total Cost                    | \$4.03 |

<sup>\*</sup> Cost estimates based on published 10K unit pricing at the time this application note was written

### 6.0 DOWN-CONVERTING TO 12V

The ability to down-convert to 12V from a higher voltage is often needed (as in the telecommunications environment). This section presents some good solutions for obtaining  $V_{PP}$  from a higher voltage.

## 6.1 Maxim Integrated Products MAX667



Figure 6-1. Maxim MAX667 12V Linear Voltage Regulator



### **Optimal Attributes**

- Small Size
- Ultra Low Shutdown Current
- All Surface Mount
- Very Low Dropout

### **Main Features**

• Input Voltage Range: 12.1V to 16.5V

• Output Voltage: 12V ±5%

• Output Current Capability: Up to 120 mA

• Typical Efficiency: 70%

• Shutdown Mode On Chip

 Low Quiescent Current at Shutdown: 0.2 μA Typical

• Rise Time from Shutdown: Less than 0.1 ms Typical

Table 6-1. Parts List for the MAX667 12V Step Down Converter

| Ref | Part #              | Value/Type              | Source                    | Cost*  |
|-----|---------------------|-------------------------|---------------------------|--------|
| U1  | MAX667CSA           | SMPS IC-<br>SO8 Package | Maxim<br>(408) 737-7600   | \$1.99 |
| C1  | 267M1602-476-MR-720 | 7 μF/16V<br>Tantalum    | Matsuo<br>(714) 969-2491  | \$0.35 |
| R1  | 9C08053A4023JLR     | 402 ΚΩ, 1%              | Philips<br>(817) 325-7871 | \$0.03 |
| R2  | 9C08053A4752JLR     | 47.5 KΩ,1%              | Philips                   | \$0.03 |
|     |                     | •                       | Total Cost                | \$2.39 |

<sup>\*</sup>Cost estimates based on published 10K unit pricing at the time this application note was written.



#### 6.2 Linear Technology Corporation LT1111-12



Figure 6-2. Linear Technology LT1111-12 Step Down Switcher

#### **Optimal Attributes**

- High Efficiency
- All Surface Mount

#### **Main Features**

• Input Voltage Range: 16V to 30V

• Output Voltage: 12V ±5%

• Output Current Capability: Up to 120 mA

• Typical Efficiency: 80%

Table 6-2. Parts List for the LT1111-12 12V Step Down Converter

| Ref    | Part #              | Value/Type              | Source                        | Cost*  |
|--------|---------------------|-------------------------|-------------------------------|--------|
| U1     | LT1111-12           | SMPS IC-<br>SO8 Package | Linear Tech<br>(408) 432-1900 | \$2.20 |
| C1     | 267M3502-225-MR-720 | 2.2 μF/35V<br>Tantalum  | Matsuo<br>(714) 969-2491      | \$0.28 |
| C2     | 267M1602-476-MR-720 | 47 μF/16V<br>Tantalum   | Matsuo<br>(714) 969-2491      | \$0.35 |
| R1     | 9C08052A1500JLR     | 150Ω, 5%                | Philips<br>(817) 325-7871     | \$0.02 |
| L1     | CDR105-470          | 47 μΗ                   | Sumida<br>(708) 956-0666      | \$0.38 |
| D1, D2 | MBRS140T3           | Schottky Diode          | Motorola<br>(800) 521-6274    | \$0.74 |
|        |                     |                         | Total Cost                    | \$3.97 |

<sup>\*</sup>Cost estimates based on published 10K unit pricing at the time this application note was written.



#### 6.3 National Semiconductor LM2940CT-12



Figure 6-3. National LM2940CT-12 12V Linear Regulator

#### **Optimal Attributes**

Lowest Cost

#### **Main Features**

Input Voltage Range: 13V to 26V
Output Voltage: 12V ±3%

• Output Current Capability: 1A

The LM2940CT-12 is a low drop-out linear regulator from National Semiconductor. This is a good low cost fixed 12V output solution. The part is offered in a standard TO-220 plastic package. The input capacitor is required only if the regulator is located far away from the input power supply filter, and the output capacitor must be at least 22  $\mu$ F in order to maintain stability.

Table 6-3. Parts List for the LM2940CT-12 Step Down Converter

| Ref | Part #              | Value/Type                                  | Source                        | Cost*  |
|-----|---------------------|---------------------------------------------|-------------------------------|--------|
| U1  | LM2940CT-12         | Voltage Reg TO-220                          | National<br>(408) 721-5000    | \$0.95 |
| C1  | GRM43-2Z5U474M050AD | 0.47 μF/50V                                 | Murata Erie<br>(404) 436-1300 | \$0.07 |
| C2  | 267M1602-226-MR-720 | 22 μF/16V Matsuo<br>Tantalum (714) 969-2491 |                               | \$0.24 |
|     |                     |                                             | Total Cost                    | \$1.26 |

<sup>\*</sup>Cost estimates based on published 10K unit pricing at the time this application note was written.



## 7.0 OBTAINING V<sub>PP</sub> FROM 12V UNREGULATED

In systems like the desktop computer, a 12V supply exists but may not be regulated to  $\pm 5\%$ . If this voltage is used as the Vpp source for flash memory, it may well degrade the write/erase performance of the memory, or adversely affect its reliability. Fortunately, in most of the situations where a 12V unregulated (or not regulated to within 5%) supply exists, a 5V supply also exists in the system (the desktop computer is a good example). It is recommended in such cases that the existing 5V supply be used to obtain the 12V  $\pm 5\%$  rail. This approach is more economical, more efficient, and provides space savings over a buck-boost topology that takes unregulated 12V and regulates it to  $\pm 5\%$ .

In the rare case where a 5V supply is not present, modular solutions exist that will regulate the unregulated 12V supply to  $\pm 5\%$ . However, these are bulky and expensive. Moreover, many of them require that a minimum load be maintained in order to stay in regulation. One such solution in presented in Appendix A.

#### 8.0 SUMMARY

For battery powered applications, the author views the discrete switching regulator IC solution or charge pump solution as a better choice than the modular solution. The lower cost, higher efficiency, and smaller size/height associated with discrete solutions justify the small additional design effort required to incorporate them in flash memory applications. In applications where the primary source of power is a wall power outlet, or in applications where the flash memory will be written to infrequently, efficiency and quiescent current take on secondary importance. In such cases, it may be acceptable to use a 12V regulated (to within  $\pm 5\%$ ) tap from the system supply. Alternatively, the ability to easily design-in modular solutions may outweigh the disadvantages of lower efficiency and increased cost. For those users wishing to incorporate modular solutions, Appendix A provides some of the lower cost solutions from this industry segment.



# APPENDIX A MODULAR SOLUTIONS

Modular solutions may work well in non-battery powered situations where the efficiency of the power supply converter is not critical. These are also advantageous in that they usually do not need any external components and there is no converter design involved. However, the type and quality of the discrete components used in these hybrid solutions is open to question. This is not true in the case of the discrete converter designs presented in the earlier sections, where the quality of the components used are under the control of the system design engineer. Hence, even though modular solutions offer the convenience of a single package and ease of testability, the quality/reliability of comparably priced modular solutions may be questionable.

Some modular solutions suited to flash memory applications are presented below, with a brief description of each. Sources for obtaining these are listed in Appendix B.

# International Power/Newport Components NMF0512S

The NMF0512S is a 5V to 12V hybrid power module that has an output current capability of 80 mA. Output tolerance is  $\pm 5\%$ . It is equipped with a shutdown pin which can be used to switch Vpp off. However, power dissipated in the shutdown mode is relatively high (about 100 mW). The part is small in size and measures 0.76 in. (19.5 mm) x 0.4 in. (9.8 mm) x 0.4 in. (9.8 mm), and costs about \$7.90 in 10K quantities (at the time this application note was written). Typical efficiency of conversion is 62%.

#### Xentek NPSC-0512S

The Xentek NPSC-0512S is a 1W power module that converts 5V to  $V_{PP}$  and will source up to 80 mA of continuous current. However, it uses two external filter capacitors—one at the input and one at the output. The input filter capacitor is 47  $\mu F/10V$ , and the output filter capacitor is 100  $\mu F/16V$ . Size of the solution (converter alone) is 0.87 in. (22 mm) x 0.39 in. (10 mm) x 0.79 in. (20 mm). The NPSC-0512S does not have a shutdown mode. The part costs around \$5.00 in 10K quantities (at the time this application note was written). Typical efficiency of conversion is 60%.

#### Shindengen America Inc. HDF-0512D

The HDF-0512D module from Shindengen will convert unregulated 12V to  $12V\pm5\%$ . This part is a dual output part ( $\pm12V$ ), but only the +12V line is used. The conversion efficiency is high (75% typical), and the part will provide a regulated Vpp voltage from input voltages as low as 8V, and as high as 16.5V. A minimum load of 5 mA needs to be maintained to guarantee regulation. Size of the solution is 1.75 in. (44 mm) x 0.43 in. (11 mm) x 0.8 in. (20 mm). Cost is approximately \$10.00 in quantities of 10K (at the time this application note was written).

#### Valor PM6064

The PM6064 is a 5V to 12V module that will source up to 60 mA of current. Output tolerance is  $\pm 5\%$ . It has an enable pin which allows Vpp to be switched off. The supply current when Vpp is disabled is less than 20  $\mu$ A. The part's dimensions are 0.78 in. (19.8mm) x 0.38 in. (14.7mm) x 0.35 in. (8.9mm). The part costs \$3.00 in 10K quantities. Typical efficiency of conversion is high, relative to other modular solutions, at 74%.

| REF | VENDOR<br>NAME | PART#       | INPUT V<br>(Volts) | OUTPUT V<br>(Volts) | OUTPUT C<br>(mA) | EFFIC<br>(%)        | EXT COMP<br>(Note 1) | 100%<br>SMD? | COST<br>(Note 2) | PC AREA<br>(Note 3) | HEIGHT<br>(in.) | SHDN ? | ISHDN<br>(Note 4) | R Time<br>(Note 5) | Temp        |
|-----|----------------|-------------|--------------------|---------------------|------------------|---------------------|----------------------|--------------|------------------|---------------------|-----------------|--------|-------------------|--------------------|-------------|
| 3.1 | Maxim          | MAX734      | 4V-7V              | 12V, 5%             | 120 mA           | 83%                 | 6;D,L,4C             | YES          | \$3.35           | 0.3                 | 0.18            | YES    | 70 μA             | 1.5 ms             | 0°C, 70°C   |
| 3.2 | Maxim          | MAX761      | 4.75V-12V          | 12V, 4%             | 150 mA           | 86%                 | 6;D,L,4C             | YES          | \$3.38           | 0.3                 | 0.12            | YES    | 5 μΑ              | 1 ms               | 0°C, 70°C   |
| 3.3 | Maxim          | MAX662      | 4.75V-5.5V         | 12V, 5%             | 30 mA            | 74%                 | 5;5C                 | YES          | \$2.18           | 0.2                 | 0.07            | YES    | 70 μA             | 0.6 ms             | 0°C, 70°C   |
| 3.4 | Linear Tech    | LT1109-12   | 5V, 10%            | 12V, 5%             | 60 mA            | 84%                 | 4,D,L,2C             | YES          | \$3.56           | 0.38                | 0.18            | YES    | 320 µA            | 0.8 ms             | 0°C, 70°C   |
| 3.5 | Linear Tech    | LT1301      | 3V-10V             | 12V, 5%             | 200 mA           | 88%                 | 4;D,L,2C             | YES          | \$4.03           | 0.38                | 0.14            | YES    | 15 μΑ             | 1.2 ms             | 0°C, 70°C   |
| 3.6 | Motorola       | MC34063A    | 5V, 10%            | 12V, 5%             | 120 mA           | 75%                 | 11;D;L;T;3C;5R       | YES          | \$2.63           | 0.49                | 0.18            | YES    | 25 μΑ             | 2 ms               | 0°C, 70°C   |
| 4.1 | Maxim          | MAX761      | 1.7V-12V           | 12V, 5%             | 75 mA            | 79%                 | 6;D,L,4C             | YES          | \$3.38           | 0.3                 | 0.12            | YES    | 5 μΑ              | 1 ms               | 0°C, 70°C   |
| 4.2 | Linear Tech    | LT1301      | 3V-10V             | 12V, 5%             | 120 mA           | 86%                 | 4;D,L,2C             | YES          | \$4.03           | 0.38                | 0.14            | YES    | 15 μA             | 1.2 ms             | 0°C, 70°C   |
| 5.1 | Maxim          | MAX756      | 0.9V-5V            | 5V, 4%              | 400 mA           | 87%                 | 5;D,L,3C             | YES          | \$3.57           | 0.4                 | 0.2             | YES    | 20 μA             | 2 ms               | 0°C, 70°C   |
| 5.2 | Linear Tech    | LT1301      | 1.8V-5V            | 5V, 5%              | 120 mA           | 86%                 | 4;D,L,2C             | YES          | \$4.03           | 0.38                | 0.14            | YES    | 15 μA             | 1.2 ms             | 0°C, 70°C   |
| 6.1 | Maxim          | MAX667      | 12.1V-16.5V        | 12V, 5%             | 250 mA           | 70%                 | 3;2R,1C              | YES          | \$2.39           | 0.25                | 0.15            | YES    | 0.2 μΑ            | 0.1 ms             | 0°C, 70°C   |
| 6.2 | Linear Tech    | LT1111-12   | 16V-30V            | 12V, 5%             | 120 mA           | 80%                 | 6;2D,L,2C,R          | YES          | \$3.97           | 0.78                | 0.2             | NO     | N/A               | N/A                | 0°C, 70°C   |
| 6.3 | National       | LM2940CT-12 | 13V-26V            | 12V, 3%             | 1 Amp            | 12V/V <sub>IN</sub> | 2;2C                 | NO           | \$1.26           | 0.5                 | 0.18            | NO     | N/A               | N/A                | 0°C, 70°C   |
| A.1 | International  | NMF0512S    | 5V, 10%            | 12V, 5%             | 80 mA            | 62%                 | 0                    | NO           | \$7.90           | 0.3                 | 0.40            | YES    | 20 mA             | 10 μs              | 0°C, 70°C   |
|     | Power          |             |                    |                     |                  |                     |                      |              |                  |                     |                 | -      | 1                 |                    |             |
| A.2 | Shindengen     | HDF1212D    | 8V-16.5V           | 12V, 5%             | 120 mA           | 77%                 | 0                    | NO           | \$10.00          | 0.76                | 0.80            | NO     | N/A               | N/A                | -40°C, 70°C |
| A.3 | Xentek         | NPSC-0512S  | 5V, 10%            | 12V, 5%             | 80 mA            | 60%                 | 2;2C                 | NO           | \$5.50           | 0.34                | 0.79            | NO     | N/A               | N/A                | -10°C, 70°C |
| A.4 | Valor          | PM6064      | 5V, 10%            | 12V, 5%             | 60 mA            | 74%                 | 0                    | NO.          | \$3.00           | 0.9                 | 0.35            | YES    | 20 μΑ             |                    | -10°C, 70°C |

#### NOTES:

- 1. # External components. D: Diode, L: Inductor, C: Capacitor, R: Resistor, T: Transistor
- 2. Cost. Cost estimates assume 10K quantities
- 3. PC Area. PC Area is conservatively estimated as 2.0X (area of all components). Where actual layouts are presented, the lower value is given. Note that this estimate is for a single sided board, and area can be reduced considerably if both sides of the board are utilized.
- 4. I Shdn. Current consumed by supply at shutdown. Output settles to VCC at shutdown, so some additional flash Vpp leakage/standby will exist.
- 5. R Time. Rise time from shutdown state. Erase/Writes should not be attempted till Vpp level has risen to valid level after shutdown is disabled.





#### APPENDIX C SOURCES/CONTACTS FOR RECOMMENDED DC-DC CONVERTERS

#### **Linear Technology Corporation**

#### Recommended Products:

- LT1109-12 (DC-DC Converter IC)
- LT1111-12 (DC-DC Converter IC)
- LT1301 (DC-DC Converter IC)

#### In U.S.A.:

1630 McCarthy Blvd. Milpitas, CA 95035-7487 Tel: (408) 432-1900 Fax: (408) 432-0507

#### In Europe (U.K.):

111 Windmill Road Sunbury Middlesex TW16 7EF U.K. Tel (44)(932) 765688 Fax (44)(932) 781936

#### In Asia (Japan):

4F Ichihashi Bldg 1-8-4 Kudankita Chiyoda-ku Tokyo 102 Japan Tel (81) (03) 3237-7891 Fax (81) (03) 3237-8010

#### **Maxim Integrated Products**

#### Recommended Products:

- MAX662 (DC-DC Converter IC)
- MAX667 (DC-DC Converter IC)
- MAX734 (DC-DC Converter IC)
- MAX756 (DC-DC Converter IC)
- MAX761 (DC-DC Converter IC)

#### In U.S.A.:

120 San Gabriel Drive Sunnyvale, CA 94086 Tel (408) 737-7600 Fax (408) 737-7194

#### In Europe (U.K.):

Maxim Integrated Products (UK), Ltd. Tel: (44) (734) 845255

#### In Asia (Japan):

Maxim Japan Co., Ltd. Tel: 81 (03) 3232-6141

#### Motorola Semiconductor Inc.

#### Recommended Product:

- MC34063AD (DC-DC Converter IC)

#### In U.S.A.:

616 West 24th Street Tempe, AZ 85282 Tel: (800) 521-6274

#### In Europe (U.K.):

Tel: (44) (296) 395-252

#### In Asia (Japan):

Tel: (81) (3) 440-3311

#### **National Semiconductor**

#### Recommended Product:

— LM2940CT-12 (Voltage Regulator IC)

#### In the U.S.:

2900 Semiconductor Drive P.O. Box 58090 Santa Clara, CA 95052 Tel: (408) 721-5000

#### In Europe:

National Semiconductor (UK) Ltd. The Maple, Kembrey Park Swindon, Wiltshire SN26UT U.K.

Tel: (07-93) 614141 Fax: (07-93) 697522

#### In Asia:

National Semiconductor Japan Ltd.
Sanseido Bldg. 5F
4-15 Nishi Shinjuku
Shinjuku-ku
Tokyo 160 Japan
Tel: (81) (3) 299-7001

Fax: (81) (3) 299-7000



#### **Newport Components/** International Power

#### Recommended Product:

NMF0512S (5V-12V Converter Module)

#### In U.S.A.:

International Power Sources 200 Butterfield Drive Ashland, MA 01721 Tel: (508) 881-7434 Fax: (508) 879-8669

#### In Europe:

**Newport Components** 4 Tanners Drive Blakelands North Milton Keynes MK14 5NA Tel: (0908) 615232

Fax: (0908) 617545

#### Shindengen Electric Co. Ltd.

#### Recommended Product:

- HDF0512D (12V unreg. to 12V reg. converter

#### In the U.S.:

2649 Townsgate Road #200 Westlake Village, CA 91361 Tel: (800) 634-3654

Fax: (805) 373-3710

#### In Europe:

Shindengen Magnaquest U.K. Ltd. Unit 13, River Road, Barking Business Park, 33 River Road, Barking, Essex 1G11 ODA Tel: (44) (81) 591-8703

Fax: (44) (81) 591-8792

#### In Asia:

2-1.2-Chome Ohtemachi Chiyoda-ku Tokvo 100 Japan Tel: (81) (3) 279-4431 Fax: (81) (3) 279-6478

#### Valor Electronics, Inc.

#### Recommended Product:

- PM6064

#### In U.S.A.:

9715 Business Park Avenue San Diego, CA 92131-1642 Tel: (619) 537-2500 Fax: (619) 537-2525

#### In Europe:

Valor Electronics GmbH Steinstraße 68 81667 Munchen Germany Tel: (49) (89) 480-2823

Fax: (49) (89) 484-743

#### In Asia:

Valor Electronics, Ltd. Room 510, 5th Floor 1 Kornhill Road, Kornhill Metro Tower Quarry Bay, Hong Kong Tel: (852) 513-8210 Fax: (852) 513-8214

#### Xentek Inc.

#### Recommended Product:

- NPSC0512S (5V-12V Converter Module)

#### In U.S.A.:

760 Shadowridge Drive Vista, CA 92083 Tel: (619) 727-0940 Fax: (619) 727-8926



In Europe (Germany): Xentek, Inc. c/o Taiyo Yuden GMBH. Obermaierstrasse 10, D-8500 Nurnberg 10 Federal Republic of Germany Tel: (49) (911) 350-8400 Fax: (49) (911) 350-8460

In Asia (Japan):

Xentek, Inc, c/o Taiyo Yuden., Ltd. 6-16-20, Ueno, Taito-ku Tokyo 110 Japan

Tel: (81) (3) 3837-6547 Fax: (81) (3) 3835-4752

2



#### APPENDIX D CONTACTS FOR DISCRETE COMPONENTS

#### Matsuo Electric Co., Ltd.

Matsuo's 267 series surface mount tantalum chip capacitors are recommended by Maxim and Linear Technology for input and output filter capacitors on their DC-DC converters. Part #s are included on the parts list that accompanies most solutions. If alternate "equivalents" are required, choose high reliability, low ESR (Equivalent Series Resistance) and low ESL (Equivalent Series Inductance) type tantalums, which help in keeping output ripple and switching noise to a minimum.

In U.S.A.:

2134 Main St., Ste. 200 Huntington Beach, CA 92648

Tel: (714) 969-2491 Fax: (714) 960-6492

In Europe:

Steucon - Center II Mergenthalleralle 77 D-6236 Eschben/Ts.

Federal Republic of Germany

Tel: 6196-470-361 Fax: 6196-470-360

In Asia:

Oak Esaka Bldg. 10-28 Hiroshiba-Cho Suita-shi

Osaka 564

Tel: (06) 337-6450 Fax: (06) 337-6456

#### Sumida Electric Co. Ltd.

Sumida CD series surface mount inductors are recommended by Maxim, Linear Technology for their miniature size and relatively low cost. These are well suited to low power DC-DC converter applications. Contact Sumida Electric directly for procuring these. The part #s are included in the parts list that accompanies most solutions. In applications where noise (EMI) is a concern, shielded varieties are also offered by Sumida.

In U.S.A.: 637 East Golf Road Suite 209

Arlington Heights, IL 60005 Tel: (708) 956-0666

Fax: (708) 956-0702

In Asia:

4-8 Kanamachi 2-chome, Katsushika-ku, Tokyo 125

Japan

Tel: (81) (03) 3607-5111

Fax: (81) (03) 3607-5428

#### Coiltronix Inc.

Coiltronix is recommended as a good alternate source for surface mount inductors. The CTX series offered by Coiltronix is well suited to DC-DC converter applications. These are shielded, and have a toroidal core. However, they are bigger in size and currently much more expensive (7X to 8X) than the Sumida varieties recommended in the solutions herein. The equivalent part numbers are:

Sumida CD54-470 → Coiltronix CTX50-1

Sumida CD54-180 → Coiltronix CTX20-1

Sumida CD54-220 → Coiltronix CTX20-1

Sumida CD75-470 → Coiltronix CTX50-2

Sumida CDR105-470 → Coiltronix CTX50-2

In U.S.A.:

Coiltronix Inc.

984 S.W. 13th Court

Pompano Beach, FL 33069

Tel: (305) 781-8900

Fax: (305) 782-4163

In U.K.:

Microelectronics Technology Ltd. Great Haseley Trading Estate

Great Haseley

Oxfordshire OX9 7PF

U.K.

Tel: (08) 44 278781

Fax: (08) 44 278746



In Asia:

Serial System Mktg. Poh Leng Bldg., #02-01 21 Moonstone Lane Singapore 1232

Tel: 2938830 Fax: 2912673

#### Coilcraft

Coilcraft is also recommended as a good alternate source for surface mount inductors. The N2724-A shielded series is well suited to DC-DC converter applications. These are bigger and currently more expensive (2x to 3x) than the Sumida inductors recommended in the solutions. Contact Coilcraft directly for any applications assistance or for procurement of these parts. The equivalent part numbers are:

Sumida CD54-470  $\rightarrow$  Coilcraft N2724-A 47  $\mu$ H Sumida CD54-180  $\rightarrow$  Coilcraft N2724-A 18  $\mu$ H Sumida CDR105-470  $\rightarrow$  Coilcraft N2724-A 47  $\mu$ H

#### In the US:

1102 Silver Lake Road Cary , IL 60013 Tel: (708) 639-6400 Fax: (708) 639-1469

#### In Europe:

21 Napier Place Wardpark North Cumbernauld Scotland G68 0LL Tel: 0236 730595 Fax: 0236 730627

#### In Asia:

Block 101, Boon Keng Road #06-13/20 Kallang Basin Industrial Estate Singapore 1233 Tel: 2966933

Fax: 2964463

#### **Philips Components**

Philips Components is recommended as a good source for surface mount (SMD) resistors (standard 9C series, and 9B (MELF) series). Part #s are included in the parts list that accompanies most of the solutions in the application note. Many alternate sources exist.

In the US:

2001 W. Blue Heron Blvd. P.O. Box 10330 Riviera Beach, FL 33404 Tel: (407) 881-3200 Fax: (407) 881-3304

In Europe:

Philips Components Ltd. Mullard House Torrington Place London WC1E 7HD Tel: (44) 71 580 6633 Fax: (44) 71 636 0394

In Asia.

Philips K.K.
Philips Bldg. 13-37
Kohnan 2-chome
Minato-Ku Tokyo 108
Tel: (81) 3 740-5028
Fax: (81) 3 740-5035

#### Siliconix-Logic Level PFETs

Siliconix offers low-"on" resistance logic level PFETs (Si9400, and Si9405) that can be used for switching a DC-DC converter into a shutdown state by using these switches on the high side of the input to the converter (see Appendix E).

In the US:

2201 Laurelwood Road P.O. Box 54951 Santa Clara, CA 95056-9951 Tel: (408) 988-8000 Fax: (408) 727-5414

#### In Europe:

Weir House Overbridge Square, Hambridge Lane Newbury, Berks RG14 5UX Tel: (0635) 30905 Fax: (0635) 34805

In Asia:

Room 709, Chinachem Golden Plaza 77 Mody Road TST East Kowloon Tel: (852) 724-3377 Fax: (852) 311-7909



# APPENDIX E OTHER DESIGN CONSIDERATIONS

#### **VPP Valid Handshake Logic**

It is often desirable to have, along with the VPP solution, a handshake signal (using extra hardware) that is asserted as long as the voltage level on VPP is valid. The following schematic illustrates a good way of achieving this. This handshake signal could be used to determine when it is suitable to perform writes/erases on the flash device. The circuit shown uses a precision zener voltage reference and a comparator, along with bias resistors, to monitor the voltage level on V<sub>PP</sub>. The point at which the comparator trips must be set after careful consideration of the variation in the reference voltage and the tolerances on the bias resistors. The worst case conditions on these variations must guarantee that the handshake signal is asserted when VPP is at its worst case lower-end level (11.4V). Care must be taken to use the exact same components as specified in order to maintain the tight tolerance on the trip level of the output signal.

## **Obtaining Shutdown Using Logic Level PFETs**

Low "on" resistance logic level PFETs can be used on the high side of the input to the DC-DC converters to obtain shutdown. One such part is the Si9405 from Siliconix Inc. The device is part of the "little foot" series, and is available in an SO8 (8-pin surface mount) package. The Si9405 is a logic level PFET with an "on resistance" of  $0.2\Omega$  (at a gate drive of 4.5V). It is important to have as low an "on" resistance as possible, since the peak currents and start-up currents into the supply are high. Care must be taken to ensure that the DC-DC conversion process is not affected after accounting for the drop in input voltage across the PFET.

# Working of the Discrete Step Up Switching Regulator

This section presents a brief overview of the operation of discrete step up switching regulators, and presents issues that the user needs to be concerned with while designing these solutions into the system.

The four most basic elements of a discrete switching regulator power supply are:

- The SMPS IC (which includes the switch control element and logic, along with the power switch itself).
- 2. An inductor for storage and transfer of energy between the input and output,
- A switching diode to direct the inductor energy to "catch", or channel, the inductor energy to the output, and
- 4. An output filter capacitor.



Figure E-1. V<sub>PP</sub> Valid Handshake Circuit



In the boost configuration where the output voltage is greater than the input voltage, the basic switching power supply configuration is as shown in Figure E.2:



Figure E-2. Working of the Step-Up Switching Regulator

The power switch SW can be turned on and off; the control for it is derived from a feedback mechanism that senses the output voltage. While the switch is turned on, the inductor stores energy as the current flows through it from the input supply. The peak current through the inductor IL can be approximated as (V<sub>IN</sub>/L \* t<sub>ON</sub>); where t<sub>ON</sub> is the on time of the switch. During this time, the energy is supplied by the input voltage,  $V_L = V_{IN}$ . The output is isolated from the inductor via the reverse-biased diode, and the load current is supplied by the output filter capacitor. When the switch turns off, the energy stored in the inductor appears as a rapidly increasing voltage across the inductor. As soon as this voltage reaches a value equal to the output voltage plus the voltage drop across the diode, the diode switches on and current starts to flow through the diode. This diode current supplies the load current while also at the same time charging up the output filter capacitor to the output voltage.

The switch is controlled by sensing the output voltage via a feedback mechanism—usually a pair of resistors. This sense voltage is gated via a comparator whose output acts as a control signal to an oscillator. The oscillator output controls the switch.

The power into the inductor  $P_L$  can be approximated as:

$$P_L = 0.5 * L * I_{PK}^2 * f_{OSC}$$

and the power into the load  $P_{LOAD}$  (out of the inductor) can be approximated as

$$P_{LOAD} = (V_{OUT} + V_D - V_{IN}) * I_{OUT}$$

The peak currents through the inductor is usually several times higher than the load current, is mostly of the value of the load current and builds up during time ton. On most of the solutions presented here, peak operating currents lie in the range of 500 mA to 1.2A. Though this may seem high, most of this in-rush of energy is transferred to the output, and little is lost to heat due to the efficient energy storage characteristic of inductors. Note that since the peak currents are high, the input voltage source must be capable of providing this current, and the current capability of the input source must not be calculated simply as  $(V_{OUT} * I_{OUT})/(V_{IN} * Eff)$ . A large bypass capacitor at the input pin of the converter is hence also necessary on all designs.

Some of the solutions presented in this application note are of the fixed duty cycle or fixed on time type (e.g. LT1109-12, MC34063A), whereas some of them vary the duty cycle depending on the load current (e.g. MAX734). These latter ones provide higher efficiencies.

#### **Inductor Selection**

The choice of an inductor is crucial to the design of the power supply system. To begin with, the inductor value must be low enough to supply the peak currents needed when the input voltage V<sub>IN</sub>, as well as the on time t<sub>on</sub>, are at their worst case low value. On the other hand, the inductor value must be high enough so that the peak currents at the worst case high values do not exceed the maximum peak currents that can be handled by the switch. Furthermore, once the value has been picked, the physical inductor that is chosen for the job must be able to handle these peak currents, and must not saturate. This is done by picking an inductor whose DC current rating is more than the worst case peak current that will be required by the operation of the device. The other characteristic to consider is the resistance of the inductor. In order to keep losses to a minimum, it is essential that the resistance of the coil is a minimum. Thus, it is important to use the inductors specified in the parts list that accompanies the solutions. These have been carefully chosen after reviewing the requirements. Alternate inductors may be used, as long as they are "equivalent".

#### EMI Concerns

Since the switching regulators presented in this application note switch at frequencies between 100 KHz and 500 KHz, there exists a potential for EMI. In cases where EMI may be a problem, shielded inductors can be used. This will reduce EMI significantly. Shielded versions of the inductors specified are readily available. Contact the vendor directly for these.



#### **Output Switching Noise**

Output switching noise has several sources. The most significant one is the IR drop through the ESR (Equivalent Series Resistance) of the output filter capacitor. This is caused by switching current pulses from the inductor. There is also noise in the form of switching spikes riding on the DC output. This is due to the output filter capacitor's ESL (Equivalent Series Inductance), current spikes in the ground trace and rectifier turn-on transients.

It is important to use low ESR and low ESL output and input filter capacitors. Proper layout is also essential in order to avoid spikes in the output. The safest solution is to use a filter circuit at the output. LC filters are not recommended, because of the transient nature of the load currents on flash devices. An RC filter is recommended on most solutions as an option. Two  $1\Omega$  resistors are used in parallel to avoid causing a significant drop across the resistance. This method is inexpensive and assures that the spikes riding on the output waveform are contained to within the 5% tolerance requirement on Vpp.

In addition, care must be taken to keep the leads from the output of the solution to all flash devices as short as possible. Use of a 0.1  $\mu$ F capacitor at the  $V_{PP}$  pin of each flash device is highly recommended.

## Working of the Discrete Charge-Pump DC-DC Converter

This section provides a brief overview of the operation of discrete charge-pump DC-DC converters.

The three most basic elements of a discrete chargepump DC-DC converter are:

- The charge-pump IC (which includes the internal charge-pumps as well as output regulation logic),
- External capacitors to store energy from the input, and
- 3. An output filter capacitor.

The basic charge-pump power supply configuration is as shown in Figure E.3 (a).

The S1 and S2 switches can be opened and closed; the control is derived from a feedback mechanism that senses the output voltage. When the S1 switches are open, the S2 switches are closed, and vice versa. When the S1 switches are closed (Figure E.3 (b)), capacitors C1 and C2 are charged to  $V_{\rm IN}$ . When the S2 switches are closed (Figure E.3 (c)), capacitors C1 and C2 are connected in series between  $V_{\rm IN}$  and  $V_{\rm OUT}$ . This triples the input voltage, with the feedback scheme in the charge-pump IC adjusting the output voltage to 12V. During one cycle, energy is transferred from the input to the external charge-pump capacitors (S1 switches closed), and then from the charge-pump capacitors to the output filter capacitor and the load (S2 switches closed).

The S1 and S2 switches are controlled by sensing the output voltage via a feedback mechanism. This sense voltage is gated via a comparator whose output acts as a control signal to an oscillator. The oscillator output controls the S2 switches, and the inverted oscillator output controls the S1 switches.





Figure E-3. Working of the Charge-Pump DC-DC Converter



# APPENDIX F PC LAYOUTS FOR SOME RECOMMENDED SOLUTIONS

#### **Maxim Integrated Products MAX662**

The double-sided layout presented below (Figure F-1) has been designed for the MAX662 5V-12V converter solution (Section 3.3). It has been designed for the parts specified in the parts list that accompanies the solution. Contact Maxim for any additional layout assistance.

#### **Maxim Integrated Products MAX734**

The double-sided layout presented below (Figure F-2) has been designed for MAX734 5V-12V converter solution (Section 3.1). It has been designed for the parts specified in the parts list that accompanies the solution. Contact Maxim for any additional layout assistance.

#### **Maxim Integrated Products MAX761**

The double-sided layout presented below (Figure F-3) has been designed for the MAX761 3.3V/5V-12V converter solution (Sections 3.2 and 4.1). It has been designed for the parts specified in the parts list that accompanies the solution. Contact Maxim for any additional layout assistance.

### Linear Technology Corporation LT1109-12

The single-sided layout presented below (Figure F-4) can be used to implement the LT1109-12 5V-12V converter solution (Section 3.4). The layout has been designed for the parts that are specified in the parts list that accompanies the solution. Contact Linear Technology for any additional layout assistance.



Figure F-1





Figure F-2





Figure F-3





Figure F-3





Figure F-3



Figure F-4



### **Revision History**

| Version | Description                                                                           |
|---------|---------------------------------------------------------------------------------------|
| 001     | Original Version                                                                      |
| 002     | Added MAX734, MAX761, MAX662, MAX756, LT1301, PM6064. Deleted MAX732, LT1110, MAX658. |



# APPLICATION NOTE

# Flash Memory Write Protection Techniques

BRIAN DIPERT
SENIOR TECHNICAL MARKETING ENGINEER

September 1993

#### 2

# Flash Memory Write Protection Techniques

| CONTENTS                                            | PAGE | CONTENTS                                                  | PAGE  |
|-----------------------------------------------------|------|-----------------------------------------------------------|-------|
| 1.0 INTRODUCTION                                    | 2-66 | 5.0 PREVENTING UNINTENDED WRITES DURING NORMAL SYS        | TEM . |
| 2.0 WHY IS WRITE PROTECTIO                          |      | OPERATION                                                 |       |
| 3.0 SYSTEM WRITES WITH BUL                          |      | 6.0 PREVENTING UNINTENDED WRITES DURING SYSTEM            |       |
| ERASE FLASH MEMORIES                                | 2-66 | POWERUP/POWERDOWN AND RESET                               | 2-68  |
| 4.0 SYSTEM WRITES WITH<br>BOOTBLOCK AND FlashFileTI |      | 6.1 Designing for Flash Memory<br>System Power Sequencing |       |
| MEMORIES                                            | 2-07 | Protection                                                | 2-69  |
|                                                     |      | 7 O CLIMMADV                                              | 2.70  |



#### 1.0 INTRODUCTION

Flash memory's combination of nonvolatility and easy in-system updateability are key attributes driving its adoption into today's system designs. However, this flexibility also brings with it the responsibility (for hardware and software engineers) to ensure that writes to flash memory occur only when intended. This is especially important for those who are accustomed to designing with various ROM (nonvolatile but non-updateable) and RAM (updateable but volatile) memories.

This application note discusses techniques for proactively designing systems to prevent unintentional writes to flash memory. These design techniques are by no means complex or costly, but their implementation is crucial to ensuring reliable operation through system lifetime. For more information on the devices and specifications discussed in this document, please consult specific flash memory datasheets.

### 2.0 WHY IS WRITE PROTECTION IMPORTANT?

Let's begin by identifying the key characteristics of two generic memory technologies: ROM (Read-Only-Memory) and RAM (Random-Access-Memory). Flash memory combines many of the capabilities of both in one solution. Therefore, it is often being utilized to replace ROM and/or RAM in new designs. At a minimum, flash memory's status as a relatively new technology means that many engineers are moving to it from the familiarity of a ROM/RAM knowledge base.

RAM is fully alterable on a bit-by-bit basis, and the mechanism for writing to it is established and well understood. RAM is in-system updateable, yet it is volatile. This means that when a RAM memory loses power, it also loses its data. RAM is guaranteed *not* to contain valid information on powerup.

ROM offers the advantage of nonvolatility, i.e. when power is removed from the device, the information stored inside is retained. However, ROM is not in-system updateable. Once the information is initially put into the device, it is permanent and unchangeable. To replace the information, you have to physically remove/replace the device itself.

Traditional system memory architectures often included both ROM (nonvolatile but non-updateable) and RAM (volatile but in-system updateable). The new model for system design retains some RAM for temporary data storage, but replaces the rest of RAM and ROM with flash memory. Being both nonvolatile and in-system updateable, flash memory encompasses the

strengths of both RAM and ROM, offering new system architecture possibilities. However, whereas in the past RAM was guaranteed to be invalid on system powerup and ROM was guaranteed to be unalterable, the same cannot be said for flash memory.

Any alteration of flash memory contents (whether planned or unintended) is permanent regardless of system power transitions, until the data is again modified. As we'll see later, command writes to flash memory can also put it in modes where it outputs something other than array data, a non-permanent but still undesirable condition when not intended. This means that the system hardware and software must ensure that flash memory is written only when specifically desired, to ensure a predictable system environment. The following sections will discuss how this can be accomplished.

#### 3.0 SYSTEM WRITES WITH BULK-ERASE FLASH MEMORIES

First-generation bulk erase flash memories from Intel Corporation are shown in Figure 1. These devices automatically power up in a "Read Array" mode in which they output array data when read. Transitions to alternate modes occur by writing commands to the flash memory.

| Device  | Density         |
|---------|-----------------|
| 28F256A | 32 Kbytes (x8)  |
| 28F512  | 64 Kbytes (x8)  |
| 28F010  | 128 Kbytes (x8) |
| 28F020  | 256 Kbytes (x8) |

Figure 1. Intel Corporation Bulk-Erase Flash Memories

Bulk-erase flash memories include several forms of "protection" to guard against unintended writes. Writes with Vpp (the program/erase voltage) at VppL (0V to 6.5V) are disregarded by the flash memory. Similarly, write attempts with V<sub>CC</sub> at or below V<sub>LKO</sub> (2.5V on most devices) are ignored. Finally, these devices require multi-byte command sequences to initiate internal program or erase algorithms. Note, however, that while the erase command sequence (shown in Figure 2) requires both the proper Erase Setup and Erase Confirm commands, the program sequence (Figure 3) relies only on the valid Program Setup command. The second command in the latter sequence can have any value, and is interpreted as data to be programmed. This means that if the flash memory receives an unintended Program Setup command, the very next write to the device (intended or not) will be interpreted as program data and initiate an internal program event (if Vpp is above VppL).





Figure 2. Flash Memory Erase Command Sequence (Simplified)

Beyond the program and erase sequences, the Read Intelligent Identifier Codes command will, when written to the flash memory, put it in a mode where it outputs device signature IDs instead of array information when read.



Figure 3. Flash Memory Programming Command Sequence (Simplified)

# 4.0 SYSTEM WRITES WITH BOOT BLOCK AND FlashFile™ MEMORIES

Second-generation block-erase Boot Block and Flash-File memories from Intel Corporation are shown in Figure 4. They function similarly to the bulk-erase devices described earlier, with a few key enhancements. As before, these devices automatically power up in "Read Array" mode, and transition to alternate modes via command writes.

| BOOT BLOCK ARCHITECTURE |                         |  |  |  |  |  |  |
|-------------------------|-------------------------|--|--|--|--|--|--|
| Device                  | Density                 |  |  |  |  |  |  |
| 28F001BX                | 128 Kbytes (x8)         |  |  |  |  |  |  |
| 28F200BX                | 256 Kbytes (x16)        |  |  |  |  |  |  |
| 28F002BX                | 256 Kbytes (x8)         |  |  |  |  |  |  |
| 28F400BX                | 512 Kbytes (x16)        |  |  |  |  |  |  |
| 28F004BX                | 512 Kbytes (x8)         |  |  |  |  |  |  |
| FlashFile™              | FlashFile™ ARCHITECTURE |  |  |  |  |  |  |
| Device                  | Density                 |  |  |  |  |  |  |
| 28F008SA                | 1 Mbyte (x8)            |  |  |  |  |  |  |

Figure 4. Intel Corporation Block-Erase Flash Memories

For full access to the flash memory Status Register, as well as for enhanced interface to internal device identifiers, these block-erase flash memories will accept commands written to them regardless of Vpp voltage, as long as  $V_{CC}$  is above  $V_{LKO}$ . Program and erase algorithms initiated by command sequences will terminate with Status Register error indication and unaltered array data, if Vpp is at Vppl. However, regardless of Vpp level, the device will still transition to a "Read Status Register" mode after program/erase command sequences are written. In this case, it will output data that the system, if the write was unintended, will not expect. The same multi-byte command sequences (shown in Figures 2 and 3) are used as in bulk-erase flash memories.

Boot Block and FlashFile memories provide commands (in addition to the program and erase sequences) which transition the memory to alternate modes, outputting data other than array information for subsequent reads. In this respect, they are similar to bulk-erase flash memory discussed earlier. These commands are Intelligent Identifier and Read Status Register.

Block-erase devices include a hardware input called RP# (or Reset/Powerdown). Among its many uses, this pin acts as a "master on/off switch" to completely disable the flash memory and lock all other control inputs. RP# is extremely effective at blocking unintended writes during system power transitions. This technique will be covered in detail, in a few paragraphs.

# 5.0 PREVENTING UNINTENDED WRITES DURING NORMAL SYSTEM OPERATION

Preventing unintended writes to flash memory during normal system operation is a routine part of debugging a new design, and a common concern for any "writeable" device on the processor interface. Any combina-



tion of active chip select (CE#) and active write enable (WE#) has the potential of being decoded by the flash memory as a valid write attempt. One common culprit in these situations is the chip select decoder logic (PAL, etc.) between the processor and external devices. As addresses propogate through this logic at the beginning of an access cycle, or in the undefined address state between accesses, spurious chip selects of indeterminate duration can be generated. System hardware should ensure that at these times, WE# to flash memory stays at a logic "1" and doesn't transition low.

Some concern has also been expressed in the past about unintended writes in certain "open" systems such as the personal computer. In these environments, the type and function of software run on the machine is beyond the control of the computer manufacturer, who must accordingly design his/her hardware. For example, a third-party software utility may write to flash memory assuming DRAM at that location. More malicious, of course, is the case of the computer virus. Fortunately, in cases like this, hardware design to prevent unintended writes is fairly simple.



Figure 5. WE# Gating

Figure 5 shows one means of clarifying the WE# signal. When flash memory is used for BIOS storage, for example, the manufacturer's update utility is the only software that should be writing to the device. By toggling the general purpose I/O line (whose default state is, of course, "disabled"), the update utility can control whether writes from the system are blocked or allowed to pass to the flash memory. This type of WE# clarifying function is integrated in the Intel386TMSL and Intel486TMSL Microprocessor Supersets. ASICs integrating motherboard functions should also be designed to include such logic.

One other method for preventing flash memory alteration is by controlling (or "switching") the V<sub>PP</sub> voltage, turning it on to V<sub>PPH</sub> only when desired for system update. Many 12V converters and power supplies integrate this on/off function as shown in Figure 6, or it can be provided by an external FET. This approach will be used again in the next section on write protection during system power transitions. Note, however, that although it prevents actual flash memory data alteration, V<sub>PP</sub> control is insufficient to keep block-erase flash memories from transitioning to alternate data output modes by unintended writes.



Figure 6. Vpp 12V Converter with Integrated Switch (Example)

In a traditional "closed" system, the software directing the hardware is totally under control of the system manufacturer. No additional effort should be needed (after the initial prototype hardware and software debugging) to protect the flash memory from unintended writes during normal system operation. Write control during system powerup and powerdown also requires attention, however; a topic covered next.

# 6.0 PREVENTING UNINTENDED WRITES DURING SYSTEM RESET AND POWERUP/POWERDOWN

System powerup and/or powerdown offer the greatest potential for unintended writes in flash memory-based system designs. As mentioned earlier, similar potential also exists for other "nonvolatile/rewriteable" memory technologies, such as EEPROM and battery-backed SRAM. Several reasons for this are listed below.

- When a system begins to power up, all logic outputs are at 0V. This is also the "enable" condition for flash memory CE# and WE# inputs.
- Logic devices have specified, documented and guaranteed operation only at a specific supply voltage range (typically 5V ±10% or 3.3V ±0.3V). Operation beyond this voltage range is not guaranteed and may not be consistent. Specifically, device output behaviour is typically undefined.
- Similarly, logic operation is sometimes undefined and erratic when devices are being reset. For example, MCS-186 embedded processors, when reset, tristate their WR# (write enable) outputs, which will then typically drift toward 0V (or "enabled", to TTL inputs).





Figure 7. Basic Processor/Flash Memory Interface

• If both the V<sub>CC</sub> and V<sub>PP</sub> power supplies are switched "on" at the same time, one or the other is likely to ramp to a "valid" level first, depending on the relative capacitive loading at the supply outputs. Similarly, one supply will often ramp below its valid voltage range before the other, on system poweroff. This situation is acceptable, as long as the WE# and/or CE# signals to the flash memory are controlled.

Figure 7 shows a very basic example processor/memory interface. When the system power is switched on, the processor (or logic) WE# output and logic CE# output are both at GND. Depending on the processor and logic, these outputs may not reliably stabilize until VCC ramps to 4.5V. In most cases, CPU and logic outputs will smoothly follow the supply voltage up to operating levels. Any oscillations on these outputs, however, can be decoded as a valid write by the flash memory, which begins to "wake up" below 4.5V V<sub>CC</sub>. Similarly, address and data processor outputs are typically undefined below operating voltage ranges. Given a x8 interface between processor and flash memory (therefore, with 256 possible combinations of data inputs), there is a finite chance that a valid command byte will be randomly generated and written to the flash memory.

If the V<sub>PP</sub> power supply output is less capacitively loaded than V<sub>CC</sub>, V<sub>PP</sub> can ramp above V<sub>PPL</sub> before V<sub>CC</sub> reaches 4.5V. This can cause unintended flash memory program and erase if the correct command data values are "spuriously" written to the device.

Again referencing Figure 7, the behaviour of processor/logic CE#, WE# and address/data outputs are typically undefined once  $V_{CC}$  drops below 4.5V. If the power supply  $V_{PP}$  output is more capacitively loaded than  $V_{CC}$ ,  $V_{PP}$  can remain above  $V_{PPL}$  as  $V_{CC}$  decays toward 0V. This has the potential to initiate program/erase operations in response to unintended flash memory writes.

#### 6.1 Designing for Flash Memory System Power Sequencing Protection

Intel has taken several steps with respect to its flash memory designs to significantly minimize the possibility of an unwanted write during system powerup or powerdown. By synergizing system designs to these flash memory features, you can easily eliminate the potential for unwanted flash memory mode switching and/or data alteration.

Flash memories from Intel are guaranteed *not* to program or erase with V<sub>PP</sub> below 6.5V. First generation bulk-erase devices additionally block *all* write attempts with V<sub>PP</sub> below 6.5V. The implication here is clear; if possible, don't switch on V<sub>PP</sub> until after the system V<sub>CC</sub> is stable (on powerup), and switch off V<sub>PP</sub> before the system is powered down. The V<sub>PP</sub> supply itself can be switched on/off, or an inline FET switch can be installed between the power supply output and flash memory input and controlled via an I/O line from the processor or discrete logic. Figure 6 gives an example of circuitry for the former case.





Figure 8. Supply Voltage/Device Output Relationship During Powerup

Intel flash memory also provides  $V_{CC}$ -driven "lockout protection" from unwanted writes. With  $V_{CC}$  below  $V_{LKO}$ , all write attempts to the flash memory are ignored.  $V_{LKO}$  varies between 2.5V and 2.0V depending on the specific flash memory, and its value is targeted to take advantage of the fact that in most cases device outputs closely follow  $V_{CC}$  inputs (both up and down). Referencing Figure 8, when  $V_{CC}$  exceeds  $V_{LKO}$ , device outputs will in most cases also be at approximately  $V_{LKO}$ , and consequently at a TTL "1" level (or disabled). The flash memory "protects itself" up to  $V_{LKO}$ , and the system designer must above that point ensure that flash memory control inputs are stable. Similarly, the flash memory is again protected once  $V_{CC}$  drops below  $V_{LKO}$  on system powerdown.

The RP# input (formerly known as PWD#), available on Intel Boot Block and FlashFile memories, acts as a "master on/off switch" for the device. With RP# at V<sub>IL</sub>, the flash memory is put in a very low power mode called Deep Powerdown, and is essentially turned "off". In this state, all write attempts to the flash memory are disregarded. RP# can be driven by the POWERGOOD output of the system power supply (if this output exists) or from an external analog "power supply monitoring" device like the Maxim MAX705 or Motorola MC34064, providing absolute flash memory protection. Figure 9 gives an example system design

using the Maxim component. Voltage monitoring circuits like those mentioned above have adjustable trip points and tight tolerances, and can be set to the lower value of the system logic normal operating voltage.



Figure 9. Reset Control during System Powerup and Powerdown

#### 7.0 SUMMARY

Unintended writes to flash memory can, at a minimum, cause it to output data that the system does not expect, forcing system reset or power sequencing to restore normal operation. Depending on the specific data written to the device, and the Vpp voltage at the time of the write, actual "permanent" alteration of flash memory contents can result from unintended program or erase. However, Intel flash memory, in combination with proper system interfacing techniques, easily eliminates the potential for either of these scenarios.

Closely analyze the powerup/down and reset behaviour of the system CPU and any interface logic that interacts with the flash memory. In the vast majority of cases, no problems will be found. If potential for unwanted writes does exist, however, nonvolatile/rewriteable memory protection can easily be included if incorporated early in the design, by following the hints described in this application note.



# APPLICATION BRIEF

# Flash Memory Applications in Laser Printers

**BRIAN DIPERT**MCD MARKETING APPLICATIONS

August 1993

# Flash Memory Applications in Laser Printers

| <b>CONTENTS</b> PAGE                   | <b>CONTENTS</b> PAGE        |
|----------------------------------------|-----------------------------|
| <b>1.0 INTRODUCTION</b> 2-73           | <b>3.0 SUMMARY</b> 2-77     |
| 2.0 MEMORY USAGE IN LASER PRINTERS2-74 | ADDITIONAL INFORMATION 2-77 |
| 2.1 System Code Memory 2-74            |                             |
| 2.2 Font Storage 2-76                  |                             |
| 2.3 Image Storage and Manipulation2-77 |                             |



Recently, several laser printer and printer peripheral companies have introduced products that incorporate flash memory. Their advertisements validate the unique capabilities and benefits that flash memory features provide. OEM interest, and predictions by market analysts like BIS Strategic Decisions, point to increasing future flash memory usage as laser printer manufacturers continue to differentiate their product lines to meet user needs. This application brief discusses the uses and benefits of flash memory in laser printer designs. Specifically, flash memory usage for system code storage, and for font and "font-like" data storage, will be highlighted.

#### 1.0 INTRODUCTION

Within the computer industry, the laser printer market is one of the most rapidly growing business sectors. The graph of Figure 1 shows growth rate of various market segments since 1988, as well as predicted growth through 1996. Laser printer proliferations are expanding to capture the needs of more and more user groups. Simultaneously, more and more computer users are turning to laser printers versus traditional "impact printer" alternatives, as features proliferate, capabilities expand, offices become more automated, and unit prices fall. This combination grows the total number of laser printer market segments, as well as the size of each segment.

When a large and steadily increasing supply of potential laser printer users exists, the "invisible hands" of economics unequivocally dictate that a large number of suppliers will appear to service this demand. What does this all mean to you, the laser printer manufacturer/designer? In a word, competition! How can any one company expand (or at a minimum maintain) their market share over the efforts of all others?



Figure 1. Laser Printer U.S. Market Growth 1988-1996 (BIS Strategic Decisions, 1992)



One way to do this is by providing equivalent product features as all other suppliers, at a lower unit price. This is referred to as **pricing-driven demand**. Unfortunately, as in the example of the "clone" market in today's PC industry, pricing-driven demand does not often translate to long-term financial health for your company.

The other method of establishing a leadership image (and the preferable means) is by stimulating differentiation-based demand through key product features that uniquely answer market needs. The advantages to this approach are many:

- Product differentiation makes good business market share sense. Uniquely meeting customer needs through product features establishes a short-term leadership image and the potential for a long-term protectable market position.
- Value-based pricing also makes good business profitability sense. If product features are chosen carefully, the resultant customer demand allows the supplier to price comfortably above per-unit cost, guaranteeing profitability and long term business health!

Flash memory is a key technology whose capabilities trendsetting OEMs are exploiting to differentiate their current and future laser printer designs. It enables clear benefits in system expandability, flexibility, performance and ease-of-use; benefits that translate directly to customer satisfaction and long-term loyalty. Flash memory combines the attributes of nonvolatility (like ROM or EPROM) and in-system updateability (like RAM or a hard disk drive), while simultaneously providing high density and compatible read performance to DRAM. This unique combination of features allows flash memory to not only replace more "traditional" laser printer memory approaches, but also to enhance systems beyond the limitations of these "conservative" memory solutions. The remainder of this application brief will review the major memory subsystems in today's laser printer designs, and how flash memory capabilities can be applied in each case.

### 2.0 MEMORY USAGE IN LASER PRINTERS

A high-level laser printer block diagram is shown in Figure 2. Memory uses in laser printers can be grouped in the following three areas:

- System and PDL (printer description language) emulation code storage
- Font (and font-like data type) storage
- Temporary bitmap image storage and manipulation

Memory is used differently in each case: therefore optimum memory features are similarly specialized, even within a common memory technology. Semiconductor vendors, for example, have optimized various types of DRAMs for the applications in which they'll be used. Similarly, Intel has optimized unique product "families" within its flash memory line to match the requirements of applications like those found in laser printers. These product "families" will be referred to in the discussions below.

#### 2.1 System Code Memory

The system code memory stores the software that is executed by the embedded processor to run and control the laser printer. This includes code to interface the processor with the input/output, coprocessor, print drum and motor subsystems. System code memory also includes a large amount of software devoted to emulating various printer description languages. The most commonly known PDLs are PostScript\* (pioneered by Adobe and currently at version 2.0) and PCL\* (Printer Control Language, pioneered by Hewlett Packard and currently at version 5). Beyond these two "industry standards", dozens of additional proprietary "languages" have been developed by various hardware and software vendors.

Depending on the complexity and capabilities of the laser printer and the number of supported emulations, system code size varies. It ranges from as little as 256 Kbytes for an entry-level personal printer to several Mbytes for powerful high-end network laser printers. The traditional memory technology used to store system code is high density ROM (for nonvolatility) shadowed to DRAM on system powerup (for fast read access time).

Flash memory, when used for system code storage, combines the nonvolatility and high density of ROM with the fast read performance of DRAM, making the ROM/DRAM redundancy unnecessary. Additionally, the in-system upgradeability of flash memory makes laser printers flexible and updateable both in the manufacturing line at your factory, and once the system is in the hands of the end customer. Although the per-device cost of flash memory is higher than that of ROM, flash memory's upgradeability can result in a lower system cost through a laser printer's operating lifetime.

Flash memory eliminates costly inventory of ROMs, ROMs that must be scrapped if an enhanced software version is released or a software "bug" is discovered. Using flash memory, one hardware design can service multiple markets via simple "end-of-line" programming as the system leaves the factory. Additionally, diagnostic code can be programmed on the assembly line for full system debug, and replaced with the final software version later in the manufacturing flow.





Today, upgradeability once a system reaches the customer's hands is achieved via proprietary, costly add-in ROM cards. These emulation modules connect to the host system through low-performance interface buses. Updating the local code memory in the printer requires a technician visit, is very costly to the customer, and is therefore rarely done. The result can be a less-than-optimized system with subpar performance, and a dissatisfied customer that will not consider your company for his/her next printer purchase!

Flash memory's in-system reprogramming makes system code upgrade as simple as running an "UPDATE" utility on the host computer, and can be done by the customer at his/her PC using a diskette sent by the printer manufacturer, or a file downloaded from a OEM computer bulletin board service. Configuring the printer with the exact emulations needed is equally straightforward. Customer service is perhaps the supreme differentiator in multiple-source markets. As companies focus more and more on the customer and the service aspects of their business, they will turn to flash memory as a means of readily and economically achieving their goals.

Intel's Boot Block flash memory product line has been specifically defined to meet the specific requirements of high-density embedded code storage and execution. These devices are also available in ROM-compatible pinouts. This allows printer OEMs to achieve quick time-to-market with rev. 0 software (updateable once initial systems are in customer hands) and later convert their designs to ROM if desired, once final production code is stable. For further information on these products, reference the Additional Information section at the conclusion of this application brief.

#### 2.2 Font Storage

Today's laser printers ship from the factory with a number of "resident" fonts stored in nonvolatile ROM. The density of this memory varies with the end market for the printer. A "Roman" set of resident typefaces requires anywhere from 1 Mbyte-2 Mbytes of storage. Japanese "Kanjii" fonts, on the other hand, require upwards of 5 Mbytes per typeface. A minimum-configured laser printer for the Japanese market therefore needs 10 Mbytes-20 Mbytes of resident font memory. Additional permanent font storage is often available through ROM font cartridges, similar to the "emulation" fonts mentioned earlier. Finally, software such as Adobe Type Manager\* and Microsoft\* TrueType\* downloads font information to the printer, storing it in volatile DRAM. This latter temporary font data is lost when the printer is turned off or reset. Resets can occur, for example, each time the printer output jams, or when the paper supply is depleted.

Computer users are more and more outgrowing the capabilities of the resident ROM fonts stored in their laser printers, or available through the ROM expansion font cartridges. ATM and TrueType are enabling these users to customize their documents by varying not only font size and attributes, but also the font typefaces themselves. Many corporations have developed custom fonts for use by their employees for a consistent documentation "look and feel". These unique typefaces are not a part of the resident standard typeface set. Finally, not only fonts, but also graphic bitmaps (corporate logos, bitmapped signatures, etc.) and page lavout templates are being integrated into desktop-published documents. All of this non-resident information must be repeatedly downloaded from the host computer to the printer DRAM after each printer poweroff or reset. Since this download is accomplished via the serial or parallel connection, print performance is dramatically and negatively impacted, especially noticeable in a networked printer arrangement.

Flash memory, with its unique set of attributes, combines the best qualities of today's font and template storage solutions while incorporating none of their weaknesses. Like DRAM, it is in-system updateable and has comparable per-device cost at higher densities. Like ROM, it is nonvolatile. Like both of these technologies, it is a very dense storage medium, available in sizes up to 1 Mbyte per component, and 20 Mbytes per card, at the time this application note was written. Where extremely high density memory is needed, as in the case of Kanjii font storage, flash memory components have an over 200,000x first read access advantage and an over 14x data transfer performance advantage over hard disk drives. The performance of a printer computing subsystem is significantly hindered by the slow access time of a HDD. Flash memory, with its sub-100 ns read speed, is the superior solution.

A resident high-density array of flash memory is coupled directly to the CPU local bus for highest performance. It allows the customer to exactly configure the printer font, bitmap graphic and page template information for his/her specific applications. This data is downloaded to the printer once, and from that point on is always available for use, even after the printer is turned off or reset. If expanded printer usage (as in a network environment) requires additional resident "font" storage in the future, easy density upgrade is enabled by designing in a PCMCIA memory-I/O card socket, again interfacing directly to the embedded processor bus. Plugging in a flash memory card means no printer disassembly is required!

**Order Number** 



Intel's FlashFile<sup>TM</sup> flash memory component and Series 2 flash memory card lines combine the high density and high performance required for resident "font" storage. For further information on these products, reference the Additional Information section at the conclusion of this application brief.

#### 2.3 Image Storage and Manipulation

The temporary graphic memory subsystern stores the image to be printed as it is "constructed" by the processor from data provided by the host computer. Optimum characteristics of this memory include full "real-time" bit-level alteration, infinite rewrite capability and fast read/write performance. Nonvolatility is not required in this area of the memory subsystem. Therefore, DRAM will continue to be the memory of choice for temporary image storage.

#### 3.0 SUMMARY

This application brief has discussed the various memory subsystems in today's laser printers, and their operating characteristics. Flash memory is an exciting new approach that offers the very real potential to significantly improve your next-generation laser printer designs. Its capabilities are superior to traditional solutions in the system code and font memory areas, and enable laser printers that are more expandable, more flexible, higher performance and easier to use than ever before. The end result is a satisfied customer, a customer that will choose your product over a competitor's, and a customer that will remain loyal to your company far into the future.

#### ADDITIONAL INFORMATION

**Boot Block Components** 

For additional information on the Intel flash memory products mentioned in this article, please reference the following documents, available through your local Intel sales representative.

| 290406       |
|--------------|
| 290448       |
| 290451       |
| 294010       |
| 294013       |
| Order Number |
| 290429       |
| 292094       |
| 292095       |
| 292099       |
| 294011       |
| Order Number |
| 290434       |
| 292096       |
| Order Number |
| 292092       |
| 294005       |
| 294012       |
|              |

<sup>\*</sup>Microsoft and TrueType are trademarks of Microsoft Corporation. Adobe Type Manager and PostScript are trademarks of Adobe Systems Incorporated. PCL is a trademark of Hewlett Packard Corporation. ETOX and FlashFile are trademarks of Intel Corporation.



### TECHNICAL PAPER

# Small and Low-Cost Power Supply Solution for Intel's Flash Memory Products

BILAL QURESHI
MCD APPLICATIONS ENGINEER
SALIM B. FEDEL
SENIOR APPLICATIONS ENGINEER

November 1994



#### 1.0 INTRODUCTION

Intel Flash memory devices with two power supply sources, a 5V V<sub>CC</sub> and 12V V<sub>PP</sub>, offer flexibility. For example, in a flash array, one simple off-chip circuit can be used by the entire array to supply the V<sub>PP</sub> voltage to any flash chip. V<sub>CC</sub> is the primary power source, and the only power source needed to read the memory. V<sub>PP</sub> is required when writing or erasing the memory.

This technical paper describes a state-of-the-art 5V to 12V power conversion solution, which uses no inductors, fits in 0.1" sq. area and yet costs less than \$2.00, in volume quantities.

A detailed description of the solution is presented in the next section. Section 3.0 deals with the components used, their type, value, price and vendors to contact. References are provided in the Additional Information section.

#### 2.0 DETAILED DESCRIPTION

The power solution uses one MAXIM's MAX662A with four small, surface-mount capacitors to generate regulated Vpp with no need for inductors (Figure 1). MAX662A is available in a small, 8-pin narrow surface mount package. The entire design fits in 0.1" sq. area, as shown in the layouts of Figures 2 and 3.

#### **Optimal Attributes**

- · Very Low Cost
- Small Size: 0.1" sq. (67.9 mm<sup>2</sup>) Total Board Area (Single Sided)
- Low Shutdown Current
- · Fast Rise Time from Shutdown
- No Inductor Necessary
- All-Surface Mount

#### Main Features

- Input Voltage Range: 4.75V to 5.5V
- Output Voltage: 12V ± 5%
- Output Current Capability up to 30 mA at  $V_{IN} = 5V$
- Typical Efficiency: 74% at Load = 30 mA
- 500 KHz Switching Frequency
- · Shutdown Feature on Chip

#### 2.1 Maxim Integrated Products— MAX662A: Vpp at 30 mA

The MAX662A provides a regulated 12V output voltage at 30 mA from a 5V  $\pm$  5% power supply. It uses internal charge pumps and external capacitors to generate 12V, eliminating inductors. Regulation is provided by pulse-skipping scheme that monitors the output voltage level and turns on the charge pumps when the output voltage begins to droop. The solution boasts a typical efficiency of 74% with  $V_{\rm CC}=5V$  and  $I_{\rm OUT}=30~{\rm mA}.$ 

For protection from accidental erasure of flash memory, a shutdown pin is provided. In shutdown mode, the charge-pump switching action is halted and  $V_{\rm IN}$  is connected to  $V_{\rm OUT}$  through a 1k internal resistor.

### 2.2 Charge-Pump Capacitors, C1 and C2

Since the values of C1 and C2 are critical, 0.22  $\mu F$  ceramic capacitors are used. Small surface-mount capacitors C2012Y5V1E224Z from TDK are used to achieve smallest board area size.

### 2.3 Input and Output Capacitors, C4 and C5

The type of input bypass (C4) and output filter capacitor (C5) affect performance. TDK C3216Y5V1C225Z and C2012Y5V1C105Z, 2.2  $\mu$ F and 1  $\mu$ F low ESR ceramic capacitors are used. The low ESR of these units eliminates the need for decoupling between  $V_{IN}$  and  $V_{OUT}$ .

#### 2.4 Layout Considerations

To ensure stability and decrease noise, careful attention is paid to keeping the connections short. Since only one side of the board is used, this 12V solution can be placed right beneath the flash chip in a two-sided board designs, thereby saving space and reducing pin to pin track length.

To keep the inductance in the circuit to a minimum, thick track lines are employed (0.025" wide). Some critical dimensions are given below:

Total Length: 0.345" (8.763 mm)

Total Width: 0.305" (7.747 mm)

Track Width: 0.025" (0.635 mm)

Track-Track Spacing: 0.01" (0.254 mm)





Figure 1. Maxim MAX662A 5V to 12V Converter Circuit



Figure 2. 5x Scale Top Side Component Placement View



Figure 3. 5x Scale Top Side Trace View



## 3.0 PARTS LIST

Table 1. Parts List for the MAX662A 5V to 12V Converter

| Reference  | Part Number    | Value/Type                     | Source                | Cost(1) |  |  |  |
|------------|----------------|--------------------------------|-----------------------|---------|--|--|--|
| U1         | MAX662ACSA     | SMPSIC Maxim<br>(408) 737-7600 |                       | \$1.69  |  |  |  |
| C1, C2     | C2012Y5V1E224Z | 0.22 μF Ceramic                | TDK<br>(408) 437-9585 | \$0.06  |  |  |  |
| C4         | C3216Y5V1C225Z | 2.2 μF Ceramic                 | TDK<br>(408) 437-9585 | \$0.09  |  |  |  |
| C5         | C2012Y5V1C105Z | 1.0 μF Ceramic                 | TDK<br>(408) 437-9585 | \$0.07  |  |  |  |
| Total Cost |                |                                |                       |         |  |  |  |

#### NOTE:

## 4.0 SUMMARY

This technical paper summarizes low-cost 5V to 12V power solution, which uses no inductors and fits in 0.1" sq. area. The solution is based on recommendations provided by the supplier vendors, and has been verified at the Intel Corporation laboratory.

## 5.0 ADDITIONAL INFORMATION

### 5.1 References

| Order Number | Document                                                                                            |
|--------------|-----------------------------------------------------------------------------------------------------|
| 292092       | AP-357, "Power Supply Solutions for Flash Memory"                                                   |
| 292153       | AB-59, "Multi-Site Layout Planning with Intel's Flash File™ Components Including ROM Compatability" |

<sup>1.</sup> Cost estimates based on published 10K unit-pricing at the time this technical paper was written.





## Intel 28F016XS Embedded Flash RAM **Product Brief**

## Highlights

- Product Ideal for embedded applications: Datacom Office automation Telecom Computing Games
  - Supports burst-mode processors: i960<sup>®</sup> and Intel486™ CPU-based systems
  - Superior power, integration and price to DRAM + ROM or code DRAM + HDD:

Ideal for battery-powered portable applications in high-speed embedded designs

- Synchronous flash RAM
- Supports 33-MHz zero-wait state
- Very high read performance: 2X DRAM
- SmartVoltage feature supports both 5V and 12V device writes and 5V or 3.3V device reads
- Nonvolatile and updatable
- In-system updatability for faster time to market
- Requires less board space than redundant multi-chip code solutions
- First flash memory-based device with synchronous pipelined read interface



#### **Product Description**

The Intel 28F016XS embedded flash RAM is a 16Mb synchronous memory component that blends very high read performance with the nonvolatility, updatability and low power of flash memory. It provides higher integration, 3.3V capability and up to twice the performance of DRAM, without price premiums or additional board space requirements. As a result, the 28F016XS embedded flash RAM is ideal for burst-mode processors, such as the i960® and Intel486TM microprocessors, as well as for embedded applications where redundant code DRAM + ROM or code DRAM + HDD were used for code execution/storage memory

Because the Intel 28F016XS embedded flash RAM is a nonvolatile, code storage and execution solution, there is no need for refresh, redundant memory or HDD "spin-up" latency when returning from deep power-down mode. It also enables instant-on system design. Using minimal glue logic, the Intel 28F016XS embedded flash RAM can easily interface directly to burst-mode processors, supporting 33-MHz zero-wait state, 5V read performance code storage. The embedded flash RAM device is internally partitioned into 16 software-lockable, 128KB blocks.

The Intel 28F016XS embedded flash RAM is particularly well suited for such data communication needs as routers, hubs and ATM switches; for office automation components, including printers, scanners and copiers; for telecommunications central office switches, local exchange switches, premise switches and cell base stations; for such computing purposes as POS terminals, diskless workstations and mobile communications; and for games applications for arcade, set-top and highend home use.

# inta

## Intel 28F016XD Embedded Flash RAM **Product Brief**

## Highlights

- Product Innovative embedded flash RAM device:
  - DRAM-like system interface Nonvolatile, updatable and low nower
  - Better price and performance than DRAM + ROM and DRAM + HDD:
    - Offers higher integration and 3.3V capability Requires lower power and less
    - board space
  - Ideal for embedded applications: Datacom Office automation Telecom Computing Games
  - Simple DRAM-like interface: Allows use of standard **DRAM** controllers Optimizes time to market Sits directly on a cachable has
  - Ideal for portable applications
  - Easy interface to systems using embedded processors: For i960°KX, i960CS, i960JX and Intel386™EX CPU-based systems
  - Internally partitioned into 32 software-lockable, 32KB blocks
  - SmartVoltage feature: Supports both 5V and 12V device writes and 5V or 3.3V device reads
  - First flash memory device with DRAM-like interface



## **Product Description**

The Intel 28F016XD embedded flash RAM is an innovative 16Mb memory component that combines a DRAM-like system interface with the nonvolatility. updatability and lower power of flash memory. The 28F016XD embedded flash RAM is an ideal solution for embedded applications where redundant code DRAM + ROM or code DRAM + HDD were used for code execution/storage memory.

Its simple DRAM-like interface allows use of standard DRAM controllers, optimizing time to market. In addition, the Intel 28F016XD embedded flash RAM is in-system updatable, reducing the risk of early manufacturing as compared to DRAM + ROM and DRAM + OTP EPROM options. The Intel 28F016XD embedded flash RAM can easily interface to systems using such embedded processors as the i960°KX, i960X, i960JX and the Intel386TMEX CPU-based systems. Several vendors offer 28F016XD embedded flash RAM SIMM modules, making it easier to upgrade code DRAM designs to embedded flash RAM.

The Intel 28F016XD embedded flash RAM is internally partitioned into 32 software-lockable, 32-KB blocks. Like Intel's 28F016SV SmartVoltage device, the 28F016XD embedded flash RAM supports both 5V and 12V device writes as well as 5V or 3.3V device reads. Because the Intel 28F016XS embedded flash RAM is a nonvolatile, code storage and execution solution, there is no need for refresh, redundant memory or HDD "spin-up" latency when returning from deep power-down mode. It also enables instant-on system design.

The Intel 28F016XD embedded flash RAM, which is the first flash memory device with a DRAM-like interface, is particularly well suited for data communications, office automation, telecommunications, computing and games.

\*Other brands and names are the trademarks of their respective owners. Printed in USA/1094/17.5K/ASI/TC/MCD © 1994 Intel Corporation Order Number: 297547-001



## 28F016XS 16-MBIT (1-MBIT x 16, 2-MBIT x 8) SYNCHRONOUS FLASH MEMORY

- Effective 0-Wait-State Performance up to 33 MHz
- SmartVoltage Technology
  - User-Selectable 3.3V or 5V V<sub>CC</sub>
  - User-Selectable 5V or 12V Vpp
- 30.8 MB/sec Burst Write Transfer Rate
- 0.48 MB/sec Sustainable Write Transfer Rate
- Configurable x8 or x16 Operation
- 16 Separately-Erasable/Lockable 128-KByte Blocks
- 56-Lead TSOP Type I Package

- Backward Compatible with 28F016SA/SV, 28F008SA Command-Set
- **■** Revolutionary Architecture
  - Synchronous Pipelined Reads
  - Multiple Command Execution
  - Write During Erase
  - Page Buffer Write
- 2 µA Typical Deep Power-Down
- 1 mA Typical Active I<sub>CC</sub> Current in Static Mode
- 1 Million Erase Cycles per Block
- State-of-the-Art 0.6 μm ETOX™ IV Flash Technology

Intel's 28F016XS 16-Mbit Flash memory is a revolutionary architecture which is the ideal choice for designing truly revolutionary high-performance products. Combining very high read performance with the intrinsic non-volatility of flash memory, the 28F016XS eliminates the traditional redundant memory paradigm of shadowing code from a slow nonvolatile storage source to a faster execution memory, such as DRAM, for improved system performance. The innovative capabilities of the 28F016XS enable the design of direct-execute code and mass storage data/file flash memory systems.

The 28F016XS is the highest performance high density nonvolatile read/write flash memory solution available today. Its synchronous pipelined read interface, flexible V<sub>CC</sub> and V<sub>PP</sub> voltages, extended cycling, fast write and read performance, symmetrically blocked architecture, and selective block locking provide a highly flexible memory component suitable for resident flash component arrays on the system board or SIMMs. The synchronous pipelined interface and x8/x16 architecture of the 28F016XS allow easy interface with minimal glue logic to a wide range of processors/buses, providing effective 0-wait-state read performance up to 33 MHz. The 28F016XS's dual read voltage allows the same component to operate at either 3.3V or 5.0V V<sub>CC</sub>. Programing voltage at 5V V<sub>PP</sub> minimizes external circuitry in minimal-chip, space critical designs, while the 12V V<sub>PP</sub> option maximizes write/erase performance. Its high read performance combined with flexible block locking enable both storage and execution of operating systems/application software and fast access to large data tables. The 28F016XS is manufactured on Intel's 0.6  $\mu$ m ETOXTM IV process technology.



290532-21

## 28F016XS 16-MBIT (1-MBIT x 16, 2-MBIT X 8) SYNCHRONOUS FLASH MEMORY

| <b>CONTENTS</b> PAGE                                                                     | CONTENTS                                                               | PAGE            |
|------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----------------|
| <b>1.0 INTRODUCTION</b>                                                                  |                                                                        | <b>)NS</b> 3-22 |
| 1.1 Product Overview 3-5                                                                 | 5.1 Absolute Maximum Ratings                                           | 3-22            |
| <b>2.0 DEVICE PINOUT</b> 3-8                                                             | 5.2 Capacitance                                                        | 3-23            |
| 2.1 Lead Descriptions                                                                    | 5.3 Transient Input/Output Ref<br>Waveforms                            | erence<br>3-24  |
| <b>3.0 MEMORY MAPS</b>                                                                   | 5.4 DC Characteristics (V <sub>CC</sub> = ±0.3V)                       | 3.3V<br>3-25    |
| Map3-12                                                                                  | 5.5 DC Characteristics (V <sub>CC</sub> = ±0.5V)                       | 5.0V<br>3-27    |
| 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER                                         | 5.6 Timing Nomenclature                                                | 3-29            |
| <b>DEFINITIONS</b>                                                                       | 5.7 AC Characteristics—Read Operations                                 | Only<br>3-30    |
| Mode (BYTE# = V <sub>IH</sub> )                                                          | 5.8 AC Characteristics for WE # Controlled Write Operations            |                 |
| 4.2 Bus Operations for Byte-Wide Mode (BYTE# = V <sub>IL</sub> )                         | 5.9 AC Characteristics for CE <sub>X</sub> Controlled Write Operations |                 |
| 4.3 28F008SA—Compatible Mode<br>Command Bus Definitions 3-15<br>4.4 28F016XS—Performance |                                                                        | #-              |
| Enhancement Command Bus Definitions                                                      | 5.11 AC Characteristics for CE                                         | v#-             |
| 4.6 Global Status Register 3-19                                                          |                                                                        |                 |
| 4.7 Block Status Register 3-20                                                           | 5.12 Fower op and Mond (Prite Min                                      |                 |
| 4.8 Device Configuration Code 3-21                                                       | or to Erado and Word, Byto Wil                                         | າເອ<br>3-45     |
| 4.9 SFI Configuration Table 3-21                                                         |                                                                        |                 |
|                                                                                          | DEVICE NOMENCLATURE AND ORDERING INFORMATION                           | <b>3-4</b> 8    |
| (x,y) = (x,y) + (x,y) + (x,y)                                                            | ADDITIONAL INFORMATION                                                 | 3-49            |
|                                                                                          | DATASHEET REVISION HISTOR                                              | <b>RY</b> 3-49  |



#### 1.0 INTRODUCTION

The documentation of the Intel 28F016XS Flash memory device includes this datasheet, a detailed user's manual, a number of application notes and design tools, all of which are referenced at the end of this datasheet.

The datasheet is intended to give an overview of the chip feature-set and of the operating AC/DC specifications. The 16-Mbit Flash Product Family User's Manual provides complete descriptions of the user modes, system interface examples and detailed descriptions of all principles of operation. It also contains the full list of software algorithm flowcharts, and a brief section on compatibility with the Intel 28F008SA.

### 1.1 Product Overview

The 28F016XS is a high-performance, 16-Mbit (16,777,216-bit) block erasable nonvolatile random access memory organized as either 1-MWord x 16 or 2-MByte x 8, subdivided into even and odd banks. Address A<sub>1</sub> makes the bank selection. The 28F016XS includes sixteen 128-KByte (131,072 byte) blocks or sixteen 64-KWord (65,536 word) blocks. Chip memory maps for x8 and x16 modes are shown in Figures 3 and 4.

The implementation of a new architecture, with many enhanced features, will improve the device operating characteristics and result in greater product reliability and ease-of-use as compared to other flash memories. Significant features of the 28F016XS as compared to previous asynchronous flash memories include:

- Synchronous Pipelined Read Interface
- Significantly Improved Read and Write Performance
- SmartVoltage Technology
  - User-Selectable 5.0V or 12.0 V<sub>PP</sub>
- Internal 3.3V/5.0V V<sub>CC</sub> Detection Circuitry
- Block Write/Erase Protection

The 28F016XS's synchronous pipelined interface dramatically raises read performance far beyond previously attainable levels. Addresses are synchronously latched and data is read from a 28F016XS bank every 30 ns. This capability translates to 0-wait-state reads at clock rates up to 33 MHz at 5V V<sub>CC</sub>, after an initial address pipeline fill delay and assuming even and odd banks within the flash mem-

ory are alternately accessed. Data is latched and driven valid 20 ns ( $t_{\rm CHQV}$ ) after a rising CLK edge. The 28F016XS is capable of operating up to 66 MHz (5V  $t_{\rm CC}$ ), and the programmable SFI Configuration enables system design flexibility optimizing the 28F016XS to a specific system clock frequency. See Section 4.9, SFI Configuration Table, for specific SFI Configurations for given operating frequencies.

The SFI Configuration optimizes the 28F016XS for a wide range of system operating frequencies. The default SFI Configuration is 4, which allows system boot from the 28F016XS at any frequency up to 66 MHz at 5V V<sub>CC</sub>. After initiating an access, data is latched and will begin driving on the data outputs after a CLK count corresponding to the SFI Configuration has elapsed. The 28F016XS will hold data valid until CE# or OE# is deactivated or a CLK count corresponding to the SFI Configuration for a subsequent access has elapsed.

The CLK and ADV# inputs, new to the 28F016XS in comparison to previous flash memories, control address latching and device synchronization during read operations. CLK input controls the device latencies, times out the SFI Configuration and synchronizes data outputs. ADV# indicates the presence of a valid address on the 28F016XS address inputs. During read operations, addresses are latched and accesses are initiated on a rising CLK edge in conjunction with ADV# low. Both CLK and ADV# are ignored by the 28F016XS during write operations.

The 28F016XS incorporates SmartVoltage technology, providing  $V_{CC}$  operation at both 3.3V and 5.0V and program and erase capability at  $V_{PP}=12.0V$  or 5.0V. Operating at  $V_{CC}=3.3V$ , the 28F016XS consumes less than one half the power consumption at 5.0V  $V_{CC}$ , while 5.0V  $V_{CC}$  provides highest read performance capability.  $V_{PP}$  operation at 5.0V eliminates the need for a separate 12.0V converter, while the  $V_{PP}=12.0V$  option maximizes write/erase performance. In addition to the flexible program and erase voltages, the dedicated  $V_{PP}$  gives complete code protection with  $V_{PP} \leq V_{PPL\,K}$ .

Internal 3.3V or 5.0V  $V_{CC}$  detection automatically configures the device internally for optimized 3.3V or 5.0V Read/Write operation. Hence, the 28F016SA's 3/5# pin is not required and is a no-connect (NC) on the 28F016XS maintaining backwards-compatibility between components.

A Command User Interface (CUI) serves as the system interface between the microprocessor or microcontroller and the internal memory operation.

#### 28F016XS FLASH MEMORY



Internal Algorithm Automation allows Byte/Word Writes and Block Erase operations to be executed using a Two-Write command sequence to the CUI in the same way as the 28F008SA 8-Mbit FlashFile™ memory.

A super-set of commands has been added to the basic 28F008SA command-set to achieve higher write performance and provide additional capabilities. These new commands and features include:

- Page Buffer Writes to Flash
- Command Queuing Capability
- Automatic Data Writes during Erase
- Software Locking of Memory Blocks
- Two-Byte Successive Writes in 8-bit Systems
- Erase All Unlocked Blocks

Writing of memory data is performed in either byte or word increments, typically within 6 µsec at 12.0V Vpp, which is a 33% improvement over the 28F008SA. A Block Erase operation erases one of the 16 blocks in typically 1.2 sec, independent of the other blocks.

Each block can be written and erased a minimum of 100,000 cycles. Systems can achieve one million Block Erase Cycles by providing wear-leveling algorithms and graceful block retirement. These techniques have already been employed in many flash file systems and hard disk drive designs.

The 28F016XS incorporates two Page Buffers of 256 bytes (128 words) each to allow page data writes. This feature can improve a system write performance by up to 4.8 times over previous flash memory devices, which have no Page Buffers.

All operations are started by a sequence of Write commands to the device. Three Status Registers (described in detail later in this datasheet) and a RY/BY# output pin provide information on the progress of the requested operation.

While the 28F008SA requires an operation to complete before the next operation can be requested, the 28F016XS allows queuing of the next operation while the memory executes the current operation. This eliminates system overhead when writing several bytes in a row to the array or erasing several blocks at the same time. The 28F016XS can also perform Write operations to one block of memory while performing Erase of another block.

The 28F016XS provides selectable block locking to protect code or data such as direct-executable operating systems or application code. Each block has an associated nonvolatile lock-bit which determines the lock status of the block. In addition, the 28F016XS has a master Write Protect pin (WP#) which prevents any modifications to memory blocks whose lock-bits are set.

The 28F016XS contains three types of Status Registers to accomplish various functions:

- A Compatible Status Register (CSR) which is 100% compatible with the 28F008SA FlashFile memory Status Register. The CSR, when used alone, provides a straightforward upgrade capability to the 28F016XS from a 28F008SA-based design.
- A Global Status Register (GSR) which informs the system of command Queue status, Page Buffer status, and overall Write State Machine (WSM) status.
- 16 Block Status Registers (BSRs) which provide block-specific status information such as the block lock-bit status.

The GSR and BSR memory maps for Byte-Wide and Word-Wide modes are shown in Figures 5 and 6.

The 28F016XS incorporates an open drain RY/BY# output pin. This feature allows the user to OR-tie many RY/BY# pins together in a multiple memory configuration such as a Resident Flash Array. The RY/BY# output pin employs five distinct configurations, which are enabled via special CUI commands and are described in detail in the 16-Mbit Flash Product Family User's Manual.

The 28F016XS also incorporates a dual chip-enable function with two input pins,  $CE_0\#$  and  $CE_1\#$ . These pins have exactly the same functionality as the regular chip-enable pin, CE#, on the 28F008SA. For minimum chip designs,  $CE_1\#$  may be tied to ground and system logic may use  $CE_0\#$  as the chip enable input. The 28F016XS uses the logical combination of these two signals to enable or disable the entire chip. Both  $CE_0\#$  and  $CE_1\#$  must be active low to enable the device. If either one becomes inactive, the chip will be disabled. This feature, along with the open drain RY/BY# pin, allows the system designer to reduce the number of control pins used in a large array of 16-Mbit devices.



The BYTE# pin allows either x8 or x16 read/writes to the 28F016XS. BYTE# at logic low selects 8-bit mode with address  $A_0$  selecting between low byte and high byte. On the other hand, BYTE# at logic

high enables 16-bit operation with address  $A_1$  becoming the lowest order address and address  $A_0$  is not used (don't care). A device block diagram is shown in Figure 1.



Figure 1. 28F016XS Block Diagram

Architectural Evolution Includes Synchronous Pipelined Read Interface, SmartVoltage Technology,
Page Buffers, Queue Registers and Extended Status Registers



The 28F016XS incorporates an Automatic Power Saving (APS) feature, which substantially reduces the active current when the device is in static mode of operation (addresses not switching). In APS mode, the typical I<sub>CC</sub> current is 1 mA at 5.0V (3 mA at 3.3V).

A deep power-down mode of operation is invoked when the RP# (called PWD# on the 28F008SA) pin transitions low. This mode brings the device power consumption to less than 2.0  $\mu\text{A}$ , typically, and provides additional write protection by acting as a device reset pin during power transitions. A reset time of 300 ns is required from RP# switching high before latching an address into the 28F016XS. In the Deep Power-Down state, the WSM is reset (any current operation will abort) and the CSR, GSR and BSR registers are cleared.

A CMOS standby mode of operation is enabled when either  $CE_0\#$  or  $CE_1\#$  transitions high and RP# stays high with all input control pins at CMOS levels. In this mode, the device typically draws an  $I_{CC}$  standby current of 70  $\mu$ A at 5V  $V_{CC}$ .

The 28F016XS will be available in a 56-Lead, 1.2mm thick, 14mm x 20mm TSOP Type I package. The package's form factor and pinout allows for very high board layout densities.

#### 2.0 DEVICE PINOUT

The 28F016XS is pinout compatible with the 28F016SA/SV 16-Mbit FlashFile™ memory component, providing an performance upgrade path to the 28F016XS. The 28F016XS 56-Lead TSOP pinout configuration is shown in Figure 2.



Figure 2. 28F016XS 56-Lead TSOP Pinout Configuration Shows Compatibility with the 28F016SA/SV,
Allowing for Easy Performance Upgrades from Existing 16-Mbit Designs



## 2.1 Lead Descriptions

| Symbol                               | Туре            | Name and Function                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub>                       | Input           | BYTE-SELECT ADDRESS: Selects between high and low byte when device is in x8 mode. This address is latched in x8 Data Writes and ignored in x16 mode (i.e., the A <sub>0</sub> input buffer is turned off when BYTE# is high).                                                                                                                              |
| A <sub>1</sub>                       | Input           | <b>BANK-SELECT ADDRESS:</b> Selects an even or odd bank in a selected block. A 128-KByte block is subdivided into an even and odd bank. $A_1=0$ selects the even bank and $A_1=1$ selects the odd bank, in both byte-wide mode and word-wide mode device configurations.                                                                                   |
| A <sub>2</sub> -A <sub>16</sub>      | Input           | <b>WORD-SELECT ADDRESSES:</b> Select a word within one 128-KByte block. Address $A_1$ and $A_{7-16}$ select 1 of 2048 rows, and $A_{2-6}$ selects 16 of 512 columns. These addresses are latched during both data reads and writes.                                                                                                                        |
| A <sub>17</sub> -A <sub>20</sub>     | Input           | <b>BLOCK-SELECT ADDRESSES:</b> Select 1 of 16 Erase blocks. These addresses are latched during Data Writes, Erase and Lock-Block operations.                                                                                                                                                                                                               |
| DQ <sub>0</sub> -DQ <sub>7</sub>     | Input<br>Output | <b>LOW-BYTE DATA BUS:</b> Inputs data and commands during CUI write cycles. Outputs array, buffer, identifier or status data in the appropriate read mode. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                               |
| DQ <sub>8</sub> -DQ <sub>15</sub>    | Input<br>Output | <b>HIGH-BYTE DATA BUS:</b> Inputs data during x16 Data-Write operations. Outputs array, buffer or identifier data in the appropriate read mode; not used for Status Register reads. Outputs floated when the chip is de-selected, the outputs are disabled (OE# = V <sub>IH</sub> ) or BYTE# is driven active.                                             |
| CE <sub>0</sub> #, CE <sub>1</sub> # | Input           | <b>CHIP ENABLE INPUTS:</b> Activate the device's control logic, input buffers, decoders and sense amplifiers. With either $CE_0\#$ or $CE_1\#$ high, the device is de-selected and power consumption reduces to standby levels upon completion of any current Data-Write or Erase operations. Both $CE_0\#$ and $CE_1\#$ must be low to select the device. |
|                                      |                 | All timing specifications are the same for both signals. Device Selection occurs with the latter falling edge of $CE_0\#$ or $CE_1\#$ . The first rising edge of $CE_0\#$ or $CE_1\#$ disables the device.                                                                                                                                                 |
| RP#                                  | Input           | <b>RESET/POWER-DOWN:</b> RP# low places the device in a Deep Power-Down state. All circuits that consume static power, even those circuits enabled in standby mode, are turned off. When returning from Deep Power-Down, a recovery time of tpHCH is required to allow these circuits to power-up.                                                         |
|                                      |                 | When RP# goes low, any current or pending WSM operation(s) are terminated, and the device is reset. All Status Registers return to ready, clearing all status flags. Exit from Deep Power-Down places the device in read array mode.                                                                                                                       |
| OE#                                  | Input           | <b>OUTPUT ENABLE:</b> Drives device data through the output buffers when low. The outputs float to tri-state off when OE# is high. CE <sub>x</sub> # overrides OE#, and OE# overrides WE#.                                                                                                                                                                 |
| WE#                                  | Input           | WRITE ENABLE: Controls access to the CUI, Page Buffers, Data Queue Registers and Address Queue Latches. WE# is active low, and latches both address and data (command or array) on its rising edge. Page Buffer addresses are latched on the falling edge of WE#.                                                                                          |



## 2.1 Lead Descriptions (Continued)

| Symbol          | Туре                    | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLK             | Input                   | <b>CLOCK:</b> Provides the fundamental timing and internal operating frequency. CLK latches input addresses in conjunction with ADV #, times out the desired output SFI Configuration as a function of the CLK period, and synchronizes device outputs. CLK can be slowed or stopped with no loss of data or synchronization. CLK is ignored during write operations.                                                                                                          |
| ADV#            | Input                   | <b>ADDRESS VALID:</b> Indicates that a valid address is present on the address inputs. ADV# low at the rising edge of CLK latches the address on the address inputs into the flash memory and initiates a read access to the even or odd bank depending on the state of address $A_1$ . ADV# is ignored during write operations.                                                                                                                                               |
| RY/BY#          | Open<br>Drain<br>Output | <b>READY/BUSY:</b> Indicates status of the internal WSM. When low, it indicates that the WSM is busy performing an operation. RY/BY # high indicates that the WSM is ready for new operations (or WSM has completed all pending operations), or Erase is Suspended, or the device is in deep power-down mode. This output is always active (i.e., not floated to tri-state off when $OE\#$ or $CE_0\#$ , $CE_1\#$ are high), except if a RY/BY# Pin Disable command is issued. |
| WP#             | Input                   | WRITE PROTECT: Erase blocks can be locked by writing a nonvolatile lock-bit for each block. When WP# is low, those locked blocks as reflected by the Block-Lock Status bits (BSR.6), are protected from inadvertent Data Writes or Erases. When WP# is high, all blocks can be written or erased regardless of the state of the lock-bits. The WP# input buffer is disabled when RP# transitions low (deep power-down mode).                                                   |
| BYTE#           | Input                   | BYTE ENABLE: BYTE# low places device in x8 mode. All data is then input or output on $DQ_{0-7}$ , and $DQ_{8-15}$ float. Address $A_0$ selects between the high and low byte. BYTE# high places the device in x16 mode, and turns off the $A_0$ input buffer. Address $A_1$ then becomes the lowest order address.                                                                                                                                                             |
| V <sub>PP</sub> | Supply                  | WRITE/ERASE POWER SUPPLY (12.0V $\pm$ 0.6V, 5.0V $\pm$ 0.5V): For erasing memory array blocks or writing words/bytes/pages into the flash array. $V_{PP}=5.0V\pm0.5V$ eliminates the need for a 12V converter, while the 12.0V $\pm$ 0.6V option maximizes Write/Erase Performance.                                                                                                                                                                                            |
|                 |                         | Write and Erase attempts are inhibited with $V_{PP}$ at or below 1.5V. Write and Erase attempts with $V_{PP}$ between 1.5V and 4.5V, between 5.5V and 11.4V, and above 12.6V produce spurious results and should not be attempted.                                                                                                                                                                                                                                             |
| V <sub>CC</sub> | Supply                  | <b>DEVICE POWER SUPPLY (3.3V</b> $\pm$ <b>0.3V</b> , <b>5.0V</b> $\pm$ <b>0.5V):</b> Internal detection configures the device for 3.3V or 5.0V operation. To switch 3.3V to 5.0V (or vice versa), first ramp V <sub>CC</sub> down to GND, and then power to the new V <sub>CC</sub> voltage. Do not leave any power pins floating.                                                                                                                                             |
| GND             | Supply                  | GROUND FOR ALL INTERNAL CIRCUITRY: Do not leave any ground pins floating.                                                                                                                                                                                                                                                                                                                                                                                                      |
| NC              |                         | NO CONNECT: No internal connection to die, lead may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                |



### 3.0 MEMORY MAPS



Figure 3. 28F016XS Memory Map (Byte-Wide Mode)



Figure 4. 28F016XS Memory Map (Word-Wide Mode)



## 3.1 Extended Status Register Memory Map



Figure 5. Extended Status Register Memory Map (Byte-Wide Mode)



Figure 6. Extended Status Register Memory Map (Word-Wide Mode)



## 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS

## 4.1 Bus Operations for Word-Wide Mode (BYTE $\# = V_{IH}$ )

| Mode                                | Notes   | RP#               | CE <sub>0-1</sub> # | OE#             | WE#             | ADV#            | CLK | A <sub>1</sub>  | DQ <sub>0-15</sub> | RY/BY#          |
|-------------------------------------|---------|-------------------|---------------------|-----------------|-----------------|-----------------|-----|-----------------|--------------------|-----------------|
| Latch Read<br>Address               | 1,9,10  | V <sub>IH</sub>   | V <sub>IL</sub>     | Х               | V <sub>IH</sub> | V <sub>IL</sub> | 1   | Х               | X                  | X               |
| Inhibit<br>Latching<br>Read Address | 1,9     | V <sub>IH</sub>   | V <sub>IL</sub>     | Х               | V <sub>IH</sub> | V <sub>IH</sub> | 1   | Х               | Х                  | X               |
| Read                                | 1,2,7,9 | V <sub>IH</sub>   | V <sub>IL</sub>     | V <sub>IL</sub> | V <sub>IH</sub> | Х               | 1   | Х               | D <sub>OUT</sub>   | Х               |
| Output<br>Disable                   | 1,6,7,9 | V <sub>IH</sub>   | V <sub>IL</sub>     | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х   | Х               | High Z             | X               |
| Standby                             | 1,6,7,9 | V <sub>IH</sub>   | V <sub>IL</sub>     | Х               | Х               | Х               | Х   | Х               | High Z             | Х               |
| Deep<br>Power-Down                  | 1,3     | V <sub>IL</sub>   | ·X                  | Х               | Х               | Х               | Х   | Х               | High Z             | V <sub>OH</sub> |
| Manufacturer<br>ID                  | 1,4,9   | V <sub>IH</sub>   | V <sub>IL</sub>     | V <sub>IL</sub> | V <sub>IH</sub> | Х               | 1   | V <sub>IL</sub> | 0089H              | V <sub>OH</sub> |
| Device ID                           | 1,4,8,9 | V <sub>IH</sub>   | V <sub>IL</sub>     | V <sub>IL</sub> | V <sub>IH</sub> | Х               | 1   | V <sub>IH</sub> | 66A8H              | V <sub>OH</sub> |
| Write                               | 1,5,6,9 | V <sub>IH</sub> 、 | V <sub>IL</sub>     | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х   | Х               | D <sub>IN</sub>    | Х               |

- X can be V<sub>IH</sub> or V<sub>IL</sub> for address or control pins except for RY/BY#, which is either V<sub>OL</sub> or V<sub>OH</sub>, or High Z or D<sub>OUT</sub> for data pins depending on whether or not OE# is active.
- RY/BY# output is open drain. When the WSM is ready, Erase is suspended or the device is in deep power-down mode.
   RY/BY# will be at V<sub>OH</sub> if it is tied to V<sub>CC</sub> through a resistor. RY/BY# at V<sub>OH</sub> is independent of OE# while a WSM operation is in progress.
- 3. RP# at GND  $\pm 0.2$ V ensures the lowest deep power-down current.
- 4. A<sub>0</sub> and A<sub>1</sub> at V<sub>IL</sub> provide device manufacturer codes in x8 and x16 modes respectively. A<sub>0</sub> and A<sub>1</sub> at V<sub>IH</sub> provide device ID codes in x8 and x16 modes respectively. All other addresses are set to zero.
- Commands for Erase, Data Write, or Lock-Block operations can only be completed successfully when V<sub>PP</sub> = V<sub>PPH2</sub>.
- While the WSM is running, RY/BY# in level-mode (default) stays at V<sub>OL</sub> until all operations are complete. RY/BY# goes
  to V<sub>OH</sub> when the WSM is not busy or in erase suspend mode.
- RY/BY# may be at V<sub>OL</sub> while the WSM is busy performing various operations. For example, a Status Register read during a Write operation.
- 8. The 28F016XS shares an identical device identifier with other Intel Flash memories. Reading this identifier in conjunction with the unique Device Proliferation Code (read from the Page Buffer after writing the Upload Device Configuration command), the 28F016XS can be identified by system software.
- 9. CE<sub>0-1</sub># at V<sub>IL</sub> is defined as both CE<sub>0</sub># and CE<sub>1</sub># low, and CE<sub>0-1</sub># at V<sub>IH</sub> is defined as either CE<sub>0</sub># or CE<sub>1</sub># high.
- 10. Addresses are latched on the rising edge of CLK in conjunction with ADV# low. Address A<sub>1</sub> = 0 selects the even bank and A<sub>1</sub> = 1 selects the odd bank, in both byte-wide mode and word-wide mode device configurations.



## 4.2 Bus Operations for Byte-Wide Mode (BYTE# = $V_{IL}$ )

| Mode                                | Notes   | RP#             | CE <sub>0-1</sub> # | OE#             | WE#             | ADV#            | CLK | A <sub>0</sub>  | DQ <sub>0-7</sub> | RY/BY#            |
|-------------------------------------|---------|-----------------|---------------------|-----------------|-----------------|-----------------|-----|-----------------|-------------------|-------------------|
| Latch Read<br>Address               | 1,9,10  | V <sub>IH</sub> | V <sub>IL</sub>     | Х               | V <sub>IH</sub> | V <sub>IL</sub> | 1   | Х               | ×                 | X                 |
| Inhibit<br>Latching<br>Read Address | 1,9     | V <sub>IH</sub> | V <sub>IL</sub>     | х               | V <sub>IH</sub> | V <sub>IH</sub> | 1   | Х               | х                 | Х                 |
| Read                                | 1,2,7,9 | V <sub>IH</sub> | VIL                 | V <sub>IL</sub> | V <sub>IH</sub> | Х               | 1   | Х               | D <sub>OUT</sub>  | Х                 |
| Output<br>Disable                   | 1,6,7,9 | V <sub>IH</sub> | V <sub>IL</sub>     | V <sub>IH</sub> | V <sub>IH</sub> | Х               | X   | Х               | High Z            | X                 |
| Standby                             | 1,6,7,9 | V <sub>IH</sub> | V <sub>IH</sub>     | Х               | ×               | Х               | Х   | Χ               | High Z            | X                 |
| Deep<br>Power-Down                  | 1,3     | V <sub>IL</sub> | х                   | X               | X               | Х               | Х   | Х               | High Z            | V <sub>OH</sub>   |
| Manufacturer<br>ID                  | 1,4,9   | V <sub>IH</sub> | VIL                 | V <sub>IL</sub> | V <sub>IH</sub> | Х               | 1   | V <sub>IL</sub> | 89H               | V <sub>OH</sub>   |
| Device ID                           | 1,4,8,9 | V <sub>IH</sub> | V <sub>IL</sub>     | V <sub>IL</sub> | V <sub>IH</sub> | х               | 1   | V <sub>IH</sub> | A8H               | . V <sub>OH</sub> |
| Write                               | 1,5,6,9 | V <sub>IH</sub> | V <sub>IL</sub>     | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х   | Х               | D <sub>IN</sub>   | X                 |

- X can be V<sub>IH</sub> or V<sub>IL</sub>for address or control pins except for RY/BY#, which is either V<sub>OL</sub> or V<sub>OH</sub>, or High Z or D<sub>OUT</sub> for data pins depending on whether or not OE# is active.
- RY/BY# output is open drain. When the WSM is ready, Erase is suspended or the device is in deep power-down mode.
   RY/BY# will be at V<sub>OH</sub> if it is tied to V<sub>CC</sub> through a resistor. RY/BY# at V<sub>OH</sub> is independent of OE# while a WSM operation is in progress.
- 3. RP# at GND  $\pm 0.2$ V ensures the lowest deep power-down current.
- 4. A<sub>0</sub> and A<sub>1</sub> at V<sub>IL</sub> provide device manufacturer codes in x8 and x16 modes respectively. A<sub>0</sub> and A<sub>1</sub> at V<sub>IH</sub> provide device ID codes in x8 and x16 modes respectively. All other addresses are set to zero.
- Commands for Erase, Data Write, or Lock-Block operations can only be completed successfully when V<sub>PP</sub> = V<sub>PPH2</sub>.
- While the WSM is running, RY/BY# in level-mode (default) stays at V<sub>OL</sub> until all operations are complete. RY/BY# goes
  to V<sub>OH</sub> when the WSM is not busy or in erase suspend mode.
- RY/BY# may be at V<sub>OL</sub> while the WSM is busy performing various operations. For example, a Status Register read during a Write operation.
- 8. The 28F016XS shares an identical device identifier with other Intel Flash memories. Reading this identifier in conjunction with the unique Device Proliferation Code (read from the Page Buffer after writing the Upload Device Configuration command), the 28F016XS can be identified by system software.
- 9. CE<sub>0-1</sub># at V<sub>IL</sub> is defined as both CE<sub>0</sub># and CE<sub>1</sub># low, and CE<sub>0-1</sub># at V<sub>IH</sub> is defined as either CE<sub>0</sub># or CE<sub>1</sub># high.
- 10. Addresses are latched on the rising edge of CLK in conjunction with ADV# low. Address A<sub>1</sub> = 0 selects the even bank and A<sub>1</sub> = 1 selects the odd bank, in both byte-wide mode and word-wide mode device configurations.



## 4.3 28F008SA—Compatible Mode Command Bus Definitions

| Command                         | Notes  | Fir   | st Bus Cy | cle  | Sec   | Second Bus Cycle |      |  |
|---------------------------------|--------|-------|-----------|------|-------|------------------|------|--|
| - Communa                       | 110103 | Oper  | Addr      | Data | Oper  | Addr             | Data |  |
| Read Array                      |        | Write | X         | FFH  | Read  | AA               | AD   |  |
| Intelligent Identifier          | 1      | Write | Х         | 90H  | Read  | IA               | ID   |  |
| Read Compatible Status Register | 2      | Write | Х         | 70H  | Read  | Х                | CSRD |  |
| Clear Status Register           | 3      | Write | Х         | 50H  |       |                  |      |  |
| Word/Byte Write                 |        | Write | Х         | 40H  | Write | WA               | WD   |  |
| Alternate Word/Byte Write       |        | Write | Х         | 10H  | Write | WA               | WD   |  |
| Block Erase/Confirm             |        | Write | Х         | 20H  | Write | ВА               | D0H  |  |
| Erase Suspend/Resume            |        | Write | Х         | вон  | Write | X                | D0H  |  |

#### **ADDRESS**

AA = Array Address BA = Block Address IA = Identifier Address

WA = Write Address X = Don't Care

#### **DATA**

AD = Array Data CSRD = CSR Data ID = Identifier Data

WD = Write Data

- 1. Following the Intelligent Identifier command, two Read operations access the manufacturer and device signature codes.
- 2. The CSR is automatically available after device enters Data Write, Erase, or Suspend operations.
- Clears CSR.3, CSR.4 and CSR.5. Also clears GSR.5 and all BSR.5, BSR.4 and BSR.2 bits. See Status Register definitions.



## 4.4 28F016XS—Performance Enhancement Command Bus Definitions

| Command                              | Mode | Notes    | First | Bus C | ycle | Sec   | ond Bu         | s Cycle      | Thi   | rd Bus | Cycle   |
|--------------------------------------|------|----------|-------|-------|------|-------|----------------|--------------|-------|--------|---------|
| Oommana                              | Wode | Notes    | Oper  | Addr  | Data | Oper  | Addr           | Data         | Oper  | Addr   | Data    |
| Read Extended<br>Status Register     |      | 1        | Write | X     | 71H  | Read  | RA             | GSRD<br>BSRD |       |        |         |
| Page Buffer Swap                     |      | 7        | Write | Х     | 72H  |       |                |              |       |        |         |
| Read Page Buffer                     |      | 11       | Write | Х     | 75H  | Read  | PA             | PD           |       |        |         |
| Single Load to<br>Page Buffer        |      |          | Write | Х     | .74H | Write | PA             | PD           |       |        |         |
| Sequential Load to Page Buffer       | x8   | 4,6,10   | Write | X     | E0H  | Write | , <b>X</b>     | BCL          | Write | X      | BCH     |
| ,                                    | x16  | 4,5,6,10 | Write | Х     | E0H  | Write | Х              | WCL          | Write | Х      | WCH     |
| Page Buffer<br>Write to Flash        | x8   | 3,4,9,10 | Write | X     | 0CH  | Write | A <sub>0</sub> | BC(L,H)      | Write | WA     | BC(H,L) |
| 1                                    | x16  | 4,5,10   | Write | ·X    | 0CH  | Write | Х              | WCL          | Write | WA     | WCH     |
| Two-Byte Write                       | х8   | 3        | Write | Х     | FBH  | Write | A <sub>0</sub> | WD(L,H)      | Write | WA     | WD(H,L) |
| Lock Block/Confirm                   |      |          | Write | X     | 77H  | Write | ВА             | D0H          |       |        |         |
| Upload Status<br>Bits/Confirm        |      | 2        | Write | X     | 97H  | Write | X              | D0H          |       |        |         |
| Upload Device<br>Information/Confirm |      | 12       | Write | х     | 99H  | Write | Х              | D0H          |       |        |         |
| Erase All Unlocked<br>Blocks/Confirm |      |          | Write | Х     | A7H  | Write | Х              | D0H          |       |        |         |
| Device<br>Configuration              |      | 8        | Write | X     | 96H  | Write | Х              | DCCD         | -     |        |         |
| Sleep                                |      |          | Write | Х     | F0H  |       |                |              |       |        |         |
| Abort                                |      |          | Write | Х     | 80H  |       |                |              |       |        |         |

### **ADDRESS**

DATA

BA = Block Address
PA = Page Buffer Address

RA = Extended Register Address

WA = Write Address

X = Don't Care

AD = Array Data

PD = Page Buffer Data

BSRD = BSR Data

GSRD = GSR Data

WC (L,H) = Word Count (Low, High)

BC(L,H) = Byte Count(Low, High)

WD(L,H) = Write Data(Low, High)

DCCD = Device Configuration Code Data



#### NOTES:

- 1. RA can be the GSR address or any BSR address. See Figures 5 and 6 for Extended Status Register memory maps.
- 2. Upon device power-up, all BSR lock-bits come up locked. The Upload Status Bits command must be written to reflect the actual lock-bit status.
- 3. A<sub>0</sub> is automatically complemented to load second byte of data. BYTE# must be at V<sub>IL</sub>. A<sub>0</sub> value determines which WD/BC is supplied first: A<sub>0</sub> = 0 looks at the WDL/BCL, A<sub>0</sub> = 1 looks at the WDH/BCH.
- 4. BCH/WCH must be at 00H for this product because of the 256-byte (128-word) Page Buffer size, and to avoid writing the Page Buffer contents to more than one 256-byte segment within an array block. They are simply shown for future Page Buffer expandability.
- 5. In x16 mode, only the lower byte DQ<sub>0-7</sub> is used for WCL and WCH. The upper byte DQ<sub>8-15</sub> is a don't care.
- 6. PA and PD (whose count is given in cycles 2 and 3) are supplied starting in the fourth cycle, which is not shown.
- 7. This command allows the user to swap between available Page Buffers (0 or 1).
- 8. This command reconfigures RY/BY# output and SFI Configuration.
- Write address, WA, is the Destination address in the flash array which must match the Source address in the Page Buffer. Refer to the 16-Mbit Flash Product Family User's Manual.
- 10. BCL = 00H corresponds to a byte count of 1. Similarly, WCL = 00H corresponds to a word count of 1.
- 11. Page buffer reads are valid at any frequency up to the corresponding SFI Configuration setting of 2. Page buffer reads above this frequency may produce invalid results and should not be attempted. See Section 4.9 for SFI Configuration frequency settings.
- 12. After writing the Upload Device Information command and the Confirm command, the following information is output at Page Buffer addresses specified below:

 Address
 Information

 06H, 07H (Byte Mode)
 Device Revision Number

 03H (Word Mode)
 Device Revision Number

 1EH (Byte Mode)
 Device Configuration Code

 0FH (DQ0\_7)(Word Mode)
 Device Configuration Code

 1FH (Byte Mode)
 Device Proliferation Code (03H)

 0FH (DQ8\_15)(Word Mode)
 Device Proliferation Code (03H)

A page buffer swap followed by a page buffer read sequence is necessary to access this information. The contents of all other Page Buffer locations, after the Upload Device Information command is written, are reserved for future implementation by Intel Corporation. See Section 4.8 for a description of the Device Configuration Code. This code also corresponds to data written to the 28F016XS after writing the Device Configuration command.



## 4.5 Compatible Status Register

| WSMS | ESS | ES | DWS | VPPS | R | R | R |
|------|-----|----|-----|------|---|---|---|
| 7    | 6   | 5  | 4   | 3    | 2 | 1 | 0 |

#### NOTES:

CSR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busv

RY/BY# output or WSMS bit must be checked to determine completion of an operation (Erase, Erase Suspend, or Data Write) before the appropriate Status bit (ESS, ES or DWS) is checked for success.

CSR.6 = ERASE-SUSPEND STATUS

1 = Erase Suspended

0 = Erase In Progress/Completed

CSR.5 = ERASE STATUS

1 = Error In Block Erasure

0 = Successful Block Erase

CSR.4 = DATA-WRITE STATUS

1 = Error in Data Write

0 = Data Write Successful

CSR.3 = Vpp STATUS

1 = V<sub>PP</sub> Error Detect, Operation

Abort

 $0 = V_{PP} OK$ 

If DWS and ES are set to "1" during an erase attempt, an improper command sequence was entered. Clear the CSR and attempt the operation again.

The VPPS bit, unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub>level. The WSM interrogates V<sub>PP</sub>'s level only after the Data Write or Erase command sequences have been entered, and informs the system if V<sub>PP</sub> has not been switched on. VPPS is not guaranteed to report accurate feedback between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min), and above V<sub>PPH2</sub>(max).

CSR.2-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the CSR.



## 4.6 Global Status Register

| WSMS | oss | DOS | DSS | QS | PBAS | PBS | PBSS |
|------|-----|-----|-----|----|------|-----|------|
| 7    | 6   | 5   | 4   | 3  | 2    | 1   | 0 .  |

#### NOTES:

GSR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

[1] RY/BY# output or WSMS bit must be checked to determine completion of an operation (Block Lock, Suspend, any RY/BY# reconfiguration, Upload Status Bits, Erase or Data Write) before the appropriate Status bit (OSS or DOS) is checked for success.

GSR.6 = OPERATION SUSPEND STATUS

1 = Operation Suspended

0 = Operation in Progress/Completed

GSR.5 = DEVICE OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

GSR.4 = DEVICE SLEEP STATUS

1 = Device in Sleep

0 = Device Not in Sleep

MATRIX 5/4

0 0 = Operation Successful or

Currently Running

0 1 = Device in Sleep mode or Pending Sleep

10 = Operation Unsuccessful

1 1 = Operation Unsuccessful or

Aborted

If operation currently running, then GSR.7 = 0.

If device pending sleep, then GSR.7 = 0.

Operation aborted: Unsuccessful due to Abort

command.

GSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

GSR.2 = PAGE BUFFER AVAILABLE STATUS The device contains two Page Buffers.

1 = One or Two Page Buffers

Available

0 = No Page Buffer Available

GSR.1 = PAGE BUFFER STATUS

1 = Selected Page Buffer Ready

0 = Selected Page Buffer Busy

GSR.0 = PAGE BUFFER SELECT STATUS

1 = Page Buffer 1 Selected

0 = Page Buffer 0 Selected

Selected Page Buffer is currently busy with WSM operation

When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



## 4.7 Block Status Register

| BS | BLS | BOS | BOAS | QS | VPPS | VPPL | ·R |
|----|-----|-----|------|----|------|------|----|
| 7  | 6   | 5   | 4    | 3  | 2    | 1    | 0  |

NOTES:

BSR.7 = BLOCK STATUS

1 = Ready

0 = Busy

[1] RY/BY# output or BS bit must be checked to determine completion of an operation (Block Lock, Suspend, Erase or Data Write) before the appropriate Status bits (BOS, BLS) is checked for success.

Operation halted via Abort command.

BSR.6 = BLOCK LOCK STATUS

1 = Block Unlocked for Write/Erase

0 = Block Locked for Write/Erase

BSR.5 = BLOCK OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

BSR.4 = BLOCK OPERATION ABORT STATUS The BOAS bit will not be set until BSR.7 = 1.

1 = Operation Aborted

0 = Operation Not Aborted

MATRIX 5/4

0 0 = Operation Successful or Currently Running

0 1 = Not a Valid Combination

10 = Operation Unsuccessful

1 1 = Operation Aborted

BSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

BSR.2 = Vpp STATUS

1 = V<sub>PP</sub> Error Detect, Operation Abort

 $0 = V_{PP} OK$ 

BSR.1 = V<sub>PP</sub> LEVEL

 $1 = V_{PP}$  Detected at 5.0V  $\pm 10\%$ 

 $0 = V_{PP}$  Detected at 12.0V  $\pm 5\%$ 

BSR.1 is not guaranteed to report accurate feedback between the V<sub>PPH1</sub> and V<sub>PPH2</sub> voltage ranges. Writes and erases with V<sub>PP</sub> between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub> (min), between V<sub>PPH2</sub>(min), and above V<sub>PPH2</sub>(max) produce spurious results and should not be attempted.

BSR.0 = RESERVED FOR FUTURE ENHANCEMENTS

This bits is reserved for future use; mask it out when polling the BSRs.

#### NOTE:

 When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



## 4.8 Device Configuration Code

| R | R | SFI2 | SFI1 | SFI0 | RB2 | RB1 | RB0 |
|---|---|------|------|------|-----|-----|-----|
| 7 | 6 | 5    | 4    | 3    | 2   | 1   | 0   |

DCC.5-DCC.3 = SFI CONFIGURATION (SFI2-SFI0)

001 = SFI Configuration 1 010 = SFI Configuration 2

011 = SFI Configuration 3

100 = SFI Configuration 4

(Default)

DCC.2-DCC.0 = RY/BY# CONFIGURATION (RB2-RB0)

001 = Level Mode (Default)

010 = Pulse-On-Write 011 = Pulse-On-Erase

100 = RY/BY# Disabled

101 = Pulse-On-Write/Erase

#### NOTES:

Default SFI Configuration on powerup or return from deep powerdown mode is 4, allowing system boot from the 28F016XS at any frequency up to the device's maximum frequency. Undocumented combinations of SFI2-SFI0 are reserved by Intel Corporation for future implementations and should not be used.

Undocumented combinations of RB2-RB0 are reserved by Intel Corporation for future implementations and should not be used.

## DCC.7-DCC.6 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when reading the Device Configuration Code. Set these bits to "0" when writing the desired RY/BY# configuration to the device.

## 4.9 SFI Configuration Table

| SFI<br>Configuration | Notes | 28F016XS-15<br>Frequency (MHz) | 28F016XS-20<br>Frequency (MHz) | 28F016XS-25<br>Frequency (MHz) |
|----------------------|-------|--------------------------------|--------------------------------|--------------------------------|
| 4                    | 1,2   | 66 (and below)                 | 50 (and below)                 | 40 (and below)                 |
| 3                    | 2     | 50 (and below)                 | 37.5 (and below)               | 30 (and below)                 |
| 2                    | 2     | 33 (and below)                 | 25 (and below)                 | 20 (and below)                 |
| 1                    | 2     | 16.7 (and below)               | 12.5 (and below)               | 10 (and below)                 |

#### NOTE

- 1. Default SFI Configuration after powerup or return from deep power-down mode via RP# low.
- 2. SFI Configuration is retained if put in sleep mode via a Sleep or Abort Command.



## 5.0 ELECTRICAL SPECIFICATIONS

## 5.1 Absolute Maximum Ratings\*

Temperature Under Bias ...........0°C to +80°C Storage Temperature ..........65°C to +125°C

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## $V_{CC} = 3.3V \pm 0.3V \text{ Systems}(5)$

| Symbol          | Parameter                                                                          | Notes | Min  | Max                   | Units | Test Conditions     |
|-----------------|------------------------------------------------------------------------------------|-------|------|-----------------------|-------|---------------------|
| T <sub>A</sub>  | Operating Temperature, Commercial                                                  | 1     | 0    | 70                    | °C    | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                                | 2     | -0.2 | 7.0                   | V.    |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with<br>Respect to GND                              | 2,3   | -0.2 | 14.0                  | Á     | ,                   |
| ٧               | Voltage on any Pin (except V <sub>CC</sub> , V <sub>PP</sub> ) with Respect to GND | 2     | -0.5 | V <sub>CC</sub> + 0.5 | ٧     |                     |
| 1               | Current into any Non-Supply Pin                                                    |       |      | 30                    | mA    |                     |
| lout            | Output Short Circuit Current                                                       | 4     |      | 100                   | mA    |                     |

#### $V_{CC} = 5.0V \pm 0.5V \text{ Systems}(5)$

| Symbol          | Parameter                                                            | Notes | Min  | Max  | Units | Test Conditions                         |  |  |
|-----------------|----------------------------------------------------------------------|-------|------|------|-------|-----------------------------------------|--|--|
| TA              | Operating Temperature, Commercial                                    | 1     | 0    | 70   | °C    | Ambient Temperature                     |  |  |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                  | 2     | -0.2 | 7.0  | . V   |                                         |  |  |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                   | 2,3   | -0.2 | 14.0 | ٧     | , , , , , , , , , , , , , , , , , , , , |  |  |
| ٧ .             | Voltage on any Pin (except $V_{CC}$ , $V_{PP}$ ) with Respect to GND | 2     | -2.0 | 7.0  | ٧     |                                         |  |  |
| 1               | Current into any Non-Supply Pin                                      |       |      | 30   | . mA  |                                         |  |  |
| lout            | Output Short Circuit Current                                         | 4     |      | 100  | mA    |                                         |  |  |

- 1. Operating temperature is for commercial product defined by this specification.
- Minimum DC voltage is −0.5V on input/output pins. During transitions, this level may undershoot to −2.0V for periods <20 ns. Maximum DC voltage on input/output pins is V<sub>CC</sub>+ 0.5V which may overshoot to V<sub>CC</sub> + 2.0V for periods <20 ns.</li>
- 3. Maximum DC voltage on VPP may overshoot to +14.0V for periods <20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.



## 5.2 Capacitance

For a 3.3V  $\pm$ 0.3V System:

| Symbol            | Parameter                                                       | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-----------------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                 | 1     | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin                       | 1     | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing Specifications | 1, 2  |     | 50  | pF    | For the 28F016XS-20<br>and 28F016XS-25   |

### For 5.0V ±0.5V System:

| Symbol            | Parameter                                                       | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-----------------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                 | 1     | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin                       | 1     | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing Specifications | 1, 2  |     | 100 | pF    | For the 28F016XS-20                      |
|                   | 2                                                               | }     |     | 30  | pF    | For the 28F016XS-15                      |

#### NOTE:

1. Sampled, not 100% tested. Guaranteed by design.

Intel is currently developing more accurate models for the Transient Equivalent Testing Load Circuits. For more information or to obtain iBIS models, please contact your local Intel/Distribution Sales Office.



## 5.3 Transient Input/Output Reference Waveforms



AC test inputs are driven at  $V_{OH}$  (2.4 VTTL) for a Logic "1" and  $V_{OL}$  (0.45 VTTL) for a Logic "0." Input timing begins at  $V_{IH}$  (2.0 VTTL) and  $V_{IL}$  (0.8 VTTL). Output timing ends at  $V_{IH}$  and  $V_{IL}$ . Input rise and fall times (10% to 90%) <10 ns.

Figure 7. Transient Input/Output Reference Waveform ( $V_{CC}=5.0V\pm0.5V$ ) for Standard Testing Configuration(1)



AC test inputs are driven at 3.0V for a Logic "1" and 0.0V for a Logic "0." Input timing begins, and output timing ends, at 1.5V. Input rise and fall times (10% to 90%) <10 ns.

Figure 8. Transient Input/Output Reference Waveform ( $V_{CC} = 3.3V \pm 0.3V$ ) High Speed Reference Waveform(2) ( $V_{CC} = 5.0V \pm 0.5V$ )

- 1. Testing characteristics for 28F016XS-20 at 5V V<sub>CC</sub>.
- 2. Testing characteristics for 28F016XS-15 at 5V V<sub>CC</sub> and 28F016XS-20/28F016XS-25 at 3.3V V<sub>CC</sub>.



## 5.4 DC Characteristics

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol           | Parameter                                     | Notes       | Min | Тур | Max  | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-----------------------------------------------|-------------|-----|-----|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ILI              | Input Load Current                            | 1           |     |     | ±1   | μΑ    | $V_{CC} = V_{CC} Max,$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                 |
| lLO              | Output Leakage<br>Current                     | 1           |     |     | ±10  | μΑ    | $V_{CC} = V_{CC} Max,$<br>$V_{OUT} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                |
| Iccs             | V <sub>CC</sub> Standby<br>Current            | 1,5         |     | 70  | 130  | μΑ    | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC}\text{Max}, \\ \text{CE}_0\#, \text{CE}_1\#, \text{RP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{BYTE}\#, \text{WP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{or GND} \pm 0.2\text{V} \end{array}$                                                                                                                                                                                                                |
|                  |                                               |             |     | 1   | 4    | mA    | $V_{CC} = V_{CC}$ Max,<br>$CE_0\#$ , $CE_1\#$ , $RP\# = V_{IH}$<br>$BYTE\#$ , $WP\# = V_{IH}$ or $V_{IL}$                                                                                                                                                                                                                                                                                                                                                          |
| I <sub>CCD</sub> | V <sub>CC</sub> Deep<br>Power-Down<br>Current | 1           |     | 2   | 5    | μΑ    | $RP\# = GND \pm 0.2V$ $BYTE\# = V_{CC} \pm 0.2V \text{ or GND } \pm 0.2V$                                                                                                                                                                                                                                                                                                                                                                                          |
| ICCR1            | V <sub>CC</sub> Word/Byte<br>Read Current     | 1,4,5       |     | 65  | 85   | mA    | $\begin{array}{l} V_{CC} = V_{CC} \text{ Max} \\ \text{CMOS: } \text{CE}_0 \text{\#, CE}_1 \text{\#} = \text{GND} \pm 0.2 \text{V} \\ \text{BYTE} \text{\#} = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{4-Location Access} \\ \text{Sequence: } 3\text{-}1\text{-}1\text{-}1 \text{ (clocks)} \\ \text{f} = 25 \text{ MHz, } I_{OUT} = 0 \text{ mA} \end{array}$ |
| ICCR2            | V <sub>CC</sub> Word/Byte<br>Read Current     | 1,4,<br>5,6 |     | 60  | 75   | mA    | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ \text{CMOS: CE}_0 \#, \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V or V}_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V or V}_{CC} \pm 0.2 \text{V} \\ \text{4-Location Access} \\ \text{Sequence: 3-1-1-1 (clocks)} \\ \text{f} = 16 \text{ MHz, I}_{OUT} = 0 \text{ mA} \end{array}$                                          |
| Iccw             | V <sub>CC</sub> Write Current                 | 1,6         |     | 8   | 12   | mA    | Word/Byte Write in Progress V <sub>PP</sub> = 12.0V ±5%                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  |                                               |             |     | 8   | . 17 | mA    | Word/Byte Write in Progress V <sub>PP</sub> = 5.0V ±10%                                                                                                                                                                                                                                                                                                                                                                                                            |
| ICCE             | V <sub>CC</sub> Block Erase<br>Current        | 1,6         |     | 6   | 12   | mA    | Block Erase in Progress V <sub>PP</sub> = 12.0V ±5%                                                                                                                                                                                                                                                                                                                                                                                                                |
|                  |                                               |             |     | 9   | 17   | mA    | Block Erase in Progress<br>V <sub>PP</sub> = 5.0V ±10%                                                                                                                                                                                                                                                                                                                                                                                                             |
| ICCES            | V <sub>CC</sub> Erase<br>Suspend Current      | 1,2         |     | 3   | 6    | mA    | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                                                                    |



### 5.4 DC Characteristics (Continued)

 $V_{CC} = 3.3V \pm 0.3V, T_A = 0^{\circ}C \text{ to } +70^{\circ}C$ 

| Symbol            | Parameter                                        | Notes | Min                     | Тур  | Max                     | Units | Test Conditions                                                                     |
|-------------------|--------------------------------------------------|-------|-------------------------|------|-------------------------|-------|-------------------------------------------------------------------------------------|
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby/Read                     | 1     |                         | ±1   | ±10                     | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                   |
| I <sub>PPR</sub>  | Current                                          |       |                         | 30   | 50                      | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                                   |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-<br>Down Current      | 1     |                         | 0.2  | 5                       | μΑ    | RP# = GND ±0.2V                                                                     |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                    | 1,6   |                         | 10   | 15                      | mA    | $V_{PP} = 12.0V \pm 5\%$<br>Word/Byte Write in Progress                             |
|                   | ٠.                                               |       |                         | 15   | 25                      | mA    | $V_{PP} = 5.0V \pm 10\%$<br>Word/Byte Write in Progress                             |
| IPPE              | V <sub>PP</sub> Erase Current                    | 1,6   |                         | 4    | 10                      | mA    | $V_{PP} = 12.0V \pm 5\%$<br>Block Erase in Progress                                 |
|                   |                                                  |       |                         | 14   | 20                      | mA    | $V_{PP} = 5.0V \pm 10\%$<br>Block Erase in Progress                                 |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase<br>Suspend Current         | 1     |                         | 30   | 50                      | μΑ    | V <sub>PP</sub> = V <sub>PPH1</sub> or V <sub>PPH2</sub> ,<br>Block Erase Suspended |
| V <sub>IL</sub>   | Input Low Voltage                                | 6     | -0.3                    | ,    | 0.8                     | ٧     |                                                                                     |
| V <sub>IH</sub>   | Input High Voltage                               | 6     | 2.0                     |      | V <sub>CC</sub><br>+0.3 | ٧     |                                                                                     |
| V <sub>OL</sub>   | Output Low<br>Voltage                            | 6     |                         |      | 0.4                     | V     | $V_{CC} = V_{CC}$ Min and $I_{OL} = 4$ mA                                           |
| V <sub>OH1</sub>  | Output High<br>Voltage                           | 6     | 2.4                     |      |                         | ٧     | $I_{OH} = -2.0 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                            |
| V <sub>OH2</sub>  |                                                  | ,     | V <sub>CC</sub><br>-0.2 |      |                         |       | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$                            |
| V <sub>PPLK</sub> | V <sub>PP</sub> Erase/Write<br>Lock Voltage      | 3,6   | 0.0                     | :    | 1.5                     | ٧     |                                                                                     |
| V <sub>PPH1</sub> | V <sub>PP</sub> during Write/Erase<br>Operations | 3     | 4.5                     | 5.0  | 5.5                     | V     |                                                                                     |
| V <sub>PPH2</sub> | V <sub>PP</sub> during Write/Erase<br>Operations | 3     | 11.4                    | 12.0 | 12.6                    | V     |                                                                                     |
| V <sub>LKO</sub>  | V <sub>CC</sub> Erase/Write<br>Lock Voltage      |       | 2.0                     |      |                         | ٧     |                                                                                     |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 3.3V, V<sub>PP</sub> = 12.0V or 5.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCR</sub>.

  3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when V<sub>PP</sub> \ V<sub>PPLK</sub> and not guaranteed in the
- ranges between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min) and above V<sub>PPH2</sub>(max).
- 4. Automatic Power Savings (APS) reduces  $I_{CCR}$  to 3 mA typical in static operation. 5. CMOS Inputs are either  $V_{CC}$   $\pm 0.2V$  or GND  $\pm 0.2V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .
- 6. Sampled, but not 100% tested. Guaranteed by design.



## 5.5 DC Characteristics

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol | Parameter                                   | Notes       | Min | Тур | Max | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|---------------------------------------------|-------------|-----|-----|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| lu .   | Input Load Current                          | 1           |     |     | ±1  | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                     |
| ILO    | Output Leakage<br>Current                   | 1           |     |     | ±10 | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                    |
| Iccs   | V <sub>CC</sub> Standby<br>Current          | 1,5         |     | 70  | 130 | μΑ    | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ \text{CE}_0 \#, \text{CE}_1 \#, \text{RP} \# = \text{V}_{CC} \pm 0.2 \text{V} \\ \text{BYTE} \#, \text{WP} \# = \text{V}_{CC} \pm 0.2 \text{V} \text{ or GND } \pm 0.2 \text{V} \end{array}$                                                                                                                                                           |
|        |                                             | !           |     | 2   | 4   | mA    | $V_{CC} = V_{CC} Max$<br>$CE_0\#$ , $CE_1\#$ , $RP\# = V_{IH}$<br>$BYTE\#$ , $WP\# = V_{IH} or V_{IL}$                                                                                                                                                                                                                                                                                                                |
| ICCD   | V <sub>CC</sub> Deep Power-<br>Down Current | 1           |     | 2   | 5   | μΑ    | $RP\# = GND \pm 0.2V$ $BYTE\# = V_{CC} \pm 0.2V \text{ or GND } \pm 0.2V$                                                                                                                                                                                                                                                                                                                                             |
| ICCR1  | V <sub>CC</sub> Read Current                | 1,4,5       |     | 120 | 175 | mA    | $\begin{split} &V_{CC} = V_{CC}  \text{Max,} \\ &\text{CMOS: CE}_0 \#  , \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ &\text{BYTE} \# = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ &\text{Inputs} = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ &\text{4-Location Access} \\ &\text{Sequence: 3-1-1-1 (clocks)} \\ &\text{f} = 33  \text{MHz, } I_{OUT} = 0  \text{mA} \end{split}$ |
| ICCR2  | V <sub>CC</sub> Read Current                | 1,4,<br>5,6 |     | 105 | 150 | mA    | $\begin{split} &V_{CC} = V_{CC}  \text{Max}, \\ &\text{CMOS: CE}_0 \#, \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ &\text{BYTE} \# = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ &\text{Inputs} = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ &\text{4-Location Access} \\ &\text{Sequence: 3-1-1-1 (clocks)} \\ &\text{f} = 20  \text{MHz, } I_{OUT} = 0  \text{mA} \end{split}$   |
| Iccw   | V <sub>CC</sub> Write Current               | 1,6         |     | 25  | 35  | mA    | Word/Byte in Progress V <sub>PP</sub> = 12.0V ±5%                                                                                                                                                                                                                                                                                                                                                                     |
|        |                                             |             |     | 25  | 40  | mA    | Word/Byte in Progress VPP = 5.0V ±10%                                                                                                                                                                                                                                                                                                                                                                                 |
| ICCE   | V <sub>CC</sub> Erase<br>Suspend Current    | 1,6         |     | 18  | 25  | mA    | Block Erase in Progress<br>V <sub>PP</sub> = 12.0V ±5%                                                                                                                                                                                                                                                                                                                                                                |
|        | ١                                           |             |     | 20  | 30  | mA    | Block Erase in Progress<br>V <sub>PP</sub> = 5.0V ±10%                                                                                                                                                                                                                                                                                                                                                                |
| ICCES  | V <sub>CC</sub> Block Erase<br>Current      | 1,2         |     | 5   | 10  | mA    | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                       |



## 5.5 DC Characteristics (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol            | Parameter                                        | Notes | Min                     | Тур  | Max                     | Units    | Test Conditions                                                                     |
|-------------------|--------------------------------------------------|-------|-------------------------|------|-------------------------|----------|-------------------------------------------------------------------------------------|
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby/Read                     | 1     |                         | ±1   | ± 10                    | μΑ       | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                   |
| I <sub>PPR</sub>  | Current                                          |       |                         | 30   | 50                      | μΑ       | V <sub>PP</sub> > V <sub>CC</sub>                                                   |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-<br>Down Current      | 1     |                         | 0.2  | 5                       | μΑ       | RP# = GND ±0.2V                                                                     |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                    | 1,6   | -                       | 7    | 12                      | mA.      | V <sub>PP</sub> = 12.0V ±5%<br>Word/Byte Write in Progress                          |
|                   |                                                  |       |                         | 17   | 22                      | mA<br>i  | V <sub>PP</sub> = 5.0V ±10%<br>Word/Byte Write in Progress                          |
| IPPE              | V <sub>PP</sub> Block Erase<br>Current           | 1,6   |                         | 5    | 10                      | mA       | V <sub>PP</sub> = 12.0V ±5%<br>Block Erase in Progress                              |
|                   |                                                  |       |                         | 16   | 20                      | mA       | V <sub>PP</sub> = 5.0V ±10%<br>Block Erase in Progress                              |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase<br>Suspend Current         | 1     |                         | 30   | 50                      | μΑ       | V <sub>PP</sub> = V <sub>PPH1</sub> or V <sub>PPH2</sub> ,<br>Block Erase Suspended |
| V <sub>IL</sub>   | Input Low Voltage                                | . 6   | -0.5                    | ,    | 0.8                     | ٧        | `                                                                                   |
| V <sub>IH</sub>   | Input High Voltage                               | 6     | 2.0                     |      | V <sub>CC</sub><br>+0.5 | <b>V</b> |                                                                                     |
| V <sub>OL</sub>   | Output Low<br>Voltage                            | 6     |                         |      | 0.45                    | ٧        | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                                             |
| V <sub>OH1</sub>  | Output High<br>Voltage                           | 6     | 0.85<br>V <sub>CC</sub> |      | V                       | ٧        | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                            |
| V <sub>OH2</sub>  |                                                  |       | V <sub>CC</sub><br>-0.4 |      |                         |          | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$                            |
| V <sub>PPLK</sub> | V <sub>PP</sub> Write/Erase<br>Lock Voltage      | 3,6   | 0.0                     |      | 1.5                     | ٧        |                                                                                     |
| V <sub>PPH1</sub> | V <sub>PP</sub> during Write/Erase<br>Operations |       | 4.5                     | 5.0  | 5.5                     | ٧        |                                                                                     |
| V <sub>PPH2</sub> | V <sub>PP</sub> during Write/Erase<br>Operations |       | 11.4                    | 12.0 | 12.6                    | ,V       |                                                                                     |
| V <sub>LKO</sub>  | V <sub>CC</sub> Write/Erase<br>Lock Voltage      |       | 2.0                     |      |                         | V        |                                                                                     |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V or 5.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum of ICCES and ICCR.
- 3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when Vpp 

  VppLK and not guaranteed in the ranges between VppLk(max) and VppH1(min), between VppH1(max) and VppH2(min) and above VppH2(max).
- Automatic Power Saving (APS) reduces I<sub>CCR</sub> to 1 mA typical in Static operation.
   CMOS Inputs are either V<sub>IC</sub> ±0.2V or GND ±0.2V. TTL Inputs are either V<sub>IL</sub> or V<sub>IH</sub>.
- 6. Sampled, but not 100% tested. Guaranteed by design.



## 5.6 Timing Nomenclature

All 3.3V system timings are measured from where signals cross 1.5V.

For 5.0V systems, use the standard JEDEC cross point definitions (standard testing) or from where signals cross 1.5V (high speed testing).

Each timing parameter consists of 5 characters. Some common examples are defined below:

 $t_{\mbox{\footnotesize ELCH}}$  time(t) from CE# (E) going low (L) to CLK (C) going high (H)

t<sub>AVCH</sub> time(t) from address (A) valid (V) to CLK (C) going high (H)

t<sub>WHDX</sub> time(t) from WE# (W) going high (H) to when the data (D) can become undefined (X)

|    | Pin Characters                  |   | Pin States                        |
|----|---------------------------------|---|-----------------------------------|
| Α  | Address Inputs                  | Н | High                              |
| С  | CLK (Clock)                     | L | Low                               |
| D  | Data Inputs                     | V | Valid                             |
| Q  | Data Outputs                    | Х | Driven, but Not Necessarily Valid |
| E  | CE# (Chip Enable)               | Z | High Impedance                    |
| F  | BYTE# (Byte Enable)             | L | Latched                           |
| G  | OE# (Output Enable)             |   |                                   |
| W  | WE# (Write Enable)              |   |                                   |
| Р  | RP# (Deep Power-Down Pin)       |   |                                   |
| R  | RY/BY# (Ready Busy)             |   |                                   |
| V  | ADV# (Address Valid)            |   |                                   |
| 5V | V <sub>CC</sub> at 4.5V Minimum |   |                                   |
| 3V | V <sub>CC</sub> at 3.0V Minimum |   |                                   |



## 5.7 AC Characteristics—Read Only Operations(1)

 $V_{CC}=3.3V~\pm0.3V$ ,  $T_{A}=0^{\circ}C$  to  $+70^{\circ}C$ 

|                   | Versions <sup>(3)</sup>                                                     | 1     | 28F01 | 6XS-20 | 28F01 | 6XS-25 | Units |
|-------------------|-----------------------------------------------------------------------------|-------|-------|--------|-------|--------|-------|
| Symbol            | Parameter                                                                   | Notes | Min   | Max    | Min   | Max    | Oints |
| fclk              | CLK Frequency                                                               | 7     |       | 50     |       | 40     | MHz   |
| tCLK              | CLK Period                                                                  |       | 20    |        | 25    |        | ns    |
| <sup>t</sup> CH   | CLK High Time                                                               |       | 6     |        | 8.5   |        | ns    |
| t <sub>CL</sub>   | CLK Low Time                                                                |       | 6     |        | 8.5   |        | ns    |
| tCLCH             | CLK Rise Time                                                               | -     | ·     | 4      |       | 4      | ns    |
| tCHCL             | CLK Fall Time                                                               |       |       | 4      |       | 4      | ns    |
| t <sub>ELCH</sub> | CE <sub>X</sub> # Setup to CLK                                              | 6     | 25    |        | 35    |        | ns    |
| tvLCH             | ADV# Setup to CLK                                                           |       | 20    |        | 25    |        | ns    |
| t <sub>AVCH</sub> | Address Valid to CLK                                                        |       | 20    |        | 25    |        | ns    |
| tCHAX             | Address Hold from CLK                                                       |       | 0     |        | 0     |        | ns    |
| tchvh             | ADV# Hold from CLK                                                          |       | 0     |        | . 0   |        | ns    |
| tGLCH             | OE# Setup to CLK                                                            |       | 20    |        | 25    |        | ns    |
| tchQv             | CLK to Data Delay                                                           |       |       | 30     |       | 35     | ns    |
| t <sub>PHCH</sub> | RP# High to CLK                                                             |       | 480   |        | 480   |        | ns    |
| tchqx             | Output Hold from CLK                                                        | 2     | 6     |        | 6     | :      | ns    |
| tELQX             | CEX# to Output Low Z                                                        | 2,6   | 0     |        | 0     |        | ns    |
| t <sub>EHQZ</sub> | CEX# High to Output High Z                                                  | 2,6   |       | 30     |       | 30     | ns    |
| tGLQX             | OE# to Output Low Z                                                         | 2     | 0     |        | 0     |        | ns    |
| t <sub>GHQZ</sub> | OE# High to Output High Z                                                   | 2     |       | 30     |       | 30     | ns    |
| tон               | Output Hold from CE <sub>X</sub> # or OE#<br>Change, Whichever Occurs First | 6     | 0     |        | 0     |        | ns    |



## 5.7 AC Characteristics—Read Only Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Versions <sup>(3)</sup> |                                                                             |       | 28F016XS-15(4) |     | 28F016XS-20 <sup>(5)</sup> |     | Units  |
|-------------------------|-----------------------------------------------------------------------------|-------|----------------|-----|----------------------------|-----|--------|
| Symbol                  | Parameter                                                                   | Notes | Min            | Max | Min                        | Max | Uiiiis |
| fCLK                    | CLK Frequency                                                               | 7     |                | 66  |                            | 50  | MHz    |
| t <sub>CLK</sub>        | CLK Period                                                                  |       | 15             |     | 20                         |     | ns     |
| t <sub>CH</sub>         | CLK High Time                                                               |       | 3.5            |     | 6                          |     | ns     |
| t <sub>CL</sub>         | CLK Low Time                                                                |       | 3.5            |     | 6                          |     | ns     |
| <sup>t</sup> CLCH       | CLK Rise Time                                                               |       |                | 4   |                            | 4   | ns     |
| t <sub>CHCL</sub>       | CLK Fall Time                                                               |       |                | 4   |                            | 4   | . ns   |
| tELCH                   | CE <sub>X</sub> # Setup to CLK                                              | 6     | 25             |     | 30                         |     | ns     |
| t <sub>VLCH</sub>       | ADV# Setup to CLK                                                           |       | 15             |     | 20                         |     | ns     |
| t <sub>AVCH</sub>       | Address Valid to CLK                                                        |       | 15             |     | 20                         |     | ns     |
| t <sub>CHAX</sub>       | Address Hold from CLK                                                       |       | 0              |     | 0                          |     | ns     |
| tchvh                   | ADV# Hold from CLK                                                          | ·     | 0              |     | 0                          |     | ns     |
| tGLCH                   | OE# Setup to CLK                                                            |       | 15             |     | 20                         |     | ns     |
| tCHQV                   | CLK to Data Delay                                                           |       |                | 20  |                            | 30  | ns     |
| tpHCH                   | RP# High to CLK                                                             |       | 300            |     | 300                        |     | ns     |
| t <sub>CHQX</sub>       | Output Hold from CLK                                                        | 2     | 5              |     | 5                          |     | ns     |
| t <sub>ELQX</sub>       | CE <sub>X</sub> # to Output Low Z                                           | 2,6   | 0              |     | 0                          |     | ns     |
| tEHQZ                   | CEX# High to Output High Z                                                  | 2,6   |                | 30  |                            | 30  | ns     |
| tGLQX                   | OE# to Output Low Z                                                         | 2     | 0              |     | 0                          |     | ns     |
| tgHQZ                   | OE# High to Output High Z                                                   | 2     |                | 30  |                            | 30  | ns     |
| tон                     | Output Hold from CE <sub>X</sub> # or OE#<br>Change, Whichever Occurs First | 6     | 0              |     | 0                          |     | ns     |

- 1. See AC Input/Output Reference Waveforms for timing measurements.
- 2. Sampled, not 100% tested. Guaranteed by design.
- 3. Device speeds are defined as:
  - 15 ns at  $V_{CC} = 5.0V$  equivalent to 20 ns at  $V_{CC} = 3.3V$  20 ns at  $V_{CC} = 3.3V$  20 ns at  $V_{CC} = 5.0V$  equivalent to 25 ns at  $V_{CC} = 3.3V$
- 4. See the high speed AC Input/Output Reference Waveforms.
- 5. See the standard AC Input/Output Reference Waveforms.
- 6.  $CE_X\#$  is defined as the latter of  $CE_0\#$  or  $CE_1\#$  going low, or the first of  $CE_0\#$  or  $CE_1\#$  going high.
- 7. Page buffer reads are valid at any frequency up to the corresponding SFI Configuration setting of 2. Page buffer reads above this frequency may produce invalid results and should not be attempted. See Section 4.9 for SFI Configuration frequency settings.





Figure 9. CLK Waveform



Figure 10. Read Timing Waveform<sup>(1)</sup> (SFI Configuration = 1, Alternate-Bank Accesses)





Figure 11. Read Timing Waveform<sup>(1)</sup> (SFI Configuration = 2, Alternate-Bank Accesses)





Depending on the actual operation frequency, a consecutive alternating bank access can be initiated one clock period earlier. See AP-398 for further information.

Figure 12. Read Timing Waveform<sup>(1)</sup> (SFI Configuration = 3, Alternate-Bank Accesses)





Figure 13. Read Timing Waveform<sup>(1)</sup> (SFI Configuration = 4, Alternating Bank Accesses)



## 5.8 AC Characteristics for WE #-Controlled Write Operations(1)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                    | Versions                                                                                   |       | 28  | F016XS | -20 | 28  | F016XS | -25 | Unit |
|--------------------|--------------------------------------------------------------------------------------------|-------|-----|--------|-----|-----|--------|-----|------|
| Symbol             | Parameter                                                                                  | Notes | Min | Тур    | Max | Min | Тур    | Max | 0    |
| t <sub>AVAV</sub>  | Write Cycle Time                                                                           |       | 75  |        |     | 75  |        |     | ns   |
| t <sub>VPWH</sub>  | V <sub>PP</sub> Setup to WE#<br>Going High                                                 | 3     | 100 |        |     | 100 |        |     | ns   |
| <sup>t</sup> PHEL  | RP# Setup to CE <sub>X</sub> #<br>Going Low                                                | 3,7   | 480 |        |     | 480 |        |     | ns   |
| <sup>t</sup> ELWL  | CE <sub>X</sub> # Setup to WE#<br>Going Low                                                | 3,7   | 0   |        |     | 0   | ,      |     | ns   |
| t <sub>AVWH</sub>  | Address Setup to WE#<br>Going High                                                         | 2,6   | 60  |        |     | 60  |        |     | ns   |
| <sup>t</sup> DVWH  | Data Setup to WE#<br>Going High                                                            | 2,6   | 60  |        |     | 60  |        |     | ns   |
| twLWH              | WE# Pulse Width                                                                            |       | 60  |        |     | 60  |        |     | ns   |
| t <sub>WHDX</sub>  | Data Hold from WE# High                                                                    | 2     | 5   |        |     | 5   |        |     | ns   |
| twhax              | Address Hold from<br>WE# High                                                              | 2     | 5   |        |     | 5   |        |     | ns   |
| t <sub>WHEH</sub>  | CEX# hold from WE# High                                                                    | 3,7   | 5   |        |     | 5   |        |     | ns   |
| t <sub>WHWL</sub>  | WE# Pulse Width High                                                                       |       | 15  |        |     | 15  |        |     | ns   |
| <sup>t</sup> GHWL  | Read Recovery before Write                                                                 | 3     | 0   |        |     | 0   |        |     | ns   |
| twhrl              | WE# High to RY/BY# Going Low                                                               | 3     |     |        | 100 |     |        | 100 | ns   |
| t <sub>RHPL</sub>  | RP# Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>data and RY/BY# High             | 3     | . 0 |        |     | 0   |        |     | ns   |
| tPHWL              | RP# High Recovery to WE# Going Low                                                         | 3     | 480 |        |     | 480 |        |     | ns   |
| twhch              | Write Recovery before Read                                                                 | 3     | 20  |        |     | 20  |        |     | ns   |
| tQVVL              | V <sub>PP</sub> Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>Data and RY/BY# High | 3     | , 0 |        |     | 0   |        |     | μs   |
| twHQV1             | Duration of Word/Byte<br>Write Operation                                                   | 3,4,5 | 5   | 9      | TBD | 5   | 9      | TBD | μs   |
| <sup>t</sup> WHQV2 | Duration of Block<br>Erase Operation                                                       | 3,4   | 0.6 | 1.6    | 20  | 0.6 | 1.6    | 20  | sec  |



## 5.8 AC Characteristics for WE #—Controlled Write Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                     | Versions                                                                                    |       | 28  | F016XS | S-15 | 28  | F016XS | 6-20 | Unit |
|---------------------|---------------------------------------------------------------------------------------------|-------|-----|--------|------|-----|--------|------|------|
| Symbol              | Parameter                                                                                   | Notes | Min | Тур    | Max  | Min | Тур    | Max  |      |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                            |       | 65  |        |      | 65  |        |      | ns   |
| t <sub>VPWH</sub>   | V <sub>PP</sub> Setup to WE#<br>Going High                                                  | 3     | 100 |        |      | 100 |        |      | ns   |
| t <sub>PHEL</sub>   | RP# Setup to CEX# Going Low                                                                 | 3,7   | 300 |        |      | 300 |        |      | ns   |
| t <sub>ELWL</sub>   | CE <sub>X</sub> # Setup to WE#<br>Going Low                                                 | 3,7   | 0   |        |      | 0   |        |      | ns   |
| t <sub>AVWH</sub>   | Address Setup to WE#<br>Going High                                                          | 2,6   | 50  |        |      | 50  | :      |      | ns   |
| t <sub>DVWH</sub>   | Data Setup to WE# Going High                                                                | 2,6   | 50  |        |      | 50  |        |      | ns   |
| twLWH               | WE# Pulse Width                                                                             |       | 50  |        |      | 50  |        |      | ns   |
| twhox               | Data Hold from WE# High                                                                     | 2     | 0   |        |      | 0   |        |      | ns   |
| twhax               | Address Hold from WE# High                                                                  | 2     | 5   |        |      | 5   |        |      | ns   |
| twheh               | CEX# hold from WE# High                                                                     | 3,7   | 5   |        |      | 5   |        |      | ns   |
| twhwL               | WE# Pulse Width High                                                                        |       | 15  |        |      | 15  |        |      | ns   |
| t <sub>GHWL</sub>   | Read Recovery before Write                                                                  | 3     | 0   |        |      | 0   |        | ,    | ns   |
| twhrl               | WE# High to RY/BY# Going Low                                                                | 3     |     |        | 100  |     |        | 100  | ns   |
| t <sub>RHPL</sub>   | RP# Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>data and RY/BY# High              | 3     | 0   |        |      | 0   |        |      | ns   |
| t <sub>PHWL</sub>   | RP# High Recovery to WE# Going Low                                                          | 3     | 300 |        |      | 300 |        |      | ns   |
| twhch               | Write Recovery<br>before Read                                                               | 3     | 20  |        |      | 20  |        |      | ns   |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>Data and RY/BY # High | 3     | 0   |        |      | 0   |        |      | μs   |
| t <sub>WHQV</sub> 1 | Duration of Word/Byte<br>Write Operation                                                    | 3,4,5 | 4.5 | 6      | TBD  | 4.5 | 6      | TBD  | μs   |
| t <sub>WHQV</sub> 2 | Duration of Block<br>Erase Operation                                                        | 3,4   | 0.6 | 1.2    | 20   | 0.6 | 1.2    | 20   | sec  |

- 1. Read timings during Write and Erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, but not 100% tested. Guaranteed by design.
- 4. Write/Erase durations are measured to valid Status Register (CSR) Data.
- 5. Word/Byte Write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of WE# for all Command Write operations.
- 7. CE<sub>X</sub># is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.





Figure 14. AC Waveforms for WE # Command Write Operations, Illustrating a Two Command Write Sequence Followed by a Extended Status Register Read



## 5.9 AC Characteristics for CE<sub>X</sub>#—Controlled Write Operations(1)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                    | Versions                                                                                   |       | 28  | F016XS | -20 | 28  | F016XS | -25 | Unit |
|--------------------|--------------------------------------------------------------------------------------------|-------|-----|--------|-----|-----|--------|-----|------|
| Symbol             | Parameter                                                                                  | Notes | Min | Тур    | Max | Min | Тур    | Max | 0    |
| t <sub>AVAV</sub>  | Write Cycle Time                                                                           |       | 75  |        |     | 75  |        |     | ns   |
| t <sub>VPEH</sub>  | V <sub>PP</sub> Setup to CE <sub>X</sub> #<br>Going High                                   | 3,7   | 100 |        |     | 100 |        |     | ns   |
| t <sub>PHWL</sub>  | RP# Setup to WE#<br>Going Low                                                              | 3     | 480 |        |     | 480 |        |     | ns   |
| tWLEL              | WE# Setup to CE <sub>X</sub> #<br>Going Low                                                | 3,7   | 0   |        |     | 0   |        |     | ns   |
| taveh              | Address Setup to CE <sub>X</sub> #<br>Going High                                           | 2,6,7 | 60  |        |     | 60  |        |     | ns   |
| <sup>t</sup> DVEH  | Data Setup to CE <sub>X</sub> #<br>Going High                                              | 2,6,7 | 60  | 1.     |     | 60  |        |     | ns   |
| t <sub>ELEH</sub>  | CE <sub>X</sub> # Pulse Width                                                              | 7     | 60  |        |     | 60  |        |     | ns   |
| t <sub>EHDX</sub>  | Data Hold from CE <sub>X</sub> # High                                                      | 2,7   | 10  |        |     | 10  |        |     | ns   |
| <sup>t</sup> EHAX  | Address Hold from CE <sub>X</sub> # High                                                   | 2,7   | 10  |        |     | 10  |        |     | ns   |
| tEHWH              | WE hold from CE <sub>X</sub> # High                                                        | 3,7   | 5   |        |     | 5   |        |     | ns   |
| tEHEL              | CEX# Pulse Width High                                                                      | 7     | 15  |        |     | 15  |        |     | ns   |
| tGHEL              | Read Recovery before Write                                                                 | 3     | 0   |        |     | 0   | •      |     | ns   |
| t <sub>EHRL</sub>  | CE <sub>X</sub> # High to RY/BY#<br>Going Low                                              | 3,7   |     |        | 100 |     |        | 100 | ns   |
| t <sub>RHPL</sub>  | RP# Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>Data and RY/BY# High             | 3     | 0   |        |     | 0   |        |     | ns   |
| t <sub>PHEL</sub>  | RP# High Recovery to CE <sub>X</sub> # Going Low                                           | 3,7   | 480 |        |     | 480 |        |     | ns   |
| t <sub>EHCH</sub>  | Write Recovery before Read                                                                 | 3     | 20  |        |     | 20  |        |     | ns   |
| <sup>t</sup> QVVL  | V <sub>PP</sub> Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>Data and RY/BY# High | 3     | 0   |        |     | 0   |        | -   | μs   |
| tEHQV1             | Duration of Word/Byte<br>Write Operation                                                   | 3,4,5 | 5   | 9      | TBD | 5   | 9      | TBD | μs   |
| t <sub>EHQV2</sub> | Duration of Block<br>Erase Operation                                                       | 3,4   | 0.6 | 1.6    | 20  | 0.6 | 1.6    | 20  | sec  |



## 5.9 AC Characteristics for CE<sub>X</sub> # Controlled Write Operations<sup>(1)</sup> (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0$ °C to +70°C

|                     | Versions                                                                                   |       | 28  | F016XS | S-15 | 28  | F016XS | S-20 | Unit |
|---------------------|--------------------------------------------------------------------------------------------|-------|-----|--------|------|-----|--------|------|------|
| Symbol              | Parameter                                                                                  | Notes | Min | Тур    | Max  | Min | Тур    | Max  |      |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                           |       | 60  |        |      | 60  |        |      | ns   |
| t <sub>PHWL</sub>   | RP# Setup to WE# Going Low                                                                 | 3     | 300 |        |      | 300 |        |      | ns   |
| t <sub>VPEH</sub>   | V <sub>PP</sub> Setup to CE <sub>X</sub> #<br>Going Low Going High                         | 3,7   | 100 |        |      | 100 |        |      | ns   |
| tWLEL               | WE# Setup to CE <sub>X</sub> # Going Low                                                   | 3,7   | 0   |        |      | 0   |        |      | ns   |
| t <sub>AVEH</sub>   | Address Setup to CE <sub>X</sub> # Going High                                              | 2,6,7 | 45  |        |      | 45  |        |      | ns   |
| tDVEH               | Data Setup to CEX# Going High                                                              | 2,6,7 | 45  |        |      | 45  |        |      | ns   |
| <sup>t</sup> ELEH   | CEX# Pulse Width                                                                           | 7     | 45  |        |      | 45  |        |      | ns   |
| t <sub>EHDX</sub>   | Data Hold from<br>Going HighCE <sub>X</sub> # High                                         | 2,7   | 0   | ,      |      | 0   |        |      | ns   |
| t <sub>EHAX</sub>   | Address Hold from CE <sub>X</sub> # High                                                   | 2,7   | -5  |        |      | 5   |        |      | ns   |
| tEHWH               | WE hold from CE <sub>X</sub> # High                                                        | 3,7   | 5   |        |      | 5   |        |      | ns   |
| t <sub>EHEL</sub>   | CE <sub>X</sub> # Pulse Width High                                                         | 7     | 15  |        |      | 15  |        |      | ns   |
| <sup>†</sup> GHEL   | Read Recovery before Write                                                                 | 3     | 0   |        |      | 0   |        |      | ns   |
| t <sub>EHRL</sub>   | CE <sub>X</sub> # High to RY/BY#<br>Going Low                                              | 3,7   |     |        | 100  |     |        | 100  | ns   |
| <sup>t</sup> RHPL   | RP# Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>Data and RY/BY# High             | 3     | 0   |        |      | 0   |        |      | ns   |
| t <sub>PHEL</sub>   | RP# High Recovery to CE <sub>X</sub> # Going Low                                           | 3,7   | 300 |        |      | 300 |        |      | ns   |
| t <sub>EHCH</sub>   | Write Recovery before Read                                                                 | 3     | 20  |        |      | 20  |        |      | ns   |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid Status<br>Register (CSR, GSR, BSR)<br>Data and RY/BY# High | 3     | 0   |        |      | 0   |        |      | μs   |
| t <sub>EHQV</sub> 1 | Duration of Word/Byte<br>Write Operation                                                   | 3,4,5 | 4.5 | 6      | TBD  | 4.5 | 6      | TBD  | μs   |
| t <sub>EHQV</sub> 2 | Duration of Block<br>Erase Operation                                                       | 3,4   | 0.6 | 1.2    | 20   | 0.6 | 1.2    | 20   | sec  |

- 1. Read timings during Write and Erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, but not 100% tested. Guaranteed by design.
- 4. Write/Erase durations are measured to valid Status Register (CSR) Data.
- 5. Word/Byte Write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of WE# for all Command Write operations.
- 7. CEX# is defined as the latter of CE0# or CE1# going low, or the first of CE0# or CE1# going high.





Figure 15. AC Waveforms for CE<sub>X</sub>#—Controlled Write Operations, Illustrating a Two Command Write Sequence Followed by a Extended Status Register Read



## 5.10 AC Characteristics for WE#—Controlled Page Buffer Write Operations(1)

 $V_{CC}=$  3.3V  $\pm 0.3$ V,  $T_{A}=$  0°C to +70°C

| Versions |                                   |       | 28  | 28F016XS-20 |     |     | 28F016XS-25 |     |      |
|----------|-----------------------------------|-------|-----|-------------|-----|-----|-------------|-----|------|
| Symbol   | Parameter                         | Notes | Min | Тур         | Max | Min | Тур         | Max | Unit |
| tavwL    | Address Setup to WE#<br>Going Low | 2     | 0   |             |     | 0   |             |     | ns   |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0$ °C to +70°C

| Versions          |                                   |       | 28  | F016XS | -15 | 28  | Unit |     |       |
|-------------------|-----------------------------------|-------|-----|--------|-----|-----|------|-----|-------|
| Symbol            | Parameter                         | Notes | Min | Тур    | Max | Min | Тур  | Max | 0,,,, |
| t <sub>AVWL</sub> | Address Setup to WE#<br>Going Low | 2     | 0   | ,      |     | 0   |      |     | ns    |

- 1. All other specifications for WE#Controlled Page Buffer Write Operations see Section 5.8.
- 2. Address must be valid during the entire WE# low pulse.



Figure 16. WE#—Controlled Page Buffer Write Timing Waveforms (Loading Data to the Page Buffer)



## 5.11 AC Characteristics for CE<sub>X</sub>#—Controlled Page Buffer Write Operations

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Versions |                                              |       | 28  | F016XS | -20 | 28  | Unit |     |    |
|----------|----------------------------------------------|-------|-----|--------|-----|-----|------|-----|----|
| Symbol   | Parameter                                    | Notes | Min | Тур    | Max | Min | Тур  | Max | J  |
| tAVEL    | Address Setup to CE <sub>X</sub> # Going Low | 2,3   | 0   |        |     | 0   |      |     | ns |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0$ °C to +70°C

| Versions |                                              |       | 28  | F016XS | -15 | 28  | Unit |     |          |
|----------|----------------------------------------------|-------|-----|--------|-----|-----|------|-----|----------|
| Symbol   | Parameter                                    | Notes | Min | Тур    | Max | Min | Тур  | Max | <b>0</b> |
| tAVEL    | Address Setup to CE <sub>X</sub> # Going Low | 2,3   | 0   |        |     | 0   |      |     | ns       |

- 1. All other specifications for CE<sub>X</sub>#Controlled Page Buffer Write Operations see Section 5.9.
- 2. Address must be valid during the entire CE# low pulse.
- 3. CE<sub>X</sub># is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.



Figure 17.  $CE_x$ #—Controlled Page Buffer Write Timing Waveforms (Loading Data to the Page Buffer)



## 5.12 Power-Up and Reset Timings



Figure 18. V<sub>CC</sub> Power-Up and RP# Reset Waveforms

| Symbol            | Parameter                                     | Notes | Min | Max | Unit |
|-------------------|-----------------------------------------------|-------|-----|-----|------|
| t <sub>PL5V</sub> | RP# Low to V <sub>CC</sub> at 4.5V (Minimum)  | 2     | 0   |     | μs   |
| t <sub>PL3V</sub> | RP# Low to V <sub>CC</sub> at 3.0V (Minimum)  | 2     | 0   |     | μs   |
| t <sub>5VPH</sub> | V <sub>CC</sub> at 4.5V Minimum) to RP# High  | 1     | 2   |     | μs   |
| t <sub>3VPH</sub> | V <sub>CC</sub> at 3.0V (Minimum) to RP# High | 1     | 2   |     | μs   |

The t<sub>5VPH</sub> and/or t<sub>3VPH</sub> times must be strictly followed to guarantee all other read and write specifications for the 28F016XS.

<sup>2.</sup> The power supply may start to switch concurrently with RP# going low.



## 5.13 Erase and Word/Byte Write Performance(3,5)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $V_{PP} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol   | Parameter                                          | Notes | Min | Typ(1) | Max | Units | Test Conditions |
|----------|----------------------------------------------------|-------|-----|--------|-----|-------|-----------------|
|          | Page Buffer Byte Write Time                        | 2     | TBD | 6.0    | TBD | μs    |                 |
|          | Page Buffer Word Write Time                        | 2     | TBD | 12.1   | TBD | μs    |                 |
| twhRH1A  | Byte Write Time                                    | 2     | TBD | 16.5   | TBD | μs    |                 |
| twhrij1B | Word Write Time                                    | 2     | TBD | 24.0   | TBD | μs    |                 |
| twHRH2   | Block Write Time                                   | 2     | TBD | 2.2    | TBD | sec   | Byte Write Mode |
| twhRH3   | Block Write Time                                   | 2     | TBD | 1.6    | TBD | sec   | Word Write Mode |
|          | Block Erase Time                                   | 2     | TBD | 2.8    | TBD | sec   |                 |
|          | Full Chip Erase Time                               | 2     | TBD | 44.8   | TBD | sec   |                 |
|          | Time From Erase<br>Suspend Command to<br>WSM Ready | 4     | TBD | 10     | TBD | μs    |                 |

 $V_{CC}=$  3.3V  $\pm 0.3$ V,  $V_{PP}=$  12.0V  $\pm 0.6$ V,  $T_{A}=$  0°C to +70°C

| Symbol             | Parameter                                          | Notes | Min | Typ(1) | Max | Units | Test Conditions |
|--------------------|----------------------------------------------------|-------|-----|--------|-----|-------|-----------------|
|                    | Page Buffer Byte Write Time                        | 2     | TBD | 2.2    | TBD | μs    |                 |
|                    | Page Buffer Word Write Time                        | 2     | TBD | 4.4    | TBD | μs    |                 |
| t <sub>WHRH1</sub> | Word/Byte Write Time                               | 2     | 5   | 9      | TBD | μs    | ,               |
| t <sub>WHRH2</sub> | Block Write Time                                   | 2     | TBD | 1.2    | 4.2 | sec   | Byte Write Mode |
| twhRH3             | Block Write Time                                   | 2     | TBD | 0.6    | 2.0 | sec   | Word Write Mode |
|                    | Block Erase Time                                   | 2     | 0.6 | 1.6    | 20  | sec   |                 |
|                    | Full Chip Erase Time                               | 2     | TBD | 25.6   | TBD | sec   |                 |
|                    | Time From Erase<br>Suspend Command to<br>WSM Ready | 4     | TBD | 10     | TBD | μs    |                 |



## 5.13 Erase and Word/Byte Write Performance(3,5) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $V_{PP} = 5.0V \pm 0.5V$ ,  $T_A = 0$ °C to +70°C

| Symbol              | Parameter                                          | Notes | Min | Typ(1) | Max | Units | Test Conditions |
|---------------------|----------------------------------------------------|-------|-----|--------|-----|-------|-----------------|
|                     | Page Buffer Byte<br>Write Time                     | 2     | TBD | 6.0    | TBD | μs    | `               |
|                     | Page Buffer Word                                   | 2     | TBD | 12.1   | TBD | μs    | Write Time      |
| twhRH1A             | Byte Write Time                                    | 2     | TBD | 11     | TBD | μs    |                 |
| t <sub>WHRH1B</sub> | Word Write Time                                    | 2     | TBD | 16     | TBD | μs    |                 |
| t <sub>WHRH2</sub>  | Block Write Time                                   | 2     | TBD | 1.6    | TBD | sec   | Byte Write Mode |
| t <sub>WHRH3</sub>  | Block Write Time                                   | 2     | TBD | 1.2    | TBD | sec   | Word Write Mode |
|                     | Block Erase Time                                   | 2     | TBD | 2.0    | TBD | sec   |                 |
|                     | Full Chip Erase Time                               | 2     | TBD | 32.0   | TBD | sec   |                 |
|                     | Time From Erase<br>Suspend Command to<br>WSM Ready | 4     | TBD | 10     | TBD | μs    |                 |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol | Parameter                                          | Notes | Min   | Typ(1) | Max | Units | Test Conditions |
|--------|----------------------------------------------------|-------|-------|--------|-----|-------|-----------------|
|        | Page Buffer Byte Write Time                        | - 2   | TBD   | 2.1    | TBD | μs    |                 |
|        | Page Buffer Word Write Time                        | 2     | TBD   | 4.1    | TBD | μs    | ·               |
| twhRH1 | Word/Byte Write Time                               | 2     | 4.5   | 6      | TBD | μs    |                 |
| twhRH2 | Block Write Time                                   | 2     | TBD   | 0.8    | 4.2 | sec   | Byte Write Mode |
| twhRH3 | Block Write Time                                   | 2     | TBD   | 0.4    | 2.0 | sec   | Word Write Mode |
|        | Block Erase Time                                   | 2     | 0.6   | 1.2    | 20  | sec   |                 |
|        | Full Chip Erase Time                               | 2     | · TBD | 19.2   | TBD | sec   |                 |
|        | Time From Erase<br>Suspend Command to<br>WSM Ready | 4     | TBD   | 10     | TBD | μs    |                 |

- 1. 25°C, and nominal voltages.
- 2. Excludes system-level overhead.
- 3. These performance numbers are valid for all speed versions.
- Specification applies to interrupt latency for Single Block Erase. Suspend latency for Erase All Unlocked Block operation typically extends erase suspend latency time to 140 μs.
- 5. Sampled, but not 100% tested. Guaranteed by design.



## 6.0 MECHANICAL SPECIFICATIONS



Figure 19. Mechanical Specifications of the 28F016XS 56-Lead TSOP Type I Package

|                | Family: Thin Small Out-Line Package |         |         |  |  |  |  |  |
|----------------|-------------------------------------|---------|---------|--|--|--|--|--|
| Symbol         |                                     | Notes   |         |  |  |  |  |  |
| Cymbo.         | Minimum                             | Nominal | Maximum |  |  |  |  |  |
| Α              |                                     |         | 1.20    |  |  |  |  |  |
| A <sub>1</sub> | 0.50                                |         |         |  |  |  |  |  |
| A <sub>2</sub> | 0.965                               | 0.995   | 1.025   |  |  |  |  |  |
| b              | 0.100                               | 0.150   | 0.200   |  |  |  |  |  |
| С              | 0.115                               | 0.125   | 0.135   |  |  |  |  |  |
| D <sub>1</sub> | 18.20                               | 18.40   | 18.60   |  |  |  |  |  |
| . E            | 13.80                               | 14.00   | 14.20   |  |  |  |  |  |
| е              |                                     | 0.50    |         |  |  |  |  |  |
| D              | 19.80                               | 20.00   | 20.20   |  |  |  |  |  |
| L              | 0.500                               | 0.600   | 0.700   |  |  |  |  |  |
| N              | ·                                   | 56      |         |  |  |  |  |  |
| Ø              | 0°                                  | 3°      | 5°      |  |  |  |  |  |
| Y              |                                     |         | 0.100   |  |  |  |  |  |
| Z              | 0.150                               | 0.250   | 0.350   |  |  |  |  |  |



### **DEVICE NOMENCLATURE AND ORDERING INFORMATION**



| *      |             |                                                                                | Valid Combinations                                                            |                                                                           |
|--------|-------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| Option | Order Code  | V <sub>CC</sub> = 3.3V ±0.3V,<br>50 pF load,<br>1.5V I/O Levels <sup>(1)</sup> | V <sub>CC</sub> = 5.0V ± 10%,<br>100 pF load<br>TTL I/O Levels <sup>(1)</sup> | $V_{CC} = 5.0V \pm 10\%,$<br>30 pF load<br>1.5V I/O Levels <sup>(1)</sup> |
| . 1 .  | E28F016XS15 | 28F016XS-20                                                                    |                                                                               | 28F016XS-15                                                               |
| 2      | E28F016XS20 | 28F016XS-25                                                                    | 28F016XS-20                                                                   |                                                                           |



## **ADDITIONAL INFORMATION**

| Order Number                               | Document/Tool                                                                                 |
|--------------------------------------------|-----------------------------------------------------------------------------------------------|
| 297372                                     | 16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016XS/28F016XD            |
| 292147                                     | AP-398, "Designing with the 28F016XS"                                                         |
| 297500                                     | "Interfacing the 28F016XS to the i960® Microprocessor Family"                                 |
| 297504                                     | "Interfacing the 28F016XS to the Intel486™ Microprocessor Family"                             |
| 292146                                     | AP-600, "Performance Benefits and Power/Energy Savings of 28F016XS Based System Designs"      |
| 297508                                     | FlashBuilder Utility                                                                          |
| Contact Intel/Distribution Sales Office    | 28F016XS Benchmark Utility FlashBuilder                                                       |
| Contact Intel/Distribution<br>Sales Office | 28F016XS iBIS/VHDL Models                                                                     |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Orcad/Viewlogic Schematic Symbols                                                    |
| 292126                                     | AP 377, "16-Mbit Flash Product Family Software Drivers 28F016SA/28F016SV/28F016XS/28F016XD"   |
| 294016                                     | ER 33, "ETOX™ Flash Memory TechnologyInsight to Intel's Fourth Generation Process Innovation" |

## **DATASHEET REVISION HISTORY**

| Number | Description      |
|--------|------------------|
| 001    | Original Version |



## 28F016XD 16-MBIT (1 MBIT X 16) DRAM-INTERFACE FLASH MEMORY

- 85 ns Access Time (t<sub>RAC</sub>)
- **Multiplexed Address Bus**
- RAS# and CAS# Control Inputs
- No-Glue Interface to Many Memory Controllers
- SmartVoltage Technology
  - User-Selectable 3.3V or 5V Vcc
  - User-Selectable 5V or 12V Vpp
- 30.8 MB/sec Burst Write Transfer Rate
- 0.48 MB/sec Sustainable Write Transfer Rate
- **■** x16 Architecture
- 56-Lead TSOP Type I Package

- Backwards-Compatible with 28F016SA/SV, 28F008SA Command Set
- **Revolutionary Architecture** 
  - Multiple Command Execution
  - Write during Erase
  - Page Buffer Write
- 2 μA Typical Deep Power-Down Current
- 1 mA Typical I<sub>CC</sub> Active Current in Static Mode
- 32 Separately-Erasable/Lockable 64-Kbyte Blocks
- 1 Million Erase Cycles per Block
- State-of-the-Art 0.6 µm ETOX™ IV Flash Technology

Intel's 28F016XD 16-MBit Flash memory is a revolutionary architecture which is the ideal choice for designing truly revolutionary high-performance products. Combining its DRAM-like read performance and interface with the intrinsic non-volatility of flash memory, the 28F016XD eliminates the traditional redundant memory paradigm of shadowing code from a slow nonvolatile storage source to a faster execution memory, such as DRAM, for improved system performance. The innovative capabilities of the 28F016XD enable the design of direct-execute code and mass storage data/file flash memory systems.

The 28F016XD is the highest performance high density nonvolatile read/write flash memory solution available today. Its DRAM-like interface with a multiplexed address bus, flexible  $V_{CC}$  and  $V_{PP}$  voltages, power saving features, extended cycling, fast write and read performance, symmetrically blocked architecture, and selective block locking provide a highly flexible memory component suitable for resident flash component arrays on the system board or SIMMs. The DRAM-like interface with RAS# and CAS# control inputs allows for easy migration to flash memory in existing DRAM-based systems. The 28F016XD's dual read voltage allows the same component to operate at either 3.3V or 5.0V  $V_{CC}$ . Programming voltage at 5V  $V_{PP}$  minimizes external circuitry in minimal-chip, space critical designs, while the 12V  $V_{PP}$  option maximizes write/erase performance. The x16 architecture allows optimization of the memory-to-processor interface. Its high read performance combined with flexible block locking enable both storage and execution of operating systems/application software and fast access to large data tables. The 28F016XD is manufactured on Intel's 0.6  $\mu$ m ETOXTM IV process technology.



290533-22

## 28F016XD 16-MBIT (1 MBIT X 16) DRAM-INTERFACE FLASH MEMORY

| <b>CONTENTS</b> PAGE                                         | CONTENTS                                                                | PAGE          |
|--------------------------------------------------------------|-------------------------------------------------------------------------|---------------|
| <b>1.0 INTRODUCTION</b>                                      | 5.6 AC Characteristics $(V_{CC} = 3.3V \pm 0.3V)$                       | 3-77          |
| 1.1 Product Overview                                         | Read, Write, Read-Modify-Write<br>Refresh Cycles (Common                |               |
| 2.1 Lead Descriptions                                        | Parameters)                                                             |               |
| •                                                            | Read Cycle                                                              |               |
| 3.0 MEMORY MAPS 3-58                                         | Read-Modify-Write Cycle                                                 |               |
| 3.1 Extended Status Registers Memory Map                     | Fast Page Mode Cycle                                                    |               |
|                                                              | Fast Page Mode Read-Modify-W                                            |               |
| 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER             | Cycle                                                                   | 3-79          |
| DEFINITIONS 3-60                                             | Refresh Cycle                                                           | 3-80          |
| 4.1 Bus Operations 3-60                                      | Misc. Specifications                                                    | 3-81          |
| 4.2 28F008SA-Compatible Mode Command Bus Definitions 3-61    | 5.7 AC Characteristics $(V_{CC} = 5.0V \pm 0.5V)$                       | 3-82          |
| 4.3 28F016XD-Performance Enhancement Command Bus Definitions | Read, Write, Read-Modify-Write<br>Refresh Cycles (Common<br>Parameters) |               |
| 4.4 Compatible Status Register 3-64                          | Read Cycle                                                              |               |
| 4.5 Global Status Register 3-65                              | Write Cycle                                                             |               |
| 4.6 Block Status Register 3-66                               | Read-Modify-Write Cycle                                                 |               |
| 4.7 Device Configuration Code 3-67                           | Fast Page Mode Cycle                                                    | 3-84          |
| 5.0 ELECTRICAL SPECIFICATIONS 3-68                           | Fast Page Mode Read-Modify-W                                            | /rite<br>3-85 |
| 5.1 Absolute Maximum Ratings 3-68                            | Refresh Cycle                                                           |               |
| <b>5.2 Capacitance</b>                                       | Refresh                                                                 |               |
| 5.3 Transient Input/Output Reference Waveforms               | Misc. Specifications                                                    | 3-86          |
| 5.4 DC Characteristics                                       | 5.8 AC Waveforms                                                        |               |
| $(V_{CC} = 3.3V \pm 0.3V)$                                   | 5.9 Power-Up and Reset Timings                                          | 3-99          |
| 5.5 DC Characteristics<br>(V <sub>CC</sub> = 5.0V ± 0.5V)    | 5.10 Erase and Word Write Performance                                   |               |
|                                                              | 6.0 MECHANICAL SPECIFICATIONS                                           | 3-101         |
|                                                              | DEVICE NOMENCLATURE AND ORDERING INFORMATION                            | 3-102         |
|                                                              | ADDITIONAL INFORMATION                                                  | 3-103         |
|                                                              | DATASHEET REVISION HISTORY .                                            | 3-108         |



#### 1.0 INTRODUCTION

The documentation of the Intel 28F016XD flash memory device includes this datasheet, a detailed user's manual, and a number of application notes and design tools, all of which are referenced at the end of this datasheet.

The datasheet is intended to give an overview of the chip feature-set and of the operating AC/DC specifications. The 16-Mbit Flash Product Family User's Manual provides complete descriptions of the user modes, system interface examples and detailed descriptions of all principles of operation. It also contains the full list of software algorithm flowcharts, and a brief section on compatibility with the Intel 28F008SA.

#### 1.1 Product Overview

The 28F016XD is a high-performance, 16-Mbit (16,777,216-bit) block erasable, nonvolatile random access memory, organized as 1 Mword x 16. The 28F016XD includes thirty-two 32-KW (32,768 word) blocks. A chip memory map is shown in Figure 3.

The implementation of a new architecture, with many enhanced features, will improve the device operating characteristics and result in greater product reliability and ease-of-use as compared to other flash memories. Significant features of the 28F016XD include:

- No-Glue Interface to Memory Controllers
- Improved Word Write Performance
- SmartVoltage Technology
  - Selectable 3.3V or 5.0V V<sub>CC</sub>
  - Selectable 5.0V or 12.0V VPP
- Internal 3.0V/5.0V V<sub>CC</sub> Detection Circuitry
- Block Write/Erase Protection

The 28F016XD's multiplexed address bus with RAS# and CAS# inputs allows for a "No Glue" interface to many existing in-system memory controllers. As such, 28F016XD-based SIMMs (72-pin JEDEC Standard) offer attractive advantages over their DRAM counterparts in many applications. For more information on 28F016XD-based SIMM designs, see the application note referenced at the end of this datasheet.

The 28F016XD incorporates SmartVoltage technology, providing V<sub>CC</sub> operation at both 3.3V and 5.0V and program and erase capability at V<sub>PP</sub> = 12.0V or 5.0V. Operating at V<sub>CC</sub> = 3.3V, the 28F016XD consumes less than 60% of the power consumption at 5.0V V<sub>CC</sub>, while 5.0V V<sub>CC</sub> provides highest read performance capability. V<sub>PP</sub> = 5.0V operation eliminates the need for a separate 12.0V converter, while V<sub>PP</sub> = 12.0V maximizes write/erase performance. In addition to the flexible program and erase voltages, the dedicated V<sub>PP</sub> gives complete code protection with V<sub>PP</sub>  $\leq$  V<sub>PPLK</sub>.

Internal 3.3V or 5.0V  $V_{CC}$  detection automatically configures the device internally for optimized 3.3V or 5.0V Read/Write operation.

A Command User Interface (CUI) serves as the system interface between the microprocessor or microcontroller and the internal memory operation.

Internal Algorithm Automation allows Word Writes and Block Erase operations to be executed using a Two-Write command sequence to the CUI in the same way as the 28F008SA 8-Mbit FlashFile™ memory.

A super-set of commands has been added to the basic 28F008SA command-set to achieve higher write performance and provide additional capabilities. These new commands and features include:

- Page Buffer Writes to Flash
- Command Queuing Capability
- Automatic Data Writes during Erase
- Software Locking of Memory Blocks
- Erase All Unlocked Blocks

Writing of memory data is performed in word increments typically within 6  $\mu$ sec (12.0V V<sub>PP</sub>) - a 33% improvement over the 28F008SA. A Block Erase operation erases one of the 32 blocks in typically 0.6 sec (12.0V V<sub>PP</sub>), independent of the other blocks, which is about a 65% improvement over the 28F008SA.

Each block can be written and erased a minimum of 100,000 cycles. Systems can achieve one million Block Erase Cycles by providing wear-leveling algorithms and graceful block retirement. These techniques have already been employed in many flash file systems and hard disk drive designs.



The 28F016XD incorporates two Page Buffers of 256 bytes (128 words) each to allow page data writes. This feature can improve a system write performance by up to 4.8 times over previous flash memory devices, which have no Page Buffers.

All operations are started by a sequence of Write commands to the device. Three types of Status Registers (described in detail later in this datasheet) and a RY/BY# output pin provide information on the progress of the requested operation.

While the 28F008SA requires an operation to complete before the next operation can be requested, the 28F016XD allows queuing of the next operation while the memory executes the current operation. This eliminates system overhead when writing several bytes in a row to the array or erasing several blocks at the same time. The 28F016XD can also perform Write operations to one block of memory while performing Erase of another block.

The 28F016XD provides selectable block locking to protect code or data such as direct-executable operating systems or application code. Each block has an associated nonvolatile lock-bit which determines the lock status of the block. In addition, the 28F016XD has a master Write Protect pin (WP#) which prevents any modifications to memory blocks whose lock-bits are set.

The 28F016XD contains three types of Status Registers to accomplish various functions:

- A Compatible Status Register (CSR) which is 100% compatible with the 28F008SA FlashFile™ memory Status Register. The CSR, when used alone, provides a straightforward upgrade capability to the 28F016XD from a 28F008SA-based design.
- A Global Status Register (GSR) which informs the system of command Queue status, Page Buffer status, and overall Write State Machine (WSM) status.
- 32 Block Status Registers (BSRs) which provide block-specific status information such as the block lock-bit status.

The GSR and BSR memory maps are shown in Figure 4.

The 28F016XD incorporates an open drain RY/BY# output pin. This feature allows the user to OR-tie many RY/BY# pins together in a multiple memory configuration such as a Resident Flash Array. The RY/BY# pin employs five distinct configurations, which are enabled via special CUI commands and are described in detail in the 16-Mbit Flash Product Family User's Manual.

The 28F016XD's enhanced Upload Device Information command provides access to additional information that the 28F016SA previously did not offer. This command uploads the Device Revision Number, Device Proliferation Code and Device Configuration Code. The Device Proliferation Code for the 28F016XD is 04H, and the Device Configuration Code identifies the current RY/BY# configuration. Section 4.3 documents the exact page buffer address locations for all uploaded information. A subsequent Page Buffer Swap and Page Buffer Read command sequence is necessary to read the correct device information.

The 28F016XD is specified for a maximum fast page mode cycle time of 65 ns ( $t_{PC,R}$ ) at 5.0V operation (4.75V to 5.25V) over the commercial temperature range (0°C to +70°C). A corresponding maximum fast page mode cycle time of 75 ns at 3.3V (3.0V to 3.6V and 0°C to +70°C) is achieved for reduced power consumption applications.

The 28F016XD incorporates an Automatic Power Saving (APS) feature, which substantially reduces the active current when the device is in static mode of operation (addresses not switching). In APS mode, the typical I<sub>CC</sub> current is 1 mA at 5.0V (3.0 mA at 3.3V).

A deep power-down mode of operation is invoked when the RP# (called PWD# on the 28F008SA) pin transitions low. This mode brings the device power consumption to less than 2.0  $\mu$ A, typically, and provides additional write protection by acting as a device reset pin during power transitions. A reset time of 300 ns (5.0V V<sub>CC</sub> operation) is required from RP# switching high until dropping RAS#. In the Deep Power-Down state, the WSM is reset (any current operation will abort) and the CSR, GSR and BSR registers are cleared.

A CMOS standby mode of operation is enabled when RAS# and CAS# transition high and RP# stays high with all input control pins at CMOS levels. In this mode, the device typically draws an  $I_{CC}$  standby current of 70  $\mu$ A at 5V  $V_{CC}$ .





Figure 1. 28F016XD Block Diagram
Architectural Evolution Includes Multiplexed Address Bus, SmartVoltage
Technology, Page Buffers, Queue Registers and Extended Registers



The 28F016XD is available in a 56-Lead, 1.2mm thick, 14mm x 20mm TSOP Type I package. This form factor and pinout allow for very high board layout densities.

### 2.0 DEVICE PINOUT

The 28F016XD 56-Lead TSOP Type I pinout configuration is shown in Figure 2.



Figure 2. 28F016XD 56-Lead TSOP Type I Pinout Configuration



# 2.1 Lead Descriptions

| Symbol                            | Туре                 | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>9</sub>    | INPUT                | MULTIPLEXED ROW/COLUMN ADDRESSES: Selects a word within one of thirty-two 32-Kword blocks. Row (upper) addresses are latched on the falling edge of RAS#, while column (lower) addresses are latched on the falling edge of CAS#.                                                                                                                                                                                                                                                                                                                                |
| DQ <sub>0</sub> -DQ <sub>15</sub> | INPUT/OUTPUT         | <b>DATA BUS:</b> Inputs data and commands during CUI write cycles. Outputs array, buffer, identifier or status data ( $DQ_{0-7}$ ) in the appropriate read mode. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                                                                                                                                                                                                               |
| RAS#                              | INPUT                | <b>ROW ADDRESS STROBE:</b> Latches row address information on inputs A <sub>9-0</sub> when RAS# transitions low. A subsequent CAS# low transition initiates 28F016XD read or write operations.                                                                                                                                                                                                                                                                                                                                                                   |
| CAS#                              | INPUT                | COLUMN ADDRESS STROBE: Latches column address information on inputs A <sub>9-0</sub> when CAS# transitions low. When preceded by a RAS# low transition, CAS# low initiates 28F016XD Read or Write operations, along with OE# and WE#. Subsequent CAS# low transitions, with RAS# held low, enable fast page mode reads/writes.                                                                                                                                                                                                                                   |
| RP#                               | INPUT                | RESET/POWER-DOWN: RP# low places the device in a Deep Power-Down state. All circuits that consume static power, even those circuits enabled in standby mode, are turned off. When returning from Deep Power-Down, a recovery time of 300 ns at 5.0V V <sub>CC</sub> is required to allow these circuits to power-up.  When RP# goes low, any current or pending WSM operation(s) are terminated, and the device is reset. All Status Registers return to ready (with all status flags cleared).  Exit from Deep Power-Down places the device in read array mode. |
| OE#                               | INPUT                | OUTPUT ENABLE: Gates device data through the output buffers when low in combination with RAS# and CAS# low. The outputs float to tristate off when OE# is high. OE# can be tied to GND if not controlled by the system memory controller. RAS# and CAS# high override OE# low. WE# low also overrides OE# low.                                                                                                                                                                                                                                                   |
| WE#                               | INPUT                | WRITE ENABLE: Controls access to the CUI, Page Buffers, Data Queue Registers and Address Queue Latches. WE# is active low and initiates writes in combination with RAS# and CAS# low. WE# low overrides OE# low. RAS# and CAS# high override WE# low.                                                                                                                                                                                                                                                                                                            |
| RY/BY#                            | OPEN DRAIN<br>OUTPUT | READY/BUSY: Indicates status of the internal WSM. When low, it indicates that the WSM is busy performing an operation. RY/BY# floating indicates that the WSM is ready for new operations (or WSM has completed all pending operations), or Erase is Suspended, or the device is in deep power-down mode. This output is always active (i.e., not floated to tri-state off when OE#, RAS# or CAS# are high), except if a RY/BY# Pin Disable command is issued.                                                                                                   |
| WP#                               | INPUT                | WRITE PROTECT: Erase blocks can be locked by writing a nonvolatile lock-bit for each block. When WP# is low, those locked blocks as reflected by the Block-Lock Status bits (BSR.6), are protected from inadvertent Data Writes or Erases. When WP# is high, all blocks can be written or erased regardless of the state of the lock-bits. The WP# input buffer is disabled when RP# transitions low (deep power-down mode).                                                                                                                                     |



## 2.1 Lead Descriptions (Continued)

| Symbol          | Туре   | Name and Function                                                                                                                                                                                                                                                                                                          |
|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>PP</sub> | SUPPLY | WRITE/ERASE POWER SUPPLY (12.0V $\pm$ 0.6V, 5.0V $\pm$ 0.5V): For erasing memory array blocks or writing words/pages into the flash array. V <sub>PP</sub> = 5.0V $\pm$ 0.5V eliminates the need for a 12V converter, while connection to 12.0V $\pm$ 0.6V maximizes Write/Erase Performance.                              |
|                 |        | NOTE:                                                                                                                                                                                                                                                                                                                      |
|                 |        | Write and Erase attempts are inhibited with V <sub>PP</sub> at or below 1.5V. Write and Erase attempts with V <sub>PP</sub> between 1.5V and 4.5V, between 5.5V and 11.4V, and above 12.6V produce spurious results and should not be attempted.                                                                           |
| V <sub>CC</sub> | SUPPLY | <b>DEVICE POWER SUPPLY (3.3V</b> $\pm$ <b>0.3V, 5.0V</b> $\pm$ <b>0.5V):</b> Internal detection configures the device for 3.3V or 5.0V operation. To switch 3.3V to 5.0V (or vice versa), first ramp V <sub>CC</sub> down to GND, and then power to the new V <sub>CC</sub> voltage. Do not leave any power pins floating. |
| GND             | SUPPLY | GROUND FOR ALL INTERNAL CIRCUITRY: Do not leave any ground pins floating.                                                                                                                                                                                                                                                  |
| NC              |        | NO CONNECT: No internal connection to die, lead may be driven or left floating.                                                                                                                                                                                                                                            |



### 3.0 MEMORY MAPS

| A <sub>[1</sub> | 9-01 |
|-----------------|------|
|-----------------|------|

| 19-01          |                |     |
|----------------|----------------|-----|
| FFFFF<br>F8000 | 32-Kword Block | 31  |
| F7FFF<br>F0000 | 32-Kword Block | 30  |
| EFFFF<br>E8000 | 32-Kword Block | 29  |
| E7FFF<br>E0000 | 32-Kword Block | 28  |
| DFFFF<br>D8000 | 32-Kword Block | 27  |
| D7FFF<br>D0000 | 32-Kword Block | 26  |
| CFFFF<br>C8000 | 32-Kword Block | 25  |
| C7FFF          | 32-Kword Block | 24  |
| BFFFF          | 32-Kword Block | 23  |
| B8000<br>B7FFF | 32-Kword Block | 22  |
| B0000<br>A8FFF | 32-Kword Block | 21  |
| A8000<br>A7FFF | 32-Kword Block | 20  |
| A0000<br>9FFFF | 32-Kword Block | 19  |
| 98000<br>97FFF | 32-Kword Block | 18  |
| 90000<br>8FFFF | 32-Kword Block | 17  |
| 88000<br>87FFF | 32-Kword Block | 16  |
| 80000<br>7FFFF | 32-Kword Block | 15  |
| 78000<br>77FFF |                |     |
| 70000<br>6FFFF | 32-Kword Block | 14  |
| 68000<br>67FFF | 32-Kword Block | 13  |
| 60000<br>5FFFF | 32-Kword Block | 12  |
| 58000<br>57FFF | 32-Kword Block | 11  |
| 50000<br>4FFFF | 32-Kword Block | 10  |
| 48000<br>47FFF | 32-Kword Block | 9   |
| 40000<br>3FFFF | 32-Kword Block | 8   |
| 38000          | 32-Kword Block | 7   |
| 37FFF<br>30000 | 32-Kword Block | - 6 |
| 2FFFF<br>28000 | 32-Kword Block | 5   |
| 27FFF<br>20000 | 32-Kword Block | 4   |
| 1FFFF<br>18000 | 32-Kword Block | 3   |
| 17FFF<br>10000 | 32-Kword Block | 2   |
| 08000          | 32-Kword Block | 1   |
| 07FFF<br>00000 | 32-Kword Block | 0   |
|                |                |     |

290533-3

#### NOTE:

The upper 10 bits  $(A_{19-10})$  reflect 28F016XD addresses  $A_{9-0}$ , latched by RAS#. The lower 10 bits  $(A_{9-0})$  reflect 28F016XD addresses  $A_{9-0}$ , latched by CAS#.

Figure 3. 28F016XD Memory Map



## 3.1 Extended Status Registers Memory Map



Figure 4. Extended Status Register Memory Map



### 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS

### 4.1 Bus Operations

| Mode                 | Notes | RP#             | RAS#            | CAS#            | OE#             | WE#             | DQ <sub>0-15</sub> | RY/BY#          |
|----------------------|-------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|-----------------|
| Row Address Latch    | 1,2,9 | V <sub>IH</sub> | ↓               | V <sub>IH</sub> | Х               | Х               | Х                  | Х               |
| Column Address Latch | 1,2,9 | V <sub>IH</sub> | V <sub>IL</sub> | 1               | X               | ·X              | ×                  | X               |
| Read                 | 1,2,7 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | D <sub>OUT</sub>   | Х               |
| Output Disable       | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | High Z             | Х               |
| Standby              | 1,6,7 | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | ×               | X               | High Z             | Х               |
| Deep Power-Down      | 1,3   | V <sub>IL</sub> | Х               | Х               | X               | Х               | High Z             | V <sub>OH</sub> |
| Manufacturer ID      | 4,8   | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | VIL             | V <sub>IH</sub> | 0089H              | V <sub>OH</sub> |
| Device ID            | 4,8   | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | 66A8H              | V <sub>OH</sub> |
| Write                | 1,5,6 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>JL</sub> | Х               | V <sub>IL</sub> | D <sub>IN</sub>    | Х               |

- X can be V<sub>IH</sub> or V<sub>IL</sub> for address or control pins except for RY/BY#, which is either V<sub>OL</sub> or V<sub>OH</sub>, or High Z or D<sub>OUT</sub> for data pins depending on whether or not OE# is active.
- RY/BY# output is open drain. When the WSM is ready, Erase is suspended or the device is in deep power-down mode, RY/BY# will be at V<sub>OH</sub> if it is tied to V<sub>CC</sub> through a resistor. RY/BY# at V<sub>OH</sub> is independent of OE# while a WSM operation is in progress.
- 3. RP# at GND ± 0.2V ensures the lowest deep power-down current.
- 4. A<sub>0</sub> (latched by CAS#) at V<sub>IL</sub> provides the Manufacturer ID code. A<sub>0</sub> (latched by CAS#) at V<sub>IH</sub> provides the Device ID code. All other addresses (row and column) should be set to zero.
- Commands for Erase, Data Write, or Lock-Block operations can only be completed successfully when V<sub>PP</sub> = V<sub>PPH2</sub> or V<sub>PP</sub> = V<sub>PPH2</sub>.
- While the WSM is running, RY/BY# in level-mode (default) stays at V<sub>OL</sub> until all operations are complete. RY/BY# goes
  to V<sub>OH</sub> when the WSM is not busy or in erase suspend mode.
- RY/BY# may be at V<sub>OL</sub> while the WSM is busy performing various operations. For example, a Status Register read during a Write operation.
- 8. The 28F016XD shares an identical device identifier with other Intel Flash memories. Reading this identifier in conjunction with the unique Device Proliferation Code (read from the Page Buffer after writing the Upload Device Configuration command) allows unique identification of the 28F016XD by system software.
- 9. Row (upper) addresses are latched via inputs A<sub>0-9</sub> on the falling edge of RAS#. Column (lower) addresses are latched via inputs A<sub>0-9</sub> on the falling edge of CAS#. Row addresses must be latched before column addresses are latched.



### 4.2 28F008SA—Compatible Mode Command Bus Definitions

| Command                         | Notes  | Fir   | st Bus Cy | cle  | Second Bus Cycle |      |      |
|---------------------------------|--------|-------|-----------|------|------------------|------|------|
|                                 | 110100 | Oper  | Addr      | Data | Oper             | Addr | Data |
| Read Array                      |        | Write | Х         | FFH  | Read             | AA   | AD   |
| Intelligent Identifier          | 1      | Write | Х         | 90H  | Read             | IA   | ID   |
| Read Compatible Status Register | 2      | Write | Х         | 70H  | Read             | Х    | CSRD |
| Clear Status Register           | 3      | Write | Х         | 50H  |                  |      |      |
| Word/Byte Write                 |        | Write | Х         | 40H  | Write            | WA   | WD   |
| Alternate Word/Byte Write       |        | Write | Х         | 10H  | Write            | WA   | WD   |
| Block Erase/Confirm             |        | Write | х         | 20H  | Write            | ВА   | D0H  |
| Erase Suspend/Resume            |        | Write | Х         | вон  | Write            | Х    | DOH  |

#### **ADDRESS**

AA = Array Address BA = Block Address IA = Identifier Address

WA = Write Address

X = Don't Care

### DATA

AD = Array Data CSRD = CSR Data ID = Identifier Data WD = Write Data

- 1. Following the Intelligent Identifier command, two Read operations access the manufacturer and device signature codes.
- 2. The CSR is automatically available after device enters Data Write, Erase, or Suspend operations.
- Clears CSR.3, CSR.4 and CSR.5. Also clears GSR.5 and all BSR.5, BSR.4 and BSR.2 bits. See Status Register definitions.



## 4.3 28F016XD—Performance Enhancement Command Bus Definitions

| Command                              | Notes   | Firs  | t Bus C | ycle | Second Bus Cycle |      |              | Third Bus Cycle |      |      |
|--------------------------------------|---------|-------|---------|------|------------------|------|--------------|-----------------|------|------|
| · ·                                  | Notes   | Oper  | Addr    | Data | Oper             | Addr | Data         | Oper            | Addr | Data |
| Read Extended<br>Status Register     | -1      | Write | Х       | 71H  | Read             | RA   | GSRD<br>BSRD |                 |      |      |
| Page Buffer Swap                     | 6       | Write | Х       | 72H  |                  |      |              |                 |      |      |
| Read Page Buffer                     |         | Write | Х       | 75H  | Read             | PA   | PD           |                 |      |      |
| Single Load to Page Buffer           |         | Write | Х       | 74H  | Write            | PA   | PD           |                 |      |      |
| Sequential Load to<br>Page Buffer    | 3,4,5,9 | Write | Х       | E0H  | Write            | Х    | WCL          | Write           | X    | WCH  |
| Page Buffer Write to Flash           | 3,4,9   | Write | X       | 0CH  | Write            | Х    | WCL          | Write           | WA   | WCH  |
| Lock Block/Confirm                   |         | Write | Х       | 77H  | Write            | ВА   | D0H          |                 |      |      |
| Upload Status<br>Bits/Confirm        | 2       | Write | Х       | 97H  | Write            | Х    | D0H          |                 |      |      |
| Upload Device<br>Information/Confirm | 10      | Write | Х       | 99H  | Write            | Х    | D0H          |                 |      |      |
| Erase All Unlocked<br>Blocks/Confirm |         | Write | Х       | A7H  | Write            | Х    | D0H          |                 |      |      |
| RY/BY# Enable to<br>Level-Mode       | 7       | Write | X       | 96H  | Write            | Х    | 01H          |                 |      |      |
| RY/BY#<br>Pulse-On-Write             | 7       | Write | ×       | 96H  | Write            | х    | 02H          |                 |      | ,    |
| RY/BY#<br>Pulse-On-Erase             | 7       | Write | Х       | 96H  | Write            | Х    | 03H          |                 |      |      |
| RY/BY# Disable                       | 7       | Write | Х       | 96H  | Write            | Х    | 04H          |                 | ,    |      |
| RY/BY# Pulse-On-<br>Write/Erase      | 7       | Write | Х       | 96H  | Write            | Х    | 05H          |                 |      |      |
| Sleep                                |         | Write | Х       | F0H  |                  |      |              |                 |      |      |
| Abort                                |         | Write | Х       | 80H  |                  |      |              |                 | }    |      |

### **ADDRESS**

BA = Block Address

PA = Page Buffer Address

RA = Extended Register Address

WA = Write Address

X = Don't Care

### DATA

AD = Array Data

PD = Page Buffer Data

BSRD = BSR Data

GSRD = GSR Data

WC (L,H) = Word Count (Low, High)

WD (L,H) = Write Data (Low, High)



#### NOTES:

- 1. RA can be the GSR address or any BSR address. See Figure 4 for the Extended Status Register memory map.
- Upon device power-up, all BSR lock-bits come up locked. The Upload Status Bits command must be written to reflect the actual lock-bit status.
- WCH must be at 00H for this product because of the 128-word Page Buffer size, and to avoid writing the Page Buffer contents to more than one 128-word segment within an array block. They are simply shown for future Page Buffer expandability.
- 4. Only the lower byte  $DQ_{0-7}$  is used for WCL and WCH. The upper byte  $DQ_{8-15}$  is a don't care.
- 5. PA and PD (whose count is given in cycles 2 and 3) are supplied starting in the fourth cycle, which is not shown.
- 6. This command allows the user to swap between available Page Buffers (0 or 1).
- 7. These commands reconfigure RY/BY# output to one of three pulse-modes or enable and disable the RY/BY# function.
- 8. Write address, WA, is the Destination address in the flash array which must match the Source address in the Page Buffer. Refer to the 16-Mbit Flash Product Family User's Manual.
- 9. WCL = 00H corresponds to a word count of 1.
- 10. After writing the Upload Device Information command and the Confirm command, the following information is output at Page Buffer addresses specified below:

| Row Address | Column Address            | Information                     |
|-------------|---------------------------|---------------------------------|
| 00H         | 03H                       | Device Revision Number          |
| 00H         | 0FH (DQ <sub>0-7</sub> )  | Device Configuration Code       |
| 00H         | 0FH (DQ <sub>8-15</sub> ) | Device Proliferation Code (04H) |

A Page Buffer Swap followed by a Page Buffer Read sequence is necessary to access this information. The contents of all other Page Buffer locations, after the Upload Device Information command is written, are reserved for future implementation by Intel Corporation. See Section 4.7 for a description of the Device Configuration Code. This code also corresponds to data written to the 28F016XD after writing the RY/BY# Configuration command.



## 4.4 Compatible Status Register

| WSMS | ESS | ES | DWS | VPPS | R | R | R |
|------|-----|----|-----|------|---|---|---|
| 7    | 6   | 5  | 4   | 3    | 2 | 1 | 0 |

#### NOTES:

CSR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

RY/BY# output or WSMS bit must be checked to determine completion of an operation (Erase, Erase Suspend, or Data Write) before the appropriate Status bit (ESS, ES or DWS) is checked for success.

CSR.6 = ERASE-SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

CSR.5 = ERASE STATUS

1 = Error In Block Erasure

0 = Successful Block Erase

CSR.4 = DATA-WRITE STATUS

1 = Error in Data Write

0 = Data Write Successful

 $CSR.3 = V_{PP} STATUS$ 

1 = V<sub>PP</sub> Error Detect, Operation Abort

 $0 = V_{PP} OK$ 

If DWS and ES are set to "1" during an erase attempt, an improper command sequence was entered. Clear the CSR and attempt the operation again.

The VPPS bit, unlike an A/D converter, does not provide continuous indication of  $V_{PP}$  level. The WSM interrogates  $V_{PP}$ 's level only after the Data Write or Erase command sequences have been entered, and informs the system if  $V_{PP}$  has not been switched on. VPPS is not guaranteed to report accurate feedback between  $V_{PPLE}(\text{max})$  and  $V_{PPH1}(\text{min})$ , between  $V_{PPH1}(\text{max})$  and  $V_{PPH2}(\text{min})$  and above  $V_{PPH2}(\text{max})$ .

CSR.2-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the CSR.



### 4.5 Global Status Register

| WSMS | oss | DOS | DSS | QS  | PBAS | PBS | PBSS |
|------|-----|-----|-----|-----|------|-----|------|
| 7    | 6   | 5   | 4   | 3 . | 2    | 1   | 0    |

#### GSR.7 = WRITE STATE MACHINE STATUS

- 1 = Ready
- 0 = Busv

[1] RY/BY# output or WSMS bit must be checked to determine completion of an operation (Block Lock, Suspend, any RY/BY# reconfiguration, Upload Status Bits, Erase or Data Write) before the appropriate Status bit (OSS or DOS) is checked for success.

#### GSR.6 = OPERATION SUSPEND STATUS

- 1 = Operation Suspended
- 0 = Operation in Progress/Completed

#### GSR.5 = DEVICE OPERATION STATUS

- 1 = Operation Unsuccessful
- 0 = Operation Successful or Currently Running

#### GSR.4 = DEVICE SLEEP STATUS

- 1 = Device in Sleep
- 0 = Device Not in Sleep

### MATRIX 5/4

- 0 0 = Operation Successful or Currently
  - Running
- 0 1 = Device in Sleep mode or Pending
  - Sleep
- 10 = Operation Unsuccessful
- 1 1 = Operation Unsuccessful or
  - Aborted

If operation currently running, then GSR.7 = 0.

If device pending sleep, then GSR.7 = 0.

Operation aborted: Unsuccessful due to Abort

### **GSR.3 = QUEUE STATUS**

- 1 = Queue Full
- 0 = Queue Available

### GSR.2 = PAGE BUFFER AVAILABLE STATUS

- 1 = One or Two Page Buffers Available
- 0 = No Page Buffer Available

The device contains two Page Buffers.

- GSR.1 = PAGE BUFFER STATUS
  - 1 = Selected Page Buffer Ready
  - 0 = Selected Page Buffer Busy
- GSR.0 = PAGE BUFFER SELECT STATUS
  - 1 = Page Buffer 1 Selected
  - 0 = Page Buffer 0 Selected

Selected Page Buffer is currently busy with WSM

### NOTE:

 When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.

command.

operation



### 4.6 Block Status Register

| BS | BLS | BOS | BOAS | QS | VPPS | VPPL | R |
|----|-----|-----|------|----|------|------|---|
| 7  | 6   | 5   | 4    | 3  | 2    | 1    | 0 |

BSR.7 = BLOCK STATUS

1 = Ready

0 = Busy

**NOTES:** 

[1] RY/BY# output or BS bit must be checked to determine completion of an operation (Block Lock, Suspend, Erase or Data Write) before the appropriate Status bits (BOS, BLS) is checked for success.

BSR.6 = BLOCK LOCK STATUS

1 = Block Unlocked for Write/Erase

0 = Block Locked for Write/Erase

BSR.5 = BLOCK OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

BSR.4 = BLOCK OPERATION ABORT STATUS

1 = Operation Aborted

0 = Operation Not Aborted

The BOAS bit will not be set until BSR.7 = 1.

MATRIX 5/4

0 0 = Operation Successful or

Currently Running

0 1 = Not a Valid Combination

1 0 = Operation Unsuccessful

1 1 = Operation Aborted

Operation halted via Abort command.

BSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

BSR.2 = Vpp STATUS

1 = V<sub>PP</sub> Error Detect, Operation Abort

 $0 = V_{PP} OK$ 

BSR.1 = VPP LEVEL

 $1 = V_{PP}$  Detected at 5.0V  $\pm$  10%

 $0 = V_{PP}$  Detected at 12.0V  $\pm$  5%

BSR.1 is not guaranteed to report accurate feedback between the V<sub>PPH1</sub> and V<sub>PPH2</sub> voltage ranges. Writes and erases with V<sub>PP</sub> between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub> (min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min), and above V<sub>PPH2</sub>(max) produce spurious results and should not be attempted.

BSR.1 was a RESERVED bit on the 28F016SA.

BSR.0 = RESERVED FOR FUTURE ENHANCEMENTS

This bit is reserved for future use; mask it out when polling the BSRs.

#### NOTE:

 When multiple operations are queued, checking BSR.7 only provides indication of completion or that particular block. GSR.7 provides indication when all queued operations are completed.



## 4.7 Device Configuration Code

| R | R | R | R | R | RB2 | RB1 | RB0 |
|---|---|---|---|---|-----|-----|-----|
| 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |

#### NOTES:

should not be used.

Undocumented combinations of RB2-RB0 are reserved by Intel Corporation for future implementations and

 ${\tt DCC.2-DCC.0} = {\tt RY/BY\#CONFIGURATION}$ 

(RB2-RB0)

001 = Level Mode (Default)

010 = Pulse-On-Write

011 = Pulse-On-Erase

100 = RY/BY# Disabled

101 = Pulse-On-Write/Erase

these bits to "0" when writing the desired RY/BY# configuration to the device.

These bits are reserved for future use; mask them out when reading the Device Configuration Code. Set

DCC.7-DCC.3 = RESERVED FOR FUTURE ENHANCEMENTS



#### 5.0 ELECTRICAL SPECIFICATIONS

#### 5.1 Absolute Maximum Ratings\*

Temperature Under Bias ............0°C to +80°C Storage Temperature .......-65°C to +125°C NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### $V_{CC} = 3.3V \pm 0.3V \text{ Systems}^{(5)}$

| Symbol            | Parameter                                                                          | Notes | Min  | Max                      | Units | Test Conditions     |
|-------------------|------------------------------------------------------------------------------------|-------|------|--------------------------|-------|---------------------|
| TA                | Operating Temperature, Commercial                                                  | 1     | 0    | 70                       | °C    | Ambient Temperature |
| V <sub>CC</sub> , | , V <sub>CC</sub> with Respect to GND                                              |       | -0.2 | 7.0                      | ٧     |                     |
| V <sub>PP</sub>   | V <sub>PP</sub> Supply Voltage with Respect to GND                                 | 2,3   | -0.2 | 14.0                     | ٧     |                     |
| ٧                 | Voltage on any Pin (except V <sub>CC</sub> , V <sub>PP</sub> ) with Respect to GND |       | -0.5 | V <sub>CC</sub><br>+ 0.5 | ٧     | ,                   |
| ı                 | Current into any Non-Supply Pin                                                    |       |      | ±30                      | . mA  |                     |
| lout              | Output Short Circuit Current                                                       | 4     |      | 100                      | mA    |                     |

#### $V_{CC} = 5.0V \pm 0.5V \text{ Systems}^{(5)}$

| Symbol          | Parameter                                                            | Notes | Min  | Max  | Units    | Test Conditions     |
|-----------------|----------------------------------------------------------------------|-------|------|------|----------|---------------------|
| TA              | Operating Temperature, Commercial                                    | 1     | 0    | 70   | °C       | Ambient Temperature |
| Vcc             | V <sub>CC</sub> with Respect to GND                                  | 2     | -0.2 | 7.0  | . V      |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                   | 2,3   | -0.2 | 14.0 | ٧        |                     |
| V               | Voltage on any Pin (except $V_{CC}$ , $V_{PP}$ ) with Respect to GND | 2     | -2.0 | 7.0  | <b>V</b> | ,                   |
| I               | Current into any Non-Supply Pin                                      |       |      | ±30  | mA       |                     |
| lout            | Output Short Circuit Current                                         | 4     |      | 1Ò0  | mA       | ·                   |

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC}$  + 0.5V which, during transitions, may overshoot to  $V_{CC}$  + 2.0V for periods <20 ns.
- 3. Maximum DC voltage on  $V_{PP}$  may overshoot to +14.0V for periods <20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.



## 5.2 Capacitance

## For a 3.3V ± 0.3V System:

| Symbol            | Parameter                                                       | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-----------------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                 | 1     | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin                       | 1     | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing Specifications | 1,2   |     | 50  | pF    |                                          |

#### For 5.0V $\pm$ 0.5V System:

| Symbol            | Parameter                                                       | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-----------------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                 | 1     | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin                       | 1     | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing Specifications | 1,2   |     | 100 | pF    | ,                                        |

- 1. Sampled, not 100% tested.
- 2. Intel is currently developing more accurate models for the Transient Equivalent Testing Load Circuits. For more information or to obtain iBIS models, please contact your local Intel/Distribution Sales Office.



### 5.3 Transient Input/Output Reference Waveforms



Figure 5. Transient Input/Output Reference Waveform for  $V_{CC} = 5.0V \pm 0.5V(1)$ 



Figure 6. Transient Input/Output Reference Waveform for  $V_{CC} = 3.3V \pm 0.3V(2)$ 

- 1. Testing characteristics for 28F016XD-85.
- 2. Testing characteristics for 28F016XD-95.



**5.4 DC Characteristics**  $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol                       | Parameter                                              | Notes | Min | Тур | Max  | Unit | Test Condition                                                                                                                                                                                                                         |
|------------------------------|--------------------------------------------------------|-------|-----|-----|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| lcc1                         | V <sub>CC</sub> Word Read<br>Current                   | 1,4,5 |     | 50  | 70   | mA   | $\begin{split} &V_{CC} = V_{CC} \text{ Max} \\ &RAS\#, CAS\# = V_{IL} \\ &RAS\#, CAS\#, Addr. \ Cycling @ \\ &t_{RC} = min \\ &I_{OUT} = 0 \ mA \\ &Inputs = TTL \ or \ CMOS \end{split}$                                              |
| l <sub>CC</sub> <sup>2</sup> | V <sub>CC</sub> Standby Current                        | 1,5   | `   | 1   | 4    | mA   | $V_{CC} = V_{CC} Max$<br>RAS#, CAS#, RP# = $V_{IH}$<br>WP# = $V_{IL}$ or $V_{IH}$                                                                                                                                                      |
| I <sub>CC</sub> 3            | V <sub>CC</sub> RAS#-Only<br>Refresh Current           | 1,5   |     | 50  | 70   | mA   | $\begin{split} &V_{CC} = V_{CC} \text{ Max} \\ &\text{CAS} \# = V_{IH} \\ &\text{RAS} \# = V_{IL} \\ &\text{RAS} \#, \text{Addr. Cycling @ $t_{RC}$} = \text{min} \\ &\text{Inputs} = \text{TTL or CMOS} \end{split}$                  |
| lcc <sup>4</sup>             | V <sub>CC</sub> Fast Page Mode<br>Word Read Current    | 1,4,5 |     | 40  | 60   | mA   | $\begin{split} &V_{CC} = V_{CC} \text{ Max} \\ &\text{RAS}\#, \text{CAS}\# = V_{IL} \\ &\text{CAS}\#, \text{Addr. Cycling } @t_{PC} = \text{min} \\ &I_{OUT} = 0 \text{ mA} \\ &\text{Inputs} = V_{IL} \text{ or } V_{IH} \end{split}$ |
| l <sub>CC</sub> <sup>5</sup> | V <sub>CC</sub> Standby Current                        | 1,5   |     | 70  | 130  | μΑ   | $V_{CC} = V_{CC} Max$<br>RAS# CAS# RP# = $V_{CC} \pm 0.2V$<br>WP# = $V_{CC} \pm 0.2V$ or GND $\pm 0.2V$                                                                                                                                |
| ICC <sup>6</sup>             | V <sub>CC</sub> CAS#-Before-<br>RAS# Refresh Current   | 1,5   |     | 40  | 55   | mA   | $V_{CC} = V_{CC}$ Max $CAS\#$ , $RAS\# = V_{IL}$ $CAS\#$ , $RAS\#$ , $Addr$ . Cycling @ $t_{RC} = min$ Inputs = TTL or CMOS                                                                                                            |
| lcc <sup>7</sup>             | V <sub>CC</sub> Standby Current<br>(Self Refresh Mode) | 1,5   |     | 40  | 55   | mA   | $\begin{split} &V_{CC} = V_{CC} \text{ Max} \\ &\text{RAS}\#, \text{CAS}\# = V_{\text{IL}} \\ &\text{I}_{\text{OUT}} = 0 \text{ mA} \\ &\text{Inputs} = V_{\text{IL}} \text{ or } V_{\text{IH}} \end{split}$                           |
| L                            | Input Load Current                                     | 1     |     |     | ± 1  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                      |
| lLO                          | Output Leakage<br>Current                              | 1     |     |     | ± 10 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                                                                                                                                                                     |
| ICCD                         | V <sub>CC</sub> Deep Power-Down<br>Current             | 1     |     | 2   | 5    | μΑ   | $RP\# = GND \pm 0.2V$                                                                                                                                                                                                                  |



# 5.4 DC Characteristics (Continued) $V_{CC} = 3.3V \pm 0.3V$ , $T_A = 0^{\circ}C$ to $+70^{\circ}C$

| Symbol            | Parameter -                                | Notes | Min  | Тур | Max                      | Unit | Test Condition                                          |
|-------------------|--------------------------------------------|-------|------|-----|--------------------------|------|---------------------------------------------------------|
| Iccw              | V <sub>CC</sub> Word Write Current         | 1,6   |      | 8   | 12                       | mA   | Word Write in Progress<br>V <sub>PP</sub> = 12.0V ± 5%  |
|                   | ·                                          | -     |      | 8   | 17                       | mA   | Word Write in Progress $V_{PP} = 5.0V \pm 10\%$         |
| ICCE              | V <sub>CC</sub> Block Erase<br>Current     | 1,6   |      | 6   | 12                       | mA   | Block Erase in Progress<br>V <sub>PP</sub> = 12.0V ± 5% |
|                   |                                            |       |      | 9   | 17                       | mA   | Block Erase in Progress $V_{PP} = 5.0V \pm 10\%$        |
| ICCES             | V <sub>CC</sub> Erase Suspend<br>Current   | 1,2   |      | 1   | 4                        | mA   | RAS#, CAS# = V <sub>IH</sub><br>Block Erase Suspended   |
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby/Read               | 1     |      | ±1  | ±10                      | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                       |
|                   | Current                                    |       |      | 30  | 50                       | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                       |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-Down<br>Current | 1     |      | 0.2 | 5                        | μА   | RP# = GND ± 0.2V                                        |
| IppW              | V <sub>PP</sub> Word Write Current         | 1,6   |      | 10  | 15                       | mA   | V <sub>PP</sub> = 12.0V ± 5%<br>Word Write in Progress  |
|                   |                                            |       |      | 15  | 25                       | mA   | V <sub>PP</sub> = 5.0V ± 10%<br>Word Write in Progress  |
| I <sub>PPE</sub>  | V <sub>PP</sub> Block Erase<br>Current     | 1,6   |      | 4   | 10                       | · mA | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress |
|                   | ·                                          |       |      | 14  | 20                       | mA   | V <sub>PP</sub> = 5.0V ± 10%<br>Block Erase in Progress |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend<br>Current   | 1 .   |      | 30  | 50                       | μΑ   | Block Erase Suspended                                   |
| V <sub>IL</sub>   | Input Low Voltage                          | 6     | -0.3 |     | 0.8                      | ٧    |                                                         |
| V <sub>IH</sub>   | Input High Voltage                         | 6     | 2.0  |     | V <sub>CC</sub><br>+ 0.3 | ٧    |                                                         |



# **5.4 DC Characteristics** (Continued) $V_{CC} = 3.3V \pm 0.3V$ , $T_A = 0$ °C to +70°C

| Symbol                        | Parameter                                        | Notes | Min                     | Тур  | Max  | Unit | Test Condition                                               |
|-------------------------------|--------------------------------------------------|-------|-------------------------|------|------|------|--------------------------------------------------------------|
| V <sub>OL</sub>               | Output Low Voltage                               | 6     |                         |      | 0.4  | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 4.0 mA$                      |
| V <sub>OH1</sub>              | Output High Voltage                              | 6     | 2.4                     |      |      | ٧    | $I_{OH} = -2.0 \text{ mA} \cdot V_{CC} = V_{CC} \text{ Min}$ |
| V <sub>OH2</sub>              |                                                  | 6     | V <sub>CC</sub><br>−0.2 |      |      | ٧    | $I_{OH} = -100 \mu A$ $V_{CC} = V_{CC} Min$                  |
| V <sub>PPLK</sub>             | V <sub>PP</sub> Erase/Write Lock<br>Voltage      | 3,6   | 0.0                     |      | 1.5  | ٧    |                                                              |
| V <sub>PPH</sub> 1            | V <sub>PP</sub> during Write/Erase<br>Operations | 3     | 4.5                     | 5.0  | 5.5  | ٧    |                                                              |
| V <sub>PPH</sub> <sup>2</sup> | V <sub>PP</sub> during Write/Erase<br>Operations | 3     | 11.4                    | 12.0 | 12.6 | ٧    |                                                              |
| V <sub>LKO</sub>              | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.0                     |      |      | ٧    |                                                              |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 3.3V, V<sub>PP</sub> = 12.0V or 5.0V, T = 25°C. These currents are valid for all product speed versions.
- 2. I<sub>CCES</sub> is specified with the device de-selected. If the device is read while in Erase Suspend mode, current draw is the sum of ICCES and ICC1/ICC4.
- 3. Block erases, word writes and lock block operations are inhibited when V<sub>PP</sub> = V<sub>PPLK</sub> and not guaranteed in the ranges between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min), and above V<sub>PPH2</sub>(max).

  4. Automatic Power Saving (APS) reduces I<sub>CC1</sub> and I<sub>CC4</sub> to 3.0 mA typical in static operation.

  5. CMOS inputs are either V<sub>CC</sub> ± 0.2V or GND ± 0.2V. TTL inputs are either V<sub>IL</sub> or V<sub>IH</sub>.

  6. Sampled, but not 100% tested. Guaranteed by design.



5.5 DC Characteristics  $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol                       | Parameter                                              | Notes | Min | Тур | Max | Unit | Test Condition                                                                                                                                                                                                                                      |
|------------------------------|--------------------------------------------------------|-------|-----|-----|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| lcc <sup>1</sup>             | V <sub>CC</sub> Word Read Current                      | 1,4,5 |     | 90  | 120 | mA   | $\begin{split} &V_{CC} = V_{CC}\text{Max} \\ &\text{RAS\#, CAS\#} = V_{\text{IL}} \\ &\text{RAS\#, CAS\#, Addr. Cycling @} \\ &t_{RC} = \text{min} \\ &t_{OUT} = 0 \text{ mA} \\ &\text{Inputs} = \text{TTL or CMOS} \end{split}$                   |
| I <sub>CC</sub> <sup>2</sup> | V <sub>CC</sub> Standby Current                        | 1,5   |     | 2   | 4   | mA   | $V_{CC} = V_{CC} Max$<br>RAS#, CAS#, RP# = $V_{IH}$<br>WP# = $V_{IL}$ or $V_{IH}$                                                                                                                                                                   |
| lcc <sup>3</sup>             | V <sub>CC</sub> RAS#-Only<br>Refresh Current           | 1,5   |     | 90  | 120 | mA   | $\begin{split} &V_{CC} = V_{CC}\text{Max} \\ &\text{CAS} \# = V_{IH} \\ &\text{RAS} \# = V_{IL} \\ &\text{RAS} \#, \text{Addr. Cycling @ $t_{RC}$} = \text{min} \\ &\text{Inputs} = TTL \text{ or CMOS} \end{split}$                                |
| lcc <sup>4</sup>             | V <sub>CC</sub> Fast Page Mode<br>Word Read Current    | 1,4,5 |     | 80  | 110 | mA   | $\begin{array}{l} V_{CC} = V_{CC}\text{Max} \\ \text{RAS\#, CAS\#} = V_{\text{IL}} \\ \text{CAS\#, Addr. Cycling @ $t_{\text{PC}}$} = \min \\ I_{\text{OUT}} = 0 \text{ mA} \\ \text{Inputs} = V_{\text{IL}} \text{ or } V_{\text{IH}} \end{array}$ |
| lcc <sup>5</sup>             | V <sub>CC</sub> Standby Current                        | 1,5   |     | 70  | 130 | μΑ   | $\begin{aligned} &V_{CC} = V_{CC}Max \\ &RAS\#, CAS\#, RP\# = V_{CC} \pm 0.2V \\ &WP\# = V_{CC} \pm 0.2V or \\ &GND \pm 0.2V \end{aligned}$                                                                                                         |
| lcc <sup>6</sup>             | V <sub>CC</sub> CAS#-Before-<br>RAS# Refresh Current   | 1,5   |     | 50  | 65  | mA   | $\begin{split} &V_{CC} = V_{CC}  \text{Max} \\ &\text{CAS\#, RAS\#} = V_{\text{IL}} \\ &\text{CAS\#, RAS\#, Addr. Cycling} \\ &\text{@}  t_{\text{RC}} = \min \\ &\text{Inputs} = \text{TTL or CMOS} \end{split}$                                   |
| lcc <sup>7</sup>             | V <sub>CC</sub> Standby Current<br>(Self Refresh Mode) | 1,5   |     | 50  | 65  | mA   | $\begin{aligned} & V_{CC} = V_{CC}Max \\ & RAS\#, CAS\# = V_{IL} \\ & I_{OUT} = 0mA \\ & Inputs = V_{IL}orV_{IH} \end{aligned}$                                                                                                                     |
| <u>ել</u>                    | Input Load Current                                     | 1     |     |     | ±1  | μА   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>IN</sub> = V <sub>CC</sub> or GND                                                                                                                                                                   |
| I <sub>LO</sub>              | Output Leakage<br>Current                              | 1     |     |     | ±10 | μΑ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>OUT</sub> = V <sub>CC</sub> or GND                                                                                                                                                                  |
| ICCD                         | V <sub>CC</sub> Deep Power-Down<br>Current             | 1     |     | 2   | 5   | μΑ   | RP# = GND ±0.2V                                                                                                                                                                                                                                     |
| Iccw                         | V <sub>CC</sub> Word Write Current                     | 1,6   |     | 25  | 35  | mA   | Word Write in Progress V <sub>PP</sub> = 12.0V ±5%                                                                                                                                                                                                  |
|                              | * .                                                    | ,     |     | 25  | 40  | mA   | Word Write in Progress V <sub>PP</sub> = 5.0V ±10%                                                                                                                                                                                                  |



# 5.5 DC Characteristics (Continued) $V_{CC} = 5.0V \pm 0.5V$ , $T_A = 0^{\circ}C$ to $+70^{\circ}C$

| Symbol           | Parameter                                  | Notes | Min  | Тур | Max                      | Unit | Test Condition                                          |
|------------------|--------------------------------------------|-------|------|-----|--------------------------|------|---------------------------------------------------------|
| ICCE             | V <sub>CC</sub> Block Erase<br>Current     | 1,6   |      | 18  | 25                       | mA   | Block Erase in Progress $V_{PP} = 12.0V \pm 5\%$        |
|                  |                                            |       |      | 20  | 30                       | mA   | Block Erase in Progress $V_{PP} = 5.0V \pm 10\%$        |
| ICCES            | V <sub>CC</sub> Erase Suspend<br>Current   | 1,2   |      | 2   | 4                        | mA   | RAS#, CAS# = V <sub>IH</sub><br>Block Erase Suspended   |
| IPPS             | V <sub>PP</sub> Standby/Read               | 1     |      | ±1  | ±10                      | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                       |
|                  | Current                                    | *     |      | 30  | 50                       | μΑ   | $V_{PP} > V_{CC}$                                       |
| I <sub>PPD</sub> | V <sub>PP</sub> Deep Power-Down<br>Current | 1     |      | 0.2 | 5                        | μА   | RP# = GND ± 0.2V                                        |
| I <sub>PPW</sub> | V <sub>PP</sub> Word Write Current         | 1,6   |      | 7   | 12                       | mA   | V <sub>PP</sub> = 12.0V ± 5%<br>Word Write in Progress  |
|                  |                                            |       |      | 17  | 22                       | · mA | V <sub>PP</sub> = 5.0V ± 10%<br>Word Write in Progress  |
| IPPE             | V <sub>PP</sub> Block Erase<br>Current     | 1,6   |      | 5   | 10                       | mA   | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress |
|                  |                                            |       |      | 16  | 20                       | mA - | $V_{PP} = 5.0V \pm 10\%$<br>Block Erase in Progress     |
| IPPES            | V <sub>PP</sub> Erase Suspend<br>Current   | 1     |      | 30  | 50                       | μΑ   | Block Erase Suspended                                   |
| V <sub>IL</sub>  | Input Low Voltage                          | 6     | -0.5 |     | 0.8                      | ٧    |                                                         |
| V <sub>IH</sub>  | Input High Voltage                         | 6     | 2.0  |     | V <sub>CC</sub><br>+ 0.5 | ٧    |                                                         |



# **5.5** DC Characteristics (Continued) $V_{CC} = 5.0V \pm 0.5V$ , $T_A = 0^{\circ}C$ to $+70^{\circ}C$

| Symbol                        | Parameter                                        | Notes | Min                     | Тур                                   | Max  | Unit     | Test Condition                                           |
|-------------------------------|--------------------------------------------------|-------|-------------------------|---------------------------------------|------|----------|----------------------------------------------------------|
| V <sub>OL</sub>               | Output Low Voltage                               | 6     | •                       |                                       | 0.45 | ٧        | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                  |
| V <sub>OH1</sub>              | Output High Voltage                              | 6     | 0.85<br>V <sub>CC</sub> |                                       |      | ٧        | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$ |
| V <sub>OH2</sub>              |                                                  | 6     | V <sub>CC</sub><br>−0.4 |                                       |      | <b>V</b> | $I_{OH} = -100 \mu A$ $V_{CC} = V_{CC} Min$              |
| V <sub>PPLK</sub>             | V <sub>PP</sub> Erase/Write Lock<br>Voltage      | 3,6   | 0.0                     |                                       | 1.5  | V        |                                                          |
| V <sub>PPH</sub> 1            | V <sub>PP</sub> during Write/Erase<br>Operations | 3     | 4.5                     | 5.0                                   | 5.5  | ٧        |                                                          |
| V <sub>PPH</sub> <sup>2</sup> | V <sub>PP</sub> during Write/Erase<br>Operations | - 3   | 11.4                    | 12.0                                  | 12.6 | ٧        |                                                          |
| V <sub>LKO</sub>              | V <sub>CC</sub> Erase/Write<br>Lock Voltage      |       | 2.0                     | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ |      | ٧        |                                                          |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V or 5.0V, T = 25°C. These currents are valid for all product speed versions.
- 2. ICCES is specified with the device de-selected. If the device is read while in Erase Suspend mode, current draw is the sum of ICCES and ICC1/ICC4.
- 3. Block erases, word writes and lock block operations are inhibited when Vpp=VppLK and not guaranteed in the ranges between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min), and above V<sub>PPH2</sub>(max).

  4. Automatic Power Saving (APS) reduces I<sub>CC1</sub> and I<sub>CC4</sub> to 1 mA typical in static operation.

  5. CMOS inputs are either V<sub>CC</sub> ± 0.2V or GND ± 0.2V. TTL inputs are either V<sub>IL</sub> or V<sub>IH</sub>.

  6. Sampled, not 100% tested. Guaranteed by design.



# 5.6 AC Characteristics(11) $V_{CC}=3.3V~\pm~0.3V$ , $T_A=0^{\circ}C$ to $+70^{\circ}C$

#### Read, Write, Read-Modify-Write and Refresh Cycles (Common Parameters)

|                  | Versions                                    |       | 28F01 | 6XD-95 | Units |
|------------------|---------------------------------------------|-------|-------|--------|-------|
| Symbol           | Parameter                                   | Notes | Min   | Max    |       |
| t <sub>RP</sub>  | RAS# Precharge Time                         |       | 10    |        | ns    |
| t <sub>CP</sub>  | CAS# Precharge Time                         |       | 15    |        | ns    |
| t <sub>ASR</sub> | Row Address Set-Up Time                     | 9     | 0     |        | ns    |
| t <sub>RAH</sub> | Row Address Hold Time                       | 9     | 15    |        | ns    |
| t <sub>ASC</sub> | Column Address Set-Up Time                  | 9     | 0     |        | ns    |
| t <sub>CAH</sub> | Column Address Hold Time                    | 9     | 20    |        | ns    |
| t <sub>AR</sub>  | Column Address Hold Time Referenced to RAS# | 3,9   | 35    |        | ns    |
| t <sub>RAD</sub> | RAS# to Column Address Delay Time           | 8,9   | 15    | 15     | ns    |
| tCRP             | CAS# to RAS# Precharge Time                 |       | 10    |        | ns    |
| tOED             | OE# to Data Delay                           | 10    | 30    |        | ns    |
| t <sub>DZO</sub> | OE# Delay Time from Data In                 | 10    | 0     |        | ns    |
| t <sub>DZC</sub> | CAS# Delay Time from Data In                | 10    | 0     |        | ns    |
| t <sub>T</sub>   | Transition Time (Rise and Fall)             | 10    | 2     | 4      | ns    |

#### **Read Cycle**

|                     | Versions                        |       | 28F01 | 6XD-95 | Units |
|---------------------|---------------------------------|-------|-------|--------|-------|
| Symbol              | Parameter                       | Notes | Min   | Max    | Omis  |
| t <sub>RC(R)</sub>  | Random Read Cycle Time          |       | 105   |        | ns    |
| t <sub>RAS(R)</sub> | RAS# Pulse Width (Reads)        |       | 95    | ∞      | ns    |
| t <sub>CAS(R)</sub> | CAS# Pulse Width (Reads)        |       | 40    | 8      | ns    |
| t <sub>RCD(R)</sub> | RAS# to CAS# Delay Time (Reads) | 1     | 15    | 55     | ns    |
| t <sub>RSH(R)</sub> | RAS# Hold Time (Reads)          |       | 30    |        | ns    |
| tCSH(R)             | CAS# Hold Time (Reads)          |       | 95    |        | ns    |
| tRAC                | Access Time from RAS#           | 1,8   |       | 95     | ns    |
| tCAC                | Access Time from CAS#           | 1,2   |       | 40     | ns    |
| t <sub>AA</sub>     | Access Time from Column Address | 8     |       | 75     | ns    |
| tOEA                | OE# Access Time                 |       | ,     | 40     | ns    |



# Read Cycle (Continued)

|                  | Versions                                   |       | 28F01 | 6XD-95 | Units |
|------------------|--------------------------------------------|-------|-------|--------|-------|
| Symbol           | Parameter                                  | Notes | Min   | Max    |       |
| t <sub>ROH</sub> | RAS# Hold Time Referenced to OE#           |       | 40    |        | ns    |
| t <sub>RCS</sub> | Read Command Set-Up Time                   |       | 5     |        | ns    |
| t <sub>RCH</sub> | Read Command Hold Time Referenced to CAS#  | 6,10  | 0     |        | ns    |
| t <sub>RRH</sub> | Read Command Hold Time Referenced to RAS#  | 6,10  | 0     |        | ns    |
| t <sub>RAL</sub> | Column Address to RAS# Lead Time           | 9     | 15    |        | ns    |
| t <sub>CAL</sub> | Column Address to CAS# Lead Time           | 9     | 75    |        | ns    |
| t <sub>CLZ</sub> | CAS# to Output in Low-Z                    |       | 0     |        | ns    |
| tон              | Output Data Hold Time                      |       | 0     |        | ns    |
| tоно             | Output Data Hold Time from OE#             |       | 0     |        | ns    |
| toff             | Output Buffer Turn-Off Delay               | 4     |       | 30     | ns    |
| t <sub>OEZ</sub> | Output Buffer Turn Off Delay Time From OE# |       |       | 30     | ns    |
| t <sub>CDD</sub> | CAS# to Data in Delay Time                 |       | 30    |        | ns    |

# Write Cycle

|                     | Versions                                   |       | Versions |      | 28F01 | 6XD-95 | Units |
|---------------------|--------------------------------------------|-------|----------|------|-------|--------|-------|
| Symbol              | Parameter                                  | Notes | Min      | Max  | Omis  |        |       |
| t <sub>RC(W)</sub>  | Random Write Cycle Time                    |       | 90       |      | ns    |        |       |
| t <sub>RAS(W)</sub> | RAS# Pulse Width (Writes)                  |       | 80       | - 00 | ns    |        |       |
| t <sub>CAS(W)</sub> | CAS# Pulse Width (Writes)                  |       | 65       | 8    | ns    |        |       |
| t <sub>RCD(W)</sub> | RAS# to CAS# Delay Time (Writes)           | 1     | 15       | 15   | ns    |        |       |
| t <sub>RSH(W)</sub> | RAS# Hold Time (Writes)                    |       | 65       |      | ns    |        |       |
| t <sub>CSH(W)</sub> | CAS# Hold Time (Writes)                    |       | 80       |      | ns    |        |       |
| twcs                | Write Command Set-Up Time                  | 5     | 0        |      | ns    |        |       |
| twch                | Write Command Hold Time                    |       | 15       |      | ns    |        |       |
| twcR                | Write Command Hold Time Referenced to RAS# | 3     | 30       |      | ns    |        |       |
| t <sub>WP</sub>     | Write Command Pulse Width                  |       | 15       |      | ns    |        |       |
| t <sub>RWL</sub>    | Write Command to RAS# Lead Time            |       | 65       |      | ns    |        |       |
| t <sub>CWL</sub>    | Write Command to CAS# Lead Time            |       | 65       |      | ns    |        |       |
| t <sub>DS</sub>     | Data-In Set-Up Time                        | 7,9   | 0        |      | ns    |        |       |
| t <sub>DH</sub>     | Data-In Hold Time                          | 7,9   | 15       |      | ns    |        |       |
| t <sub>DHR</sub>    | Data-In Hold Time Referenced to RAS#       | 3,9   | 30       |      | ns    |        |       |



## Read-Modify-Write Cycle

| Versions         |                                  |        | 28F016 | Units |       |
|------------------|----------------------------------|--------|--------|-------|-------|
| Symbol           | Parameter                        | Notes  | Min    | Max   | Julio |
| tRWC             | Read-Modify-Write Cycle Time     | 10     | 200    |       | ns    |
| t <sub>RWD</sub> | RAS# to WE# Delay Time           | 5,10   | 125    |       | ns    |
| tcwD             | CAS# to WE# Delay Time           | 5,10   | 70     |       | ns    |
| t <sub>AWD</sub> | Column Address to WE# Delay Time | 5,9,10 | 105    |       | ns    |
| toeh             | OE# Command Hold Time            | 10     | 15     |       | ns    |

## Fast Page Mode Cycle

|                      | Versions                                    |       | 28F01 | Units |    |
|----------------------|---------------------------------------------|-------|-------|-------|----|
| Symbol               | Parameter                                   | Notes | Min   | Max   |    |
| t <sub>PC(R)</sub>   | Fast Page Mode Cycle Time (Reads)           |       | 75    |       | ns |
| t <sub>PC(W)</sub>   | Fast Page Mode Cycle Time (Writes)          |       | 80    |       | ns |
| t <sub>RASP(R)</sub> | RAS# Pulse Width (Reads)                    |       | 95    | ∞     | ns |
| t <sub>RASP(W)</sub> | RAS# Pulse Width (Writes)                   |       | 80    | ∞     | ns |
| t <sub>CPA</sub>     | Access Time from CAS# Precharge             |       |       | 85    | ns |
| t <sub>CPW</sub>     | WE# Delay Time from CAS# Precharge          | 10    | 0     |       | ns |
| t <sub>CPRH(R)</sub> | RAS# Hold Time from CAS# Precharge (Reads)  |       | 75    |       | ns |
| t <sub>CPRH(W)</sub> | RAS# Hold Time from CAS# Precharge (Writes) |       | 80    |       | ns |

## Fast Page Mode Read-Modify-Write Cycle

| Versions |                                             | 28F016 | Units |     |         |
|----------|---------------------------------------------|--------|-------|-----|---------|
| Symbol   | Parameter                                   | Notes  | Min   | Max | J.III.O |
| tPRWC    | Fast Page Mode Read-Modify-Write Cycle Time | 10     | 170   |     | ns      |



# Refresh Cycle

|                  | Versions                                    |       |     | 28F016XD-95 |       |
|------------------|---------------------------------------------|-------|-----|-------------|-------|
| Symbol           | Parameter                                   | Notes | Min | Max         | Units |
| tcsr             | CAS# Set-Up Time (CAS#-Before-RAS# Refresh) | 10    | 10  |             | ns    |
| tCHR             | CAS# Hold Time (CAS#-Before-RAS# Refresh)   | 10    | 10  |             | ns    |
| t <sub>WRP</sub> | WE# Set-Up Time (CAS#-Before-RAS# Refresh)  | 10    | 10  |             | ns    |
| twRH             | WE# Hold Time (CAS#-Before-RAS# Refresh)    | 10    | 10  |             | ns    |
| tRPC             | RAS# Precharge to CAS# Hold Time            | 10    | 10  |             | ns    |
| tRASS            | RAS# Pulse Width (Self-Refresh Mode)        | 10    | . 0 |             | ns    |
| t <sub>RPS</sub> | RAS# Precharge Time (Self-Refresh Mode)     | 10    | 10  |             | ns    |
| tCPN             | CAS# Precharge Time (Self-Refresh Mode)     | 10    | 10  |             | ns    |
| tchs             | CAS# Hold Time (Self-Refresh Mode)          | 10    | 0   |             | ns    |

## Refresh

|                  | Versions       |       | 28F016 | SXD-95   | Units    |
|------------------|----------------|-------|--------|----------|----------|
| Symbol           | Parameter      | Notes | Min    | Max      | - Clinto |
| t <sub>REF</sub> | Refresh Period | 10    |        | <b>∞</b> | ms       |



#### **Miscellaneous Specifications**

| Versions                                                             |       | 28F016XD-95 |     | Units |
|----------------------------------------------------------------------|-------|-------------|-----|-------|
| Parameter                                                            | Notes | Min         | Max | Cinto |
| RP# High to RAS# Going Low                                           | 10    | 480         |     | ns    |
| RP# Set-Up to WE# Going Low                                          | 10    | 480         |     | ns    |
| V <sub>PP</sub> Set-Up to CAS# High at End of Write Cycle            | . 10  | 100         |     | ns    |
| WE# High to RY/BY# Going Low                                         | 10    |             | 100 | ns    |
| RP# Hold from Valid Status Register Data and RY/BY# high             | 10    | 0           |     | ns    |
| V <sub>PP</sub> Hold from Valid Status Register Data and RY/BY# high | 10    | 0           |     | ns    |

- 1. Operation within the t<sub>RCD(max)</sub> limit insures that t<sub>RAC(max)</sub> can be met. t<sub>RCD(max)</sub> is specified as a reference point.
- 2. Assumes that  $t_{RCD} \ge t_{RCD(max)}$
- 3. t<sub>AR</sub>, t<sub>WCR</sub>, t<sub>DHR</sub> are referenced to t<sub>RAD(max)</sub>.
  4. t<sub>OFF(max)</sub> defines the time at which the output achieves the open circuit condition and is not referenced to V<sub>OH</sub> or V<sub>OL</sub>.
- 5. twcs, t<sub>RWD</sub>, t<sub>CWD</sub> and t<sub>AWD</sub> are non restrictive operating parameters. They are included in the datasheet as electrical characteristics only. If t<sub>WCS</sub> ≥ t<sub>WCS(min)</sub> the cycle is an early write cycle and the data output will remain high impedance for the duration of the cycle. If  $t_{CWD} \ge t_{CWD(min)}$ ,  $t_{RWD} \ge t_{RWD(min)}$ ,  $t_{AWD} \ge t_{AWD(min)}$ , then the cycle is a read-write cycle and the data output will contain the data read from the selected address. If neither of the above conditions are satisfied, the condition of the data out is indeterminate.
- 6. Either t<sub>BCH</sub> or t<sub>BBH</sub> must be satisfied for a read cycle.
- 7. These parameters are referenced to the CAS# leading edge in early write cycles and to the WE# leading edge in readwrite cycles.
- 8. Operation within the tRAD(max) limit ensures that tRAC(max) can be met, tRAD(max) is specified as a reference point only. If t<sub>RAD</sub> is greater than the specified t<sub>RAD(max)</sub> limit, then the access time is controlled by t<sub>AA</sub>.
- 9. Refer to command definition tables for valid address and data values.
- 10. Sampled, but not 100% tested. Guaranteed by design.
- 11. See AC Input/Output Reference Waveforms for timing measurements.



5.7 AC Characteristics(11)  $V_{CC}=5.0V\pm0.5V$ ,  $T_A=0^{\circ}C$  to  $+70^{\circ}C$ 

## Read, Write, Read-Modify-Write and Refresh Cycles (Common Parameters)

|                   | Versions                                    |       |      | 6XD-85 | Units |
|-------------------|---------------------------------------------|-------|------|--------|-------|
| Symbol            | Parameter                                   | Notes | Min  | Max    |       |
| t <sub>RP</sub>   | RAS# Precharge Time                         |       | 10   |        | ns    |
| t <sub>CP</sub>   | CAS# Precharge Time                         | -     | 15   |        | ns    |
| tASR              | Row Address Set-Up Time                     | 9     | 0    | `      | ns    |
| t <sub>RAH</sub>  | Row Address Hold Time                       | 9     | 15   |        | ns    |
| tasc              | Column Address Set-Up Time                  | 9     | 0    |        | ns    |
| t <sub>CAH</sub>  | Column Address Hold Time                    | 9     | 20   |        | ns    |
| tAR               | Column Address Hold Time Referenced to RAS# | 3,9   | 35   |        | ns    |
| t <sub>RAD</sub>  | RAS# to Column Address Delay Time           | 8,9   | . 15 | 15     | ns    |
| tCRP              | CAS# to RAS# Precharge Time                 |       | 10   |        | ns    |
| toED              | OE# to Data Delay                           | 10    | 30   |        | ns    |
| ,t <sub>DZO</sub> | OE# Delay Time from Data In                 | 10    | 0    |        | ns    |
| t <sub>DZC</sub>  | CAS# Delay Time from Data In                | 10    | 0    |        | ns    |
| t⊤                | Transition Time (Rise and Fall)             | 10    | . 2  | 4      | ns    |



## **Read Cycle**

|                     | Versions                                   |       | 28F01 | 6XD-85 | Units |  |
|---------------------|--------------------------------------------|-------|-------|--------|-------|--|
| Symbol              | Parameter                                  | Notes | Min   | Max    |       |  |
| t <sub>RC(R)</sub>  | Random Read Cycle Time                     |       | 95    |        | ns    |  |
| t <sub>RAS(R)</sub> | RAS# Pulse Width (Reads)                   |       | 85    | 8      | ns    |  |
| tCAS(R)             | CAS# Pulse Width (Reads)                   |       | 35    | - 00   | ns    |  |
| t <sub>RCD(R)</sub> | RAS# to CAS# Delay Time (Reads)            | 1     | 15    | 50     | ns    |  |
| t <sub>RSH(R)</sub> | RAS# Hold Time (Reads)                     |       | 30    |        | ns    |  |
| t <sub>CSH(R)</sub> | CAS# Hold Time (Reads)                     |       | 85    |        | ns    |  |
| tRAC                | Access Time from RAS#                      | 1,8   |       | 85     | ns    |  |
| tCAC                | Access Time from CAS#                      | 1,2   |       | 35     | ns    |  |
| t <sub>AA</sub>     | Access Time from Column Address            | 8     |       | 65     | ns    |  |
| tOEA                | OE# Access Time                            |       |       | 35     | ns    |  |
| t <sub>ROH</sub>    | RAS# Hold Time Referenced to OE#           |       | 35    |        | ns    |  |
| t <sub>RCS</sub>    | Read Command Set-Up Time                   |       | 5     |        | ns    |  |
| t <sub>RCH</sub>    | Read Command Hold Time Referenced to CAS#  | 6,10  | . 0   |        | ns    |  |
| t <sub>RRH</sub>    | Read Command Hold Time Referenced to RAS#  | 6,10  | 0     |        | ns    |  |
| t <sub>RAL</sub>    | Column Address to RAS# Lead Time           | 9     | 15    |        | ns    |  |
| t <sub>CAL</sub>    | Column Address to CAS# Lead Time           | 9     | 65    |        | ns    |  |
| t <sub>CLZ</sub>    | CAS# to Output in Low-Z                    | 10    | 0 -   | i      | ns    |  |
| tон                 | Output Data Hold Time                      | 10    | 0     |        | ns    |  |
| tоно                | Output Data Hold Time from OE#             | 10    | 0     |        | ns    |  |
| toff                | Output Buffer Turn-Off Delay               | 4,10  |       | 30     | ns    |  |
| t <sub>OEZ</sub>    | Output Buffer Turn-Off Delay Time from OE# | 10    |       | 30     | ns    |  |
| t <sub>CDD</sub>    | CAS# to Data in Delay Time                 | 10    | 30    |        | ns    |  |



# Write Cycle

| Versions            |                                            |       | 28F01 | 6XD-85 | Units |
|---------------------|--------------------------------------------|-------|-------|--------|-------|
| Symbol              | Parameter                                  | Notes | Min   | Max    |       |
| t <sub>RC(W)</sub>  | Random Write Cycle Time                    |       | 75    |        | ns    |
| t <sub>RAS(W)</sub> | RAS# Pulse Width (Writes)                  |       | 65    | ∞      | ns    |
| tCAS(W)             | CAS# Pulse Width (Writes)                  |       | 50    | - ∞    | ns    |
| t <sub>RCD(W)</sub> | RAS# to CAS# Delay Time (Writes)           | 1     | 15    | 15     | ns    |
| t <sub>RSH(W)</sub> | RAS# Hold Time (Writes)                    |       | 50    |        | ns    |
| t <sub>CSH(W)</sub> | CAS# Hold Time (Writes)                    |       | 65    |        | ns    |
| twcs                | Write Command Set-Up Time                  | 5     | 0     |        | ns    |
| twch                | Write Command Hold Time                    |       | 15    |        | ns    |
| twcR                | Write Command Hold Time Referenced to RAS# | 3     | 30    |        | ns    |
| t <sub>WP</sub>     | Write Command Pulse Width                  |       | 15    |        | ns    |
| t <sub>RWL</sub>    | Write Command to RAS# Lead Time            |       | 50    |        | ns    |
| tcwL                | Write Command to CAS# Lead Time            |       | 50    |        | ns    |
| t <sub>DS</sub>     | Data-In Set-Up Time                        | 7,9   | 0     |        | ns    |
| t <sub>DH</sub>     | Data-In Hold Time                          | 7,9   | 15    |        | ns    |
| t <sub>DHR</sub>    | Data-In Hold Time Referenced to RAS#       | 3,9   | 30    | ÷ .    | ns    |

# Read-Modify-Write Cycle

| Versions         |                                  |        | 28F016 | XD-85 | Units |
|------------------|----------------------------------|--------|--------|-------|-------|
| Symbol           | Parameter                        | Notes  | Min    | Max   |       |
| tRWC             | Read-Modify-Write Cycle Time     | 10     | 175    |       | ns    |
| tRWD             | RAS# to WE# Delay Time           | 5,10   | 115    | ,     | ns    |
| tcwD             | CAS# to WE# Delay Time           | 5,10   | 65     |       | ns    |
| tawd             | Column Address to WE# Delay Time | 5,9,10 | 100    |       | ns    |
| t <sub>OEH</sub> | OE# Command Hold Time            | 10     | 15     |       | ns    |

# Fast Page Mode Cycle

|                    | Versions                           |       | 28F016 | Units |        |
|--------------------|------------------------------------|-------|--------|-------|--------|
| Symbol             | Parameter                          | Notes | Min    | Max   | Omto : |
| t <sub>PC(R)</sub> | Fast Page Mode Cycle Time (Reads)  |       | 65     |       | ns     |
| t <sub>PC(W)</sub> | Fast Page Mode Cycle Time (Writes) |       | 65     | ,     | ns     |



## Fast Page Mode Cycle (Continued)

|                      | Versions                                    |       |     | 28F016XD-85 |       |
|----------------------|---------------------------------------------|-------|-----|-------------|-------|
| Symbol               | Parameter                                   | Notes | Min | Max         | Units |
| t <sub>RASP(R)</sub> | RAS# Pulse Width (Reads)                    |       | 85  | ∞           | ns    |
| t <sub>RASP(W)</sub> | RAS# Pulse Width (Writes)                   |       | 65  | ∞           | ns    |
| t <sub>CPA</sub>     | Access Time from CAS# Precharge             |       |     | 70          | ns    |
| t <sub>CPW</sub>     | WE# Delay Time from CAS# Precharge          | 10    | 0   |             | ns    |
| t <sub>CPRH(R)</sub> | RAS# Hold Time from CAS# Precharge (Reads)  |       | 65  |             | ns    |
| t <sub>CPRH(W)</sub> | RAS# Hold Time from CAS# Precharge (Writes) | -     | 65  |             | ns    |

#### Fast Page Mode Read-Modify-Write Cycle

| Versions |                                             |       | 28F016 | Units |          |
|----------|---------------------------------------------|-------|--------|-------|----------|
| Symbol   | Parameter                                   | Notes | Min    | Max   | Oillis . |
| tPRWC    | Fast Page Mode Read-Modify-Write Cycle Time | 10    | 145    |       | ns       |

## **Refresh Cycle**

|                  | Versions                                    |       |      | 28F016XD-85 |       |  |
|------------------|---------------------------------------------|-------|------|-------------|-------|--|
| Symbol           | Parameter                                   | Notes | Min  | Max         | Units |  |
| tcsR             | CAS# Set-Up Time (CAS#-Before-RAS# refresh) | 10    | 10   |             | ns    |  |
| tCHR             | CAS# Hold Time (CAS#-Before-RAS# Refresh)   | 10    | 10   |             | ns    |  |
| t <sub>WRP</sub> | WE# Set-Up Time (CAS#-Before-RAS# Refresh)  | 10    | . 10 |             | ns    |  |
| twRH             | WE# Hold Time (CAS#-Before-RAS# Refresh)    | 10    | 10   |             | ns    |  |
| t <sub>RPC</sub> | RAS# Precharge to CAS# Hold Time            | 10    | 10   |             | ns    |  |
| tRASS            | RAS# Pulse Width (Self-Refresh Mode)        | 10    | 0    |             | ns    |  |
| t <sub>RPS</sub> | RAS# Precharge Time (Self-Refresh Mode)     | 10    | 10   |             | ns    |  |
| t <sub>CPN</sub> | CAS# Precharge Time (Self-Refresh Mode)     | 10    | 10   |             | ns    |  |
| t <sub>CHS</sub> | CAS# Hold Time (Self-Refresh Mode)          | 10    | 0    |             | ns    |  |

#### Refresh

| Versions         |                |       | 28F016XD-85 |     | Units |
|------------------|----------------|-------|-------------|-----|-------|
| Symbol           | Parameter      | Notes | Min         | Max |       |
| t <sub>REF</sub> | Refresh Period | 10    |             | ∞   | ms    |



#### Misc. Specifications

| Versions Parameter Notes                                             |      | 28F016XD-85 |     | 11-14- |
|----------------------------------------------------------------------|------|-------------|-----|--------|
|                                                                      |      | Min         | Max | Units  |
| RP# High to RAS# Going Low                                           | 10   | 300         |     | ns     |
| RP# Set-Up to WE# Going Low                                          | 10   | 300         |     | ns     |
| V <sub>PP</sub> Set-Up to CAS# High at End of Write Cycle            | 10   | 100         |     | ns     |
| WE# High to RY/BY# Going Low                                         | 10   |             | 100 | ns     |
| RP# Hold from Valid Status Register Data and RY/BY# High             | . 10 | 0           |     | ns     |
| V <sub>PP</sub> Hold from Valid Status Register Data and RY/BY# High | 10   | 0           |     | ns     |

#### **NOTES:**

1. Operation within the t<sub>RCD(max)</sub> limit insures that t<sub>RAC(max)</sub> can be met. t<sub>RCD(max)</sub> is specified as a reference point.

2. Assumes that  $t_{RCD} \ge t_{RCD(max)}$ .

3. t<sub>AR</sub>, t<sub>WCR</sub>, t<sub>DHR</sub> are referenced to t<sub>RAD(max)</sub>.
4. t<sub>OFF(max)</sub> defines the time at which the output achieves the open circuit condition and is not referenced to V<sub>OH</sub> or V<sub>OL</sub>.

5. twcs, thwo, town and the datasheet as electrical characteristics only. If t<sub>WCS</sub> ≥ t<sub>WCS(min)</sub> the cycle is an early write cycle and the data output will remain high impedance for the duration of the cycle. If town  $\geq$  town(min), then  $\geq$  the town the cycle is a read-write cycle and the data output will contain the data read from the selected address. If neither of the above conditions are satisfied, the condition of the data out is indeterminate.

6. Either t<sub>BCH</sub> or t<sub>BBH</sub> must be satisfied for a read cycle.

- 7. These parameters are referenced to the CAS# leading edge in early write cycles and to the WE# leading edge in readwrite cycles.
- Operation within the t<sub>RAD</sub>(max) limit ensures that t<sub>RAC</sub>(max) can be met, t<sub>RAD</sub>(max) is specified as a reference point only. If t<sub>RAD</sub> is greater than the specified t<sub>RAD(max)</sub> limit, then the access time is controlled by t<sub>AA</sub>.

9. Refer to command definition tables for valid address and data values.

10. Sampled, but not 100% tested. Guaranteed by design.

11. See AC Input/Output Reference Waveforms for timing measurements.



## 5.8 AC Waveforms



Figure 7. AC Waveforms for Read Operations





Figure 8. AC Waveforms for Early Write Operations





Figure 9. AC Waveforms for Delayed Write Operations



Figure 10. AC Waveforms for Read-Modify-Write Operations





Figure 11. AC Waveforms for Fast Page Mode Read Operations





Figure 12. AC Waveforms for Fast Page Mode Early Write Operations





Figure 13. AC Waveforms for Fast Page Mode Delayed Write Operations



Figure 14. AC Waveforms for Fast Page Mode Read-Modify-Write Operations





Figure 15. AC Waveforms for RAS#-Only Refresh Operations





Figure 16. AC Waveforms for CAS#-before-RAS# Refresh Operations





Figure 17. AC Waveforms for Hidden Refresh Operations





Figure 18. AC Waveforms for Self-Refresh Operations



# 5.9 Power-Up and Reset Timings



Figure 19. V<sub>CC</sub> Power-Up and RP# Reset Waveforms

| Symbol            | Parameter                                     | Notes | Min | Max | Unit |
|-------------------|-----------------------------------------------|-------|-----|-----|------|
| t <sub>PL5V</sub> | RP# Low to V <sub>CC</sub> at 4.5V (Minimum)  | 2     | 0   | ·   | μs   |
| t <sub>PL3V</sub> | RP# Low to V <sub>CC</sub> at 3.0V (Minimum)  | 2     | 0   |     | μs   |
| t <sub>5VPH</sub> | V <sub>CC</sub> at 4.5V Minimum) to RP# High  | 1     | 2   |     | μs   |
| t <sub>3VPH</sub> | V <sub>CC</sub> at 3.0V (Minimum) to RP# High | 1     | 2   |     | μs   |

#### NOTES:

For Read Timings following Reset, see sections 5.6 and 5.7.

- 1. The t<sub>5VPH</sub> and/or t<sub>3VPH</sub> times must be strictly followed to guarantee all other read and write specifications for the 28F016XD.
- 2. The power supply may start to switch concurrently with RP# going low.



5.10 Erase and Word Write Performance(3,5)  $V_{CC}=5.0V\pm0.5V$ ,  $V_{PP}=5.0V\pm0.5V$ ,  $V_{A}=0$ C to +70°C

| Symbol              | Parameter                                       | Notes | Min | Typ(1) | Max | Units |
|---------------------|-------------------------------------------------|-------|-----|--------|-----|-------|
|                     | Page Buffer Word Write Time                     | 2     | TBD | 12.1   | TBD | μs    |
| twhRH1              | Word Write Time                                 | 2     | TBD | 16     | TBD | μs    |
| t <sub>WHRH</sub> 3 | Block Write Time                                | 2     | TBD | 0.6    | TBD | sec   |
|                     | Block Erase Time                                | 2     | TBD | 1.0    | TBD | sec   |
|                     | Full Chip Erase Time                            | 2     | TBD | 32.0   | TBD | sec   |
|                     | Time From Erase Suspend<br>Command to WSM Ready | 4     | TBD | 10     | TBD | μs    |

 $V_{CC}$  = 5.0V  $\pm$  0.5V,  $V_{PP}$  = 12.0V  $\pm$  0.6V,  $T_A$  = 0°C to +70°C

| Symbol              | Parameter                                       | Notes | Min | Typ(1) | Max | Units |
|---------------------|-------------------------------------------------|-------|-----|--------|-----|-------|
|                     | Page Buffer Word Write Time                     | 2     | TBD | 4.1    | TBD | μs    |
| twhRH1              | Word Write Time                                 | 2     | 4.5 | 6      | TBD | μs    |
| t <sub>WHRH</sub> 3 | Block Write Time                                | 2     | TBD | 0.2    | 1.0 | sec   |
|                     | Block Erase Time                                | 2     | 0.3 | 0.6    | 10  | sec   |
| ,                   | Full Chip Erase Time                            | 2     | TBD | 19.2   | TBD | sec   |
|                     | Time From Erase Suspend<br>Command to WSM Ready | 4     | TBD | 10     | TBD | μs    |

- 1. 25°C, and nominal voltages.
- 2. Excludes system-level overhead.
- 3. These performance numbers are valid for all speed versions.
- Specification applies to interrupt latency for Single Block Erase. Suspend latency for Erase All Unlocked Block operation extends the latency time to 140 μs (typical).
- 5. Sampled, but not 100% tested. Guaranteed by design.



# **6.0 MECHANICAL SPECIFICATIONS**



Figure 20. Mechanical Specifications of the 28F016XD 56-Lead TSOP Type I Package

|                | Family: Thin Small Outline Package |             |         |       |  |  |
|----------------|------------------------------------|-------------|---------|-------|--|--|
| Symbol         |                                    | Millimeters |         |       |  |  |
| Cymbol         | Minimum                            | Nominal     | Maximum | Notes |  |  |
| Α              |                                    | ·           | 1.20    |       |  |  |
| A <sub>1</sub> | 0.50                               |             |         |       |  |  |
| A <sub>2</sub> | 0.965                              | 0.995       | 1.025   |       |  |  |
| b              | 0.100                              | 0.150       | 0.200   |       |  |  |
| С              | 0.115                              | 0.125       | 0.135   | ·     |  |  |
| D <sub>1</sub> | 18.20                              | 18.40       | 18.60   |       |  |  |
| E              | 13.80                              | 14.00       | 14.20   |       |  |  |
| е              |                                    | 0.50        |         |       |  |  |
| D              | 19.80                              | 20.00       | 20.20   |       |  |  |
| L              | 0.500                              | 0.600       | 0.700   |       |  |  |
| N              |                                    | 56          | · .     |       |  |  |
| Ø              | 0°                                 | 3°          | 5°      |       |  |  |
| Υ              |                                    |             | 0.100   |       |  |  |
| Z              | 0.150                              | 0.250       | 0.350   |       |  |  |



#### **DEVICE NOMENCLATURE AND ORDERING INFORMATION**



|              | Valid Combinations                                        |                                                                       |  |  |  |
|--------------|-----------------------------------------------------------|-----------------------------------------------------------------------|--|--|--|
| Order Code   | $V_{CC} = 3.3V \pm 0.3V$ , 50 pF load, 1.5V I/O Levels(1) | $V_{CC} = 5.0V \pm 10\%$ , 100 pF load, TTL I/O Levels <sup>(1)</sup> |  |  |  |
| E28F016XD 85 | E28F016XD-95                                              | E28F016XD-85                                                          |  |  |  |

<sup>1.</sup> See Section 5.2 for Transient Input/Output Reference Waveforms.



## **ADDITIONAL INFORMATION**

| Order Number                               | Document/Tool                                                                                |
|--------------------------------------------|----------------------------------------------------------------------------------------------|
| 297372                                     | 16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016XS/28F016XD           |
| 292152                                     | AB-58, "28F016XD-Based SIMM Designs"                                                         |
| 292092                                     | AP-357, "Power Supply Solutions for Flash Memory"                                            |
| 292123                                     | AP-374, "Flash Memory Write Protection Techniques"                                           |
| 292126                                     | AP-377, "16-Mbit Flash Product Family Software Drivers, 28F016SA/28F016SV/28F016XS/28F016XD" |
| 292131                                     | AP-384, "Designing with the 28F016XD"                                                        |
| 297508                                     | FlashBuilder Utility                                                                         |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Benchmarking Utility                                                                |
| Contact Intel/Distribution<br>Sales Office | 28F016XD iBIS Models                                                                         |
| Contact Intel/Distribution<br>Sales Office | 28F016XD VHDL/Verilog Models                                                                 |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Timing Designer Library Files                                                       |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Orcad and ViewLogic Schematic Symbols                                               |

## **DATASHEET REVISION HISTORY**

| Number | Description      |
|--------|------------------|
| 001    | Original Version |

intel<sub>®</sub>

**AB-58** 

## APPLICATION BRIEF

# 28F016XD-Based SIMM Designs

BRIAN DIPERT
SENIOR TECHNICAL
MARKETING ENGINEER
SUJAN KAMRAN
TECHNICAL MARKETING
ENGINEER

November 1994



#### 1.0 INTRODUCTION

This application brief provides design information for SIMM (Single In-Line Memory Module) configurations based on the 28F016XD flash memory. The 28F016XD is an Intel 16 Mbit Flash memory component with a multiplexed address bus hardware interface, compatible with system DRAM controllers. As such, it is an ideal high-density flash memory for use in existing designs with DRAM SIMM connectors, or in new designs where flexibility in system memory configuration is needed. The 28F016XD preserves all traditional FlashFileTM memory attributes, including perbit programmability and per-block eraseability. Its low power consumption, full nonvolatility (i.e., no refresh required) and in-system updateability are desirable attributes in comparison to the DRAM memory alternative. The 28F016XD supports both standard and fast page mode reads/writes and all refresh cycles (which it internally disregards).

The example design explained in detail in this application brief (Section 2), uses the JEDEC 72-lead DRAM SIMM standard and supports densities of 1-Mbyte x 32 and 2-Mbyte x 32. Section 3 discusses ideas for extrapolating this design to other JEDEC DRAM SIMM pinouts, while Section 4 provides software guidelines corresponding to flash memory-based SIMM hardware designs. See Section 6 for additional information on Intel's flash memory products.

### 2.0 72-LEAD SIMM DESIGN EXAMPLE

Figure 1 shows a full-size layout for the 72-lead SIMM explained in this section, while Tables 1 and 2 show and describe the SIMM pinout. Figure 2 shows the SIMM component interconnect.



Figure 1. Flash Memory-Based 72-Lead SIMM (1M x 32 or 2M x 32) with Identical Dimensions and Pinout as the DRAM-Based Alternative



**Table 1. 72-Lead SIMM Pinout** 

| 1  | GND              | 13 | A <sub>1</sub>   | 25      | DQ <sub>22</sub>      | 37    | NC                    | 49 | DQ <sub>8</sub>  | 61 | DQ <sub>13</sub> |
|----|------------------|----|------------------|---------|-----------------------|-------|-----------------------|----|------------------|----|------------------|
| 2  | DQ <sub>0</sub>  | 14 | A <sub>2</sub>   | 26      | DQ <sub>7</sub>       | 38    | NC                    | 50 | DQ <sub>24</sub> | 62 | DQ <sub>30</sub> |
| 3  | DQ <sub>16</sub> | 15 | A <sub>3</sub>   | 27      | DQ <sub>23</sub>      | 39    | GND                   | 51 | DQ <sub>9</sub>  | 63 | DQ <sub>14</sub> |
| 4  | DQ <sub>1</sub>  | 16 | A <sub>4</sub>   | 28      | A <sub>7</sub>        | 40    | CAS <sub>0</sub> #    | 52 | DQ <sub>25</sub> | 64 | DQ <sub>31</sub> |
| 5  | DQ <sub>17</sub> | 17 | A <sub>5</sub>   | 29      | NC                    | 41    | CAS <sub>2</sub> #    | 53 | DQ <sub>10</sub> | 65 | DQ <sub>15</sub> |
| 6  | DQ <sub>2</sub>  | 18 | A <sub>6</sub>   | 30      | V <sub>CC</sub>       | 42    | CAS <sub>1</sub> #    | 54 | DQ <sub>26</sub> | 66 | NC               |
| 7  | DQ <sub>18</sub> | 19 | NC               | 31      | A <sub>8</sub>        | 43    | CAS <sub>3</sub> #    | 55 | DQ <sub>11</sub> | 67 | PD <sub>1</sub>  |
| 8  | DQ <sub>3</sub>  | 20 | DQ <sub>4</sub>  | 32      | A <sub>9</sub>        | 44    | RAS <sub>0</sub> #    | 56 | DQ <sub>27</sub> | 68 | PD <sub>2</sub>  |
| 9  | DQ <sub>19</sub> | 21 | DQ <sub>20</sub> | , 33(1) | NC/RAS <sub>3</sub> # | 45(1) | NC/RAS <sub>1</sub> # | 57 | DQ <sub>12</sub> | 69 | PD <sub>3</sub>  |
| 10 | Vcc              | 22 | DQ <sub>5</sub>  | 34      | RAS <sub>2</sub> #    | 46    | NC                    | 58 | DQ <sub>28</sub> | 70 | PD <sub>4</sub>  |
| 11 | NC               | 23 | DQ <sub>21</sub> | 35      | NC                    | 47    | W# .                  | 59 | V <sub>CC</sub>  | 71 | NC               |
| 12 | A <sub>0</sub>   | 24 | DQ <sub>6</sub>  | 36      | NC                    | 48    | NC                    | 60 | DQ <sub>29</sub> | 72 | GND              |

## NOTES:

<sup>1.</sup> Pin 33 is a NC for the 1M x 32 SIMM and RAS $_3\#$  for the 2M x 32 SIMM. 2. Pin 45 is a NC for the 1M x 32 SIMM and RAS $_1\#$  for the 2M x 32 SIMM.



**Table 2. 72-Lead SIMM Pin Description** 

| Symbol                            | Туре             | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>9</sub>    | INPUT            | <b>MULTIPLEXED ROW/COLUMN ADDRESSES:</b> Select a location within the flash memory array in conjunction with appropriate RAS# and CAS# signals. Row (upper) addresses are latched on the falling edge of RAS#, while column (lower) addresses are latched on the falling edge of CAS#.                                                                                                                                                                                                                |
| DQ <sub>0</sub> -DQ <sub>31</sub> | INPUT/<br>OUTPUT | <b>DATA BUS:</b> Inputs flash memory data and commands during CUI write cycles. Outputs flash memory array, buffer, identifier or status data in the appropriate read mode. Floated when the SIMM is de-selected or the outputs are disabled.                                                                                                                                                                                                                                                         |
| RAS <sub>0-3</sub> #              | INPUT            | <b>ROW ADDRESS STROBE:</b> Latches row address information on inputs $A_{0-9}$ when RAS# transitions low. A subsequent CAS# low transition initiates flash memory read or write operations. RAS $_0$ # selects the lower 1M x 32 memory bank, while RAS $_1$ # selects the upper 1M x 32 bank (for the 2M x 32 SIMM). Signals RAS $_2$ # and RAS $_3$ # are not used in the design shown in Section 2.                                                                                                |
| CAS <sub>0-3</sub> #              | INPUT            | <b>COLUMN ADDRESS STROBE:</b> Latches column address information on inputs $A_{0-9}$ when CAS# transitions low. When preceded by a RAS# low transition, CAS# low initiates flash memory read or write operations in conjunction with W#. Subsequent CAS# low transitions, with RAS# held low, enable fast page mode reads/writes. CAS_0# selects the lower 16 bits of a memory bank, while CAS_2# selects the upper 16 bits. Signals CAS_1# and CAS_3# are not used in the design shown in Section 2. |
| W#                                | INPUT            | WRITE ENABLE: Controls access to the CUI, Page Buffers, Data Queue Registers and Address Queue Latches. W# is active low and initiates writes in combination with RAS# and CAS# low. W# inactive high with RAS# and CAS# low signifies a flash memory read operation. RAS# and CAS# high override W# low.                                                                                                                                                                                             |
| PD <sub>1-4</sub>                 | OUTPUT           | PRESENCE DETECT: Indicates SIMM speed/density information for system identification. Various combinations of PD pins, either connected to GND or left not connected (pulled high by a resistor on the system board) refer to JEDEC standards, as indicated in Table 3.                                                                                                                                                                                                                                |
| V <sub>CC</sub>                   | INPUT            | <b>OPERATIONAL AND ERASE/WRITE POWER SUPPLY (5V</b> $\pm$ <b>0.5V).</b> Do not leave any power pins unconnected. V <sub>CC</sub> also provides the flash memory V <sub>PP</sub> update voltage. The design example in Section 2 does not support operation at V <sub>CC</sub> = 3.3V $\pm$ 0.3V (see Section 3.4).                                                                                                                                                                                    |
| GND                               | SUPPLY           | <b>GROUND FOR ALL INTERNAL CIRCUITRY:</b> Do not leave any ground pins floating.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| NC                                |                  | NO CONNECT: Lead may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |





Figure 2. The 28F016XD's Multiplexed Address Bus Interface Makes DRAM-Compatible SIMM Designs Simple

#### 2.1 Address and Data Bus

The multiplexed address and data buses of all flash memories are connected together. See the 28F016XD data sheet (Additional Information, Section 6) for percomponent address and data bus pin capacitance. RAS#, CAS# and W# control prevents data bus contention between multiple flash memory components.

## 2.2 RAS#, CAS#, W#

The 28F016XD is a x16-only flash memory, and each 28F016XD contains one CAS# input. CAS $_0$ # connects to the lower 16-bit component in each 28F016XD bank, while CAS $_2$ # connects to the upper 16-bit component. Therefore, this interface supports x16 or x32 reads and writes. RAS $_0$ # selects the first 1 Mbyte x 32 bank, while RAS $_1$ # selects the optional second bank. W# from the SIMM interface connects to all flash memories.

#### 2.3 SIMM Power Pins

 $V_{CC}$  from the SIMM interface connects to the  $V_{CC}$  and  $V_{PP}$  inputs of all 28F016XD flash memories, and  $V_{CC}$  also connects to the optional supply voltage monitoring

circuit. GND from the SIMM interface connects to all SIMM component GNDs. This design uses the 5.0V  $V_{PP}$  option of Intel's SmartVoltage technology. A small ceramic capacitor filters each flash memory  $V_{CC}$  and  $V_{PP}$  input, while a larger decoupling capacitor filters  $V_{CC}$  at the SIMM interface. See Section 3.4 for alternate  $V_{CC}$  and  $V_{PP}$  techniques.

## 2.4 Other 28F016XD Signals

#### RP# Reset/Power-Down

This design includes an optional low-cost supply voltage monitoring circuit (Maxim MAX705) whose POWERGOOD output controls flash memory RP# inputs. This scheme protects the flash memory from spurious command writes during system power transitions. Include the monitoring circuit unless you can guarantee that your DRAM controller holds the RAS#/CAS# combination and W# inactive with V<sub>CC</sub> above V<sub>LKO</sub> (see 28F016XD specifications) in all cases except when intentionally writing to flash memory. Experience has shown that many memory controllers have unspecified and unpredictable operation during system power transitions.



If the monitoring circuit is not used, remove the 8-pin SOIC layout from the SIMM and connect RP# to  $V_{\rm CC}$ . Alternatively, connect SOIC layout pins corresponding to the (non-present) monitoring circuit  $V_{\rm CC}$  input and POWERGOOD output, together with a 0-ohm resistor.

#### WP#

This design connects WP# to V<sub>CC</sub>, driving this input inactive at all times.

#### RY/BY#

This design does not use the RY/BY# output, leaving it disconnected. System software should poll the flash memory Status Registers to determine device status and completion of internal operations.

#### OE#

This design connects OE# to GND. RAS# and CAS# active, in conjunction with an inactive (high) W#, initiate a flash memory read. W# active low overrides the state of OE#. RAS# and CAS# inactive high override OE# active low.

## 2.5 Other SIMM Signals

#### PD<sub>1-4</sub>

PD leads are connected to GND or left unconnected on the SIMM, and are connected to  $V_{CC}$  via pull-up resistors on the system board. Their state ("1" or "0"), when read by system logic, provide SIMM speed/density information and reference the speed bin of the 28F016XD flash memories. JEDEC standard Presence Detect pin combinations for 4-MB, 8-MB and 16-MB (x36 72-pin) SIMMs with  $t_{RAC}=100~\rm ns$  are shown in Table 3. PD combinations for other "non-standard" speed/density combinations are user definable.

Table 3. PD Signal Combinations for Various Densities  $(t_{RAC} = 100 \text{ ns})$ 

|       | PD <sub>1</sub> | PD <sub>2</sub> | PD <sub>3</sub> | PD <sub>4</sub> |
|-------|-----------------|-----------------|-----------------|-----------------|
| 4 MB  | GND             | GND             | GND             | GND             |
| 8 MB  | NC              | NC              | GND             | GND             |
| 16 MB | GND             | NC              | GND             | GND             |

# 3.0 RECOMMENDATIONS FOR DESIGN MODIFICATIONS AND OTHER SIMM INTERFACES

The 72-lead SIMM interface is only one of several pinouts approved by JEDEC and other standards bodies. This section gives recommendations for adapting the design techniques of Section 2 to other SIMM interfaces. In addition, it discusses providing voltages other than 5.0V to the 28F016XD SIMM and enhancing system control of 28F016XD operations.

## 3.1 Parity

Flash memory is not subject to the alpha particle soft errors that plague DRAM, as it stores the data value ("1" or "0") intrinsically on the floating gate of the flash memory transistor. For this reason, a parity output was not included as part of the 28F016XD pinout. In systems that employ parity check to confirm the integrity of the DRAM memory subsystem, on-SIMM programmable or dedicated logic can generate parity bits required for the flash memory-based SIMM read interface, if required. See Figure 3 for an example.



Figure 3. Parity Generation for DRAM Controller Compatibility



#### 3.2 8-Bit or 9-Bit SIMM Interfaces

The 28F016XD is a x16-only flash memory component. When used in a x8 or x9 (see Section 3.1) SIMM pinout, interface logic like that shown in Figure 4 should be used to route system data to the correct 8 bits of the flash memory bus and drive the alternate 8 bits to "1"s. System software must write commands to the flash memory only on the lower 8 bits for such an interface.



Figure 4. Converting the 16-Bit Flash Memory Data Bus to a x8/x9 System Interface

## 3.3 Flash Memory Control Input/ Output and Vpp Control

SIMMs other than the 72-lead version described in Section 2 may include additional inputs and outputs that can provide a system RESET# to the supply voltage monitoring circuit MR# input. Alternatively, if system RESET# includes power supply monitoring, this signal can directly control the 28F016XD RP# inputs. Additionally, system I/O signals can control the flash memory WP# input and route the RY/BY# output to a system port pin or hardware interrupt line. Finally, by separating out supply and program/erase voltage pins, alternate or semi-custom SIMM interfaces can provide 12.0V to the 28F016XD flash memory Vpp inputs for fast write performance and switch this program/erase voltage to GND when not updating flash memory contents for additional write protection.

## 3.4 V<sub>CC</sub> and V<sub>PP</sub> Flexibility

The 28F016XD, by virtue of its SmartVoltage technology can be operated at either 3.3V or 5.0V  $V_{CC}$ , and at either 5.0V or 12.0V  $V_{PP}$ . If 3.3V  $V_{CC}$  operation is desired (for lower power), an on-SIMM 3.3V-to-5.0V converter can generate the necessary 5.0V  $V_{PP}$  voltage.

Some designs may desire to program and erase the 28F016XD at 12.0V V<sub>PP</sub> for high write performance. In these cases, include a 5.0V-to-12.0V or 3.3V-to-12.0V converter on the SIMM to generate the 12.0V V<sub>PP</sub> voltage. See application note AP-357 for industry-representative 12V-converters.

#### 4.0 SOFTWARE GUIDELINES

System software should not attempt to scan/check the 28F016XD memory space as part of system initialization. The 28F016XD does not support the DRAM self-check function. Data combinations written to the 28F016XD may be decoded as valid commands and result in unintended flash memory operations. Check-sum calculation and comparison with a checksum data value stored in the flash memory is a recommended technique for ensuring data/code integrity.

The hardware interface described in Section 2 allows only 16- and 32-bit command/data writes to flash memory. When programming a flash memory location, set bits not to be programmed to "1"s as part of the data write. This technique can also be used to mask a write to the alternate byte of a 16-bit word when performing a byte program operation.

The 72-lead SIMM interface of Section 2 does not allow use of the flash memory RY/BY# output. System software should poll flash memory Status Registers to determine status of device operations, including program and erase.

System software should separate temporary data from code and "permanent" data tables, and route writes to the former to the system DRAM memory space. Flash memory is per-bit programmable (changing data "1"s to "0"s) and per-block erasable (changing data "0"s to "1"s), unlike DRAM, which is fully per-bit alterable.



## 5.0 CONCLUSION

This application brief has described one possible SIMM design using Intel's 28F016XD Flash memory, and has provided design recommendations for alternative SIMM approaches. Consult reference documentation

for a more complete understanding of device capabilities and design techniques. Please contact your local Intel or distribution sales office for more information on Intel's flash memory products.

#### 6.0 ADDITIONAL INFORMATION

#### 6.1 References

| Order Number                               | Document/Tool                                                                               |
|--------------------------------------------|---------------------------------------------------------------------------------------------|
| 290533                                     | 28F016XD DRAM-Interface Flash Memory Datasheet                                              |
| 297372                                     | "16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016XS/28F016XD"        |
| 292092                                     | AP-357 "Power Supply Solutions for Flash Memory"                                            |
| 292123                                     | AP-374 "Flash Memory Write Protection Techniques"                                           |
| 292126                                     | AP-377 "16-Mbit Flash Product Family Software Drivers, 28F016SA/28F016SV/28F016XS/28F016XD" |
| 292131                                     | AP-384 "Designing with the 28F016XD"                                                        |
| Contact Intel/Distribution<br>Sales Office | FlashBuilder Utility                                                                        |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Benchmarking Utility                                                               |
| Contact Intel/Distribution<br>Sales Office | 28F016XD iBIS Models                                                                        |
| Contact Intel/Distribution<br>Sales Office | 28F016XD VHDL/Verilog Models                                                                |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Timing Designer Library Files                                                      |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Orcad and ViewLogic Schematic Symbols                                              |

## 6.2 Revision History

| Number | Description      |  |  |  |  |
|--------|------------------|--|--|--|--|
| 001    | Original Version |  |  |  |  |



**AP-398** 

# APPLICATION NOTE

# Designing with the 28F016XS

KEN MCKEE
TECHNICAL MARKETING
ENGINEER

November 1994

## 3

## **DESIGNING WITH THE 28F016XS**

| CONTENTS                                               | PAGE                   | CONTENTS                                                                            | PAGE           |
|--------------------------------------------------------|------------------------|-------------------------------------------------------------------------------------|----------------|
| 1.0 INTRODUCTION                                       | 3-114                  | 4.4 Interfacing Examples                                                            | 3-127          |
| 2.0 OPERATIONAL FUNDAMENTAL OF THE 28F016XS            | <b>S</b><br>3-114<br>o | 4.5 Optimizing Read Perform Mode  4.6 Consecutive Accesses A Memory Bank Boundaries | 3-132<br>cross |
| the 28F016SA                                           | 3-114                  | 4.7 Handling Asynchronous \                                                         | Writes 3-136   |
| 2.2 Enhanced Read Capability                           | 3-115                  | 4.8 System Boot from 28F01                                                          | 6XS 3-137      |
| 2.3 SFI Configuration                                  | 4                      | 5.0 DESIGNING A FLEXIBLE<br>INTERFACE FOR THE 28F0<br>AND 28F016SA/SV               |                |
| 4.0 INTERFACING TO THE 28F016XS                        | 3-120                  | 6.0 CONCLUSION                                                                      | 3-140          |
| 4.1 Clocking Options                                   |                        | ADDITIONAL INFORMATION                                                              | 3-140          |
| 4.2 Alternating-A1 Access Rule 4.3 Same-A1 Access Rule | 3-124                  | REVISION HISTORY                                                                    | 3-140          |



#### 1.0 INTRODUCTION

The interfacing concepts discussed in this document are based on preliminary 28F016XS specifications. Please contact your Intel or distribution sales office for up-to-date information. Do not finalize a design based on the specifications in this document.

The 28F016XS is an extremely high performance 16-Mbit memory component, organized as either 2 MBytes or 1 MWord. The 28F016XS contains sixteen 128-KByte (64 KWord) blocks. Each block is separately erasable, lockable and capable of 1 million write/erase cycles by providing wear-leveling algorithms and graceful block retirement.

28F016XS's enhancements over first generation 16-Mbit flash memories include:

- Synchronous pipelined read interface providing significantly improved read performance
- SmartVoltage technology

The 28F016XS's synchronous pipelined read interface delivers highest read performance when interfaced to a microprocessor with a burst or pipelined bus, such as the i960® and Intel486TM microprocessors. The 28F016XS delivers equivalent or better read performance than DRAM, given an optimized interface.

The enhanced read performance capability of the 28F016XS eliminates the need of code shadowing from nonvolatile memory (ROM, EPROM, etc.) to DRAM for increased system performance. The 28F016XS eliminates the need for this multi-component memory model, enabling direct code execution out of nonvolatile memory with its high read performance.

This application note will discuss the concepts involved in interfacing to the 28F016XS, illustrating that it requires minimal glue logic and is compatible with a wide range of processors and buses.

### 2.0 OPERATIONAL FUNDAMENTALS OF THE 28F016XS

The 28F016XS, in read mode, is a fully synchronous component with a maximum operating frequency of 66 MHz at 5V V<sub>CC</sub>. Write operations to the 28F016XS are asynchronous, similar to traditional flash memories such as the 28F016SA. Flash memory is read, erased and written in system via the local processor.

# 2.1 28F016XS Pinout Comparison to the 28F016SA

The 28F016XS's pinout is very similar to the pinouts of the 28F016SA/SV (see Figure 1). All devices use the 56-Lead TSOP package.

The 28F016SA uses the 3/5 # pin (pin 1) to configure the flash memory for operation at 3.3V or 5.0V  $V_{CC}$ . The 28F016XS and 28F016SV use an internal detector connected to  $V_{CC}$  to accomplish this same function. The 3/5 # pin is no longer needed on the 28F016XS and 28F016SV, and pin 1 has been renamed NC ("no connect"). This pin may be driven to  $V_{IL}$  or  $V_{IH}$ , or may be left unconnected.

The 28F016XS also incorporates two new pins in comparison to the 28F016SA/SV: CLK (pin 29) and ADV# (pin 30). These two pins control the 28F016XS's synchronous pipelined read interface.

#### **CLK**

CLK provides the fundamental timing and internal operating read frequency for the 28F016XS (maximum frequency of 66 MHz at  $5.0V\pm0.5V$  V<sub>CC</sub> and 50 MHz at  $3.3V\pm0.3V$  V<sub>CC</sub>). CLK latches input addresses on its rising edge in conjunction with ADV#, times out the SFI Configuration (configurable via the Configure Device Command), and synchronizes device outputs. CLK can be slowed or stopped without loss of data synchronization. CLK is ignored during write operations.





Figure 1, 28F016XS Pinout Configuration Compared to the 28F016SA/SV

#### ADV#

Address Valid (ADV#) indicates that a valid address is present on the 28F016XS's address pins. ADV# sensed active low on the rising edge of CLK latches the address into the 28F016XS, which initiates a read access. ADV# is ignored by the 28F016XS during write cycles.

## 2.2 Enhanced Read Capability

Given an optimized interface, the 28F016XS's read performance is up to 2x higher than traditional asynchronous flash memory. The 28F016XS's synchronous pipelined read interface is capable of executing multiple read accesses in parallel. This parallel execution capability more than doubles read performance.

#### **Memory Address Decoding**

Figure 2 illustrates the 28F016XS's memory address decoding. Addresses  $A_{20-1}$  select a 16-bit location within the 28F016XS's memory array. Address  $A_1$  makes the bank selection, even or odd bank. Byte selection, in x8 mode (BYTE# =  $V_{IL}$ ), is based on the value of address  $A_0$ . In x16 mode (BYTE# =  $V_{IH}$ ), the 28F016XS does not use  $A_0$ .



Figure 2. Memory Address Decoding Illustrating
A<sub>0</sub> Selecting the Byte Location and
A<sub>1</sub> Selecting the Even or Odd Bank





Figure 3. Initiating a Single Read Access Waveform (28F016XS-15, SFI Configuration = 2)

#### **Executing a Read Access Cycle**

In read mode, ADV# and CLK together initiate read accesses when the device is selected (Figure 3). A read cycle is initiated and addresses are latched when the 28F016XS senses ADV# low on a rising CLK edge. After a read cycle begins and the SFI Configuration value has elapsed, data is latched and begins driving on the output pins. Valid data is guaranteed t<sub>CHQV</sub> after the elapse of the SFI Configuration value.

Refer to Section 2.3 for further information about the SFI Configuration.

#### **Consecutive Read Accesses**

Consecutive accesses to the 28F016XS, from the processor perspective, occur in either an *Alternating-A*<sub>1</sub> or a  $Same-A_1$  pattern. Of the two sequences, consecutive *Alternating-A*<sub>1</sub> accesses offer highest read performance.

Consecutive Alternating- $A_1$  accesses change the value of address  $A_1$  between consecutive read cycles. As Figure 4 illustrates, up to three accesses can be initiated before data from the first access is valid on the output pins. Consecutive Alternating- $A_1$  accesses allow multiple accesses to the 28F016XS to occur in parallel, effectively filling the 28F016XS's internal pipeline.

Consecutive  $Same-A_1$  accesses retain the same address  $A_1$  value between consecutive read cycles. This pattern allows up to two accesses to be initiated before data from the first accesses is read. The SFI Configuration value must elapse before a second access can begin (see Section 2.3).

Refer to Sections 4.2 and 4.3, the *Alternating-A*<sub>I</sub> and Same-A<sub>I</sub> access rules, for minimum delays between consecutive read accesses. The *Alternating-A*<sub>I</sub> and Same-A<sub>I</sub> access rules both apply to consecutive *Alternating-A*<sub>I</sub> accesses, while only the Same-A<sub>I</sub> rule applies to consecutive Same-A<sub>I</sub> accesses.





Figure 4. Synchronous Pipelined Read Waveform Example (28F016XS-15, SFI Configuration = 2, Consecutive Alternating-A<sub>1</sub> Access)

## 2.3 SFI Configuration

The SFI Configuration (Table 1) optimizes the 28F016XS for a wide range of input CLK frequencies. After a read access begins, the 28F016XS will latch data on its output pins after a CLK count corresponding to the SFI Configuration has elapsed.

The 28F016XS default SFI Configuration is 4 after power-up or return from deep power-down mode (RP# =  $V_{IL}$ ), allowing system boot from the 28F016XS, if desired, at any CLK frequency up to 66 MHz at 5.0V  $\pm$  0.5V  $V_{CC}$  (50 MHz at 3.3V  $\pm$  0.3V  $V_{CC}$ ). SFI Configurations are retained if the 28F016XS is put in sleep mode via a Sleep or Abort command. An optimized SFI Configuration for a given frequency (Table 1) enables the highest read performance. The SFI Configuration is updated via the Device Configuration command. SFI Configurations can range from 1 to 4.

The 28F016XS is fully synchronous. CLK can be slowed or stopped at any time within a series of accesses without loss of data synchronization.

Table 1. SFI Configuration
Correspondence to CLK Frequency

| 28F016XS-15      |                   |  |  |
|------------------|-------------------|--|--|
| Frequency (MHz)  | SFI Configuration |  |  |
| 66 (and below)   | 4                 |  |  |
| 50 (and below)   | 3                 |  |  |
| 33 (and below)   | 2                 |  |  |
| 16.7 (and below) | 1                 |  |  |

| 28F016XS-20      |                   |  |  |
|------------------|-------------------|--|--|
| Frequency (MHz)  | SFI Configuration |  |  |
| 50 (and below)   | 4                 |  |  |
| 37.5 (and below) | 3                 |  |  |
| 25 (and below)   | 2                 |  |  |
| 12.5 (and below) | 1                 |  |  |



Table 1. SFI Configuration Correspondence to CLK Frequency (Continued)

| 28F016XS-25     |                   |  |  |
|-----------------|-------------------|--|--|
| Frequency (MHz) | SFI Configuration |  |  |
| 40 (and below)  | 4                 |  |  |
| 30 (and below)  | 3                 |  |  |
| 20 (and below)  | 2                 |  |  |
| 10 (and below)  | 1                 |  |  |

#### NOTE:

SFI Configurations other than those shown in Table 1 produce spurious results and should not be used.

# 3.0 CPU/BUS COMPATIBILITY WITH 28F016XS

The 28F016XS's synchronous read interface pipelines up to three accesses at time. This multiple execution capability makes the 28F016XS highly compatible with CPUs and buses that employ an Intel or linear burst, or pipelined bus.

#### **Burst Bus**

A burst bus executes a series of accesses in retrieving data from the memory subsystem. Accessing data consecutively, a processor or bus employing an Intel or linear burst order increments the lower address lines, effectively executing consecutive *Alternating-A*<sub>1</sub> accesses. Tables 2 and 3 illustrate the Intel and linear burst order, for a 4-access burst.

Table 2. Intel Burst Order
Address A<sub>3-2</sub> on a 32-Bit Processor

|                  | Intel-Burst Order |                  |                   |  |  |  |
|------------------|-------------------|------------------|-------------------|--|--|--|
| First<br>Address | Second<br>Address | Third<br>Address | Fourth<br>Address |  |  |  |
| 00               | 01                | 10               | 11                |  |  |  |
| 01               | 00                | 11               | 10                |  |  |  |
| 10               | 11                | 00               | 01                |  |  |  |
| - 11             | 10                | 01               | 00                |  |  |  |

Table 3. Linear Burst Order Address A<sub>3-2</sub> on a 32-Bit Processor

| Linear Burst Order |                   |                  |                   |  |
|--------------------|-------------------|------------------|-------------------|--|
| First<br>Address   | Second<br>Address | Third<br>Address | Fourth<br>Address |  |
| 00                 | 01                | 10               | 11.               |  |
| 01                 | 10 ·              | 11               | 00                |  |
| 10                 | 11                | 00               | 01                |  |
| 11                 | 00                | 01               | 10                |  |

During a burst cycle, some CPUs themselves increment addresses, while others only supply the initial address, requiring peripheral logic to increment the address. CPUs that increment addresses, however, may not provide addresses quick enough to take full advantage of the 28F016XS's synchronous pipelined interface. Some processors wait for the completion of the first access before incrementing the address for the next access. Generating addresses within the interfacing logic, the 28F016XS is not forced to wait for the CPU. Therefore, several accesses can be initiated before the 28F016XS completes the initial access.



Figure 5 shows a block diagram of a four double-word burst CPU interface to the 28F016XS. This interface executes a 4 double word burst. Notice that addresses  $A_{2-1}$  are controlled by the interface. A multi-bit counter generates the addresses for the burst cycle.

Using the interface to increment addresses, the 28F016XS achieves highest read performance executing multiple *Alternating-A*<sub>1</sub> accesses at the same time. For example, the 28F016XS-15, at 33 MHz and 5.0V V<sub>CC</sub>, can deliver effective zero wait state performance interfacing to a burst bus, after the initial pipeline fill.



Figure 5. Burst Address Generation and Wait-State Control When Interfacing the 28F016XS to a Burst Processor





Figure 6. Comparing Past Address with Current Address to Determine Whether an Alternating-A<sub>1</sub> or Same-A<sub>1</sub> Access Occurs When Interfacing the 28F016XS to a Pipelined Bus Processor

#### **Pipelined Bus**

A pipelined bus activates the address and control signals for the next cycle before completing the current cycle. Pipelined buses have no defined access order; therefore, Alternating-A<sub>1</sub> accesses are not guaranteed. The interface must guard against a possible mixture of consecutive Alternating-A<sub>1</sub> and Same-A<sub>1</sub> accesses. Figure 6 illustrates a pipelined bus interface to the 28F016XS.

In a pipelined interface, the system logic does not increment the 28F016XS's lower addresses. The system logic instead latches address  $A_1$  and compares it to  $A_1$  of the following cycle. Comparing  $A_1$ , the interface logic can identify Alternating- $A_1$  and Same- $A_1$  accesses, which directly informs the interface logic when it can initiate a read access to the 28F016XS. The Alternating- $A_1$  and Same- $A_1$  access rules define the minimum delay between consecutive accesses (see Section 4.2 and 4.3).

In the past, external latches were required to latch the next address and control signals. The 28F016XS eliminates this extra system overhead, latching the next address internally and initiating the next cycle prior to completing the current cycle. The 28F016XS's synchronous pipelined interface takes full advantage of a pipelined bus.

#### 4.0 INTERFACING TO THE 28F016XS

The 28F016XS can interface to a wide range of CPUs and bus architectures. Glue logic is minimal and the performance enhancements are significant. Below are key considerations to keep in mind when interfacing to the 28F016XS:

- Clocking Options
- Alternating-A<sub>1</sub> Access Rule
- Same-A<sub>1</sub> Access Rule
- Optimizing Read Performance in x8 Mode
- Consecutive Accesses across Bank Boundaries
- Handling Asynchronous Write Cycles
- System Boot-Up out of the 28F016XS

## 4.1 Clocking Options

In choosing a CLK option, keep in mind that the 28F016XS operates at optimum performance with a CLK frequency at an upper SFI Configuration boundary (50 MHz and 33 MHz are two of four SFI Configuration upper boundaries for the 28F016XS-15 at 5.0V V<sub>CC</sub>). See Section 2.3 for information about the SFI Configuration.





Figure 7. Different CLK Options when Interfacing to a Processor that Requires a 2x CLK Input

For example, a processor running at 25 MHz with a 2x CLK input of 50 MHz provides both 25 MHz and 50 MHz CLK options (Figure 7). Using the 25 MHz CLK, the 28F016XS-15/-20 will begin driving data to the output pins two clocks (or 80 ns) after initiating a read cycle (SFI Configuration = 2 at 5.0  $\pm$  0.5V VCC). Using the 2x CLK, the 28F016XS-15 will begin driving data to the output pins in three clocks, or 60 ns (SFI Configuration = 3 at 5.0  $\pm$  0.5V VCC). The CLK frequency and SFI Configuration relationship affects the 28F016XS's read performance.

#### 2x vs. 1x CLK

Figure 7 illustrates three possible CLK options when interfacing to a processor requiring a 2x CLK input (processors such as the i960 processor and Intel386TM processor are two examples). Depending on the processor frequency, the 2x CLK may be closer to an upper SFI Configuration boundary, thereby reducing the 28F016XS's access time. The higher frequency of the 2x CLK however, reduces the amount of available

time for interface logic to meet the 28F016XS's set-up time (ADV#,  $CE_X$ # and OE# to rising CLK edge). A 1x CLK, on the other hand, has a longer period, relaxing the demands on the interfacing logic to meet the 28F016XS set-up time.

A general "rule of thumb" when choosing a CLK option: The higher the CLK frequency the higher the 28F016XS read performance but the faster the interfacing logic required.

#### **Clock Generation and Synchronization**

External clock generation and synchronization may be required when the interfacing processor uses a 2x CLK input and does not provide external access to the internally synchronized 1x CLK. Generating and synchronizing a 1x CLK from a 2x or 4x CLK can be accomplished with simple flip-flop logic. (Many processors, such as the Intel386 processor, synchronize their internal 1x CLK with the trailing edge of RESET.) Example PLD equations that generate and synchronize a 1x system output CLK are located in Appendix A.



Clock skew can arise depending upon the approach taken to derive the 1x CLK. Figure 8 (A) will have a maximum skew between the 2x and 1x clock of t<sub>CO1</sub>. Figure 8 (B) will have minimal-to-no skew because

both the 2x and 1x CLK outputs will have the same delay, t<sub>CO1</sub>, through the EPLD. Figure 9 graphically illustrates the amount of skew the two different CLK generation circuits produce.



Figure 8. 1x CLK Configurations Using RESET for CLK Synchronization





Figure 9. CLK Skew Produced by 1x CLK Configurations in Figure 8





Figure 10. Alternating Access Rule, Illustrating t<sub>CHCHA</sub> (28F016XS-15, SFI Configuration = 2, Consecutive *Alternating-A*<sub>1</sub> Accesses)

## 4.2 Alternating-A<sub>1</sub> Access Rule

The Alternating- $A_1$  access rule (Figure 10) defines the minimum time required between consecutive accesses with different  $A_1$  values. The Alternating- $A_1$  access rule is:

t<sub>CHCHA</sub> > = t<sub>CHQV</sub> + (System Propagation Delay) + (CPU Set-up Requirement)

t<sub>CHCHA</sub> is then rounded up to the nearest CLK period. For example, if the summation of t<sub>CHQV</sub>, system delay and CPU set-up requirement equals 24 ns, and the CLK (33 MHz) period equals 30 ns, t<sub>CHCHA</sub> is rounded up to 30 ns (1 CLK period).

When  $t_{CHCHA}$  equal one CLK period, an Alternating- $A_I$  access can execute on the next rising CLK edge. In

some designs, however, the sum of t<sub>CHQV</sub>, system delay and CPU set-up requirement may exceed the CLK period, requiring access stretching.

Section 4.4 describes several interface examples demonstrating the *Alternating-A*<sub>1</sub> access rule.

#### **Access Stretching**

Access stretching (Figure 11) extends the amount of time data is held between consecutive accesses. Intermediate cycles with ADV# disabled between initial access and subsequent access will extend the number of CLKs that the 28F016XS holds data. Intermediate cycles with ADV# disabled are required in all cases when tCHQV exceeds the CLK period.





Figure 11. Access Stretching Example at 40 MHz (28F016XS-15, SFI Configuration = 3, Consecutive *Alternating-A* $_1$  Accesses)



## 4.3 Same-A 1 Access Rule

The Same- $A_1$  access rule (Figure 12) defines the minimum time required between accesses with the same address  $A_1$  value. The Same- $A_1$  access rule is:

$$t_{CHCHS} > = SFI Configuration$$
  
or  
 $t_{CHCHS} > = 2 * t_{CHCHA}$ 

t<sub>CHCHS</sub> equals the largest value derived from the two above equations. For instance, a system operating at 50 MHz (20 ns period) with a SFI Configuration value set to 3 and a t<sub>CHCHA</sub> equaling 40 ns

SFI Configuration (3) = 60 ns  

$$2 * t_{CHCHA}$$
 = 80 ns  
will have a  $t_{CHCHS}$  equal to 80 ns.

Section 4.4 describes several interface examples that show the Same-A<sub>1</sub> access rule.



Figure 12. Same-A<sub>1</sub> Access Rule, Illustrating t<sub>CHCHS</sub> (28F016XS-15, SFI Configuration = 3, Consecutive Alternating-A<sub>1</sub> Accesses)



## 4.4 Interfacing Examples

The following waveform examples illustrate the Alternating- $A_1$  and Same- $A_1$  access rules.

#### Consecutive Alternating-A 1 Accesses at 33 MHz

Figure 13 illustrates consecutive Alternating-A<sub>I</sub> accesses at 33 MHz, interfacing to a burst bus. The system logic controls ADV #, CE<sub>X</sub># and OE# to initiate read accesses to the 28F016XS. t<sub>CHCHA</sub> and t<sub>CHCHS</sub> (delay between Alternating-A<sub>I</sub> and Same-A<sub>I</sub> accesses) define the rate at which the system logic can initiate read accesses to the 28F016XS.

| tourne             | ~ 2 |     | lation  |
|--------------------|-----|-----|---------|
| t <sub>CHCHA</sub> | va  | ıvu | iauoii. |

| CHORA S    |                          |         |
|------------|--------------------------|---------|
|            | t <sub>CHQV</sub>        | = 20 ns |
|            | System Propagation Delay | = 0 ns  |
|            | CPU Set-up Requirement   | = 4 ns  |
|            | Summation                | = 24 ns |
| <i>:</i> . | <sup>t</sup> CHCHA       | = 30 ns |

Access 2 can begin on the next rising CLK edge after access 1 because t<sub>CHCHA</sub> equals one CLK period.

#### toucus calculation:

| CHCHS can  | Julation.              |         |
|------------|------------------------|---------|
|            | SFI Configuration (2)  | = 60 ns |
|            | or                     |         |
|            | 2 * t <sub>CHCHA</sub> | = 60 ns |
| <i>:</i> . | t <sub>CHCHS</sub>     | = 60 ns |

 $t_{\rm CHCHS}$  is equal to two CLK periods. A second Same- $A_I$  access can occur two clocks after the initial access. This burst bus interface delivers 1-0-0-0 wait-state read performance at 33 MHz, excluding system-level overhead.



Figure 13. 33 MHz Read Timing Waveform Example (28F016XS-15, SFI Configuration = 2, Consecutive *Alternating-A*<sub>1</sub> Accesses)



#### Consecutive Same-A 1 Accesses at 33 MHz

Figure 14 illustrates consecutive  $Same-A_1$  accesses at 33 MHz. This situation could occur when interfacing to a pipelined bus. Pipelined buses do not guarantee consecutive  $Alternating-A_1$  accesses.

Consecutive  $Same-A_I$  accesses, as shown in this example, retain the same address  $A_I$  value between accesses. Therefore, the  $t_{\rm CHCHA}$  calculation is not required because no  $Alternating-A_I$  accesses occur.

t<sub>CHCHS</sub> calculation:

SFI Configuration (2)

 $= 60 \, \text{ns}$ 

tchchs

 $= 60 \, \text{ns}$ 

 $t_{\mbox{CHCHS}}$  equals two CLK periods. Hence, access 2 can begin two CLK periods after access 1.

This example read wait-state performance is 1-1 at 33 MHz, excluding system-level overhead.



Figure 14. 33 MHz Read Timing Waveform Example (28F016XS-15, SFI Configuration = 2, Consecutive Same-A<sub>1</sub> Access)



# Consecutive *Alternating-A* <sub>1</sub> Accesses at 40 MHz, Example 1

Figure 15 illustrates consecutive Alternating- $A_1$  accesses at 40 MHz, interfacing to a burst bus.

t<sub>CHCHA</sub> calculation:

| t <sub>CHQV</sub>        | = 20 ns |
|--------------------------|---------|
| System Propagation Delay | = 0 ns  |
| CPU Set-up Requirement   | = 4 ns  |
| Summation                | = 24 ns |

t<sub>CHCHA</sub> equals one CLK period (25 ns). Therefore, an *Alternating-A*<sub>1</sub> can begin on the next rising CLK edge.

**t**CHCHA



| SFI Configuration (3)  | = 75 ns |
|------------------------|---------|
| or                     |         |
| 2 * t <sub>CHCHA</sub> | = 50 ns |
| tchchs                 | = 75 ns |

 ${\it t_{CHCHS}}$  is equal to three CLK periods. A second Same-  $A_I$  access, therefore, can start three clocks after the initial access.

This interface delivers 2-0-1-0 wait-state read performance at 40 MHz, excluding system-level overhead.



= 25 ns

Figure 15. 40 MHz Read Timing Waveform Example 1 (28F016XS-15, SFI Configuration = 3, Consecutive *Alternating-A*<sub>1</sub> Accesses)



## Consecutive Alternating-A<sub>1</sub> Accesses at 40 MHz, Example 2

Figure 16 also illustrates consecutive  $Alternating-A_1$  accesses at 40 MHz, interfacing to a burst bus. In this example, a transceiver between the 28F016XS's outputs and the CPU inputs add a system propagation delay to the  $t_{\rm CHCHA}$  calculation.

| t <sub>CHCHA</sub> calculation: |                                               |                    |
|---------------------------------|-----------------------------------------------|--------------------|
|                                 | t <sub>CHQV</sub><br>System Propagation Delay | = 20 ns<br>= 5 ns  |
|                                 | CPU Set-up Requirement                        | = 4 ns             |
|                                 | Summation<br>tchcha                           | = 29 ns<br>= 50 ns |

t<sub>CHCHA</sub> equals two CLK periods (25 ns). Therefore, access stretching is required between *Alternating-A1* accesses.

t<sub>CHCHS</sub> calculation:

SFI Configuration (3) = 75 ns or 2 \* t<sub>CHCHA</sub> = 100 ns t<sub>CHCHS</sub> = 100 ns

 $t_{CHCHS}$  is equal to four CLK periods. A second Same- $A_I$  access can begin four clocks after the initial access.

This burst bus interface to the 28F016XS gives 2-1-1-1 wait-state read performance at 40 MHz, excluding system-level overhead.



Figure 16. 40 MHz Read Timing Waveform Example 2 (28F016XS-15, SFI Configuration = 3, Consecutive *Alternating-A*<sub>1</sub> Accesses, Access Stretching)



#### Consecutive Alternating-A<sub>1</sub> Accesses at 66 MHz

Figure 17 illustrates consecutive Alternating- $A_1$  accesses at 66 MHz, interfacing to a burst bus.

s required between Alternating-A1 accesses.

t<sub>CHCHA</sub> calculation:

| tCHQV                    | = 20 ns |
|--------------------------|---------|
| System Propagation Delay | = 0 ns  |
| CPU Set-up Requirement   | = 4 ns  |
| Summation                | = 24 ns |
| t <sub>CHCHA</sub>       | = 30 ns |

t<sub>CHCHA</sub> equals two CLK periods or 30 ns. Therefore, access stretching is required between *Alternating-A*<sub>1</sub> accesses.

tchchs calculation:

SFI Configuration (4) = 60 ns

OI

 $2 * t_{CHCHA} = 60 \text{ ns}$ 

 $t_{CHCHS} = 60 \text{ ns}$ 

 $t_{CHCHS}$  is equal to four CLK periods. Hence, a second  $Same-A_I$  access can begin four clocks after the initial access.

This burst bus interface to the 28F016XS delivers 3-1-1-1 wait-state read performance at 66 MHz, excluding system-level overhead.



Figure 17. 66 MHz Read Timing Waveform Example (28F016XS-15, SFI Configuration = 3, Consecutive *Alternating-A1* Accesses, Access Stretching)



# 4.5 Optimizing Read Performance in x8 Mode

When using the 28F016XS as a x8 device, the system interface to flash memory should be slightly modified to ensure highest read performance. The interface shown in Figure 18 ensures that, for a series of sequential accesses, address  $A_1$  will alternate between "0" and "1." This configuration takes advantage of consecutive Alternating- $A_1$  accesses and enables highest the 28F016XS read performance.

The examples below show the  $A_0/A_1$  address sequence that will be presented to the 28F016XS when either the conventional or optimized  $A_0$  and  $A_1$  interface configurations are used.

#### Conventional A<sub>0</sub> and A<sub>1</sub> Configuration

| A <sub>1</sub> | A <sub>0</sub> | Access                                       |
|----------------|----------------|----------------------------------------------|
| 0              | -0             | Initial Access                               |
| 0              | 1              | Subsequent Same-A <sub>1</sub> Access        |
| 1              | 0              | Subsequent Alternating-A <sub>1</sub> Access |
| 1              | 1              | Subsequent Same-A 1 Access                   |

Optimized A<sub>0</sub> and A<sub>1</sub> Configuration

| A <sub>1</sub> | A <sub>0</sub> | Access                                       |
|----------------|----------------|----------------------------------------------|
| 0              | 0              | Initial Access                               |
| 1              | 0              | Subsequent Alternating-A <sub>1</sub> Access |
| 0              | 1              | Subsequent Alternating-A <sub>1</sub> Access |
| 1              | 1              | Subsequent Alternating-A <sub>1</sub> Access |



Figure 18. A<sub>0</sub>/A<sub>1</sub> Optimized Interface for x8 Mode Operation

Implementing this hardware solution requires that code and data be stored to the 28F016XS in a modified sequence when using a PROM programmer. This allows expected data to be read in-system with addresses  $A_0$  and  $A_1$  swapped. On-board or in-system data write and erase "proceed as normal;" the address translation is handled automatically by hardware.

Figure 19 shows the code/data pattern that should be used when storing information to the 28F016XS using a PROM programmer. Figure 20 shows how that same data pattern appears to the system bus, after the  $A_0/A_1$  address swap.



Figure 19. Code/Data Structure when Performing Off-Board Programming





Figure 20. Code/Date
Structure Seen by the Processor

# 4.6 Consecutive Accesses Across Memory Bank Boundaries

Figure 21 illustrates a multi-bank 28F016XS configuration.  $CE_0\#$  and  $CE_1\#$  make the particular memory bank selection.

In this configuration, a sequence of accesses can potentially begin and end in different memory banks, which could potentially cause bus contention if not properly handled. All pipelined accesses to the initial bank must complete before activating the output buffer to the next memory bank. Both burst and pipelined buses are susceptible to this occurrence because of their sequential accessing nature.

#### **Burst Bus**

A burst bus will only cross memory bank boundaries when the length of the burst transfer exceeds the size of the individual banks. Refer to Tables 2 and 3 for the Intel and linear burst orders.

#### **Pipelined Bus**

Pipelined buses do not guarantee linear sequential accesses. Therefore, consecutive accesses can potentially bounce back and forth between different memory banks, crossing bank boundaries.

# Handling Consecutive Accesses That Cross Memory Bank Boundaries

When consecutive accesses cross memory bank boundaries, it is important to guard against enabling the output buffers for both banks. All pipeline accesses to the initial bank must complete before activating the OE# to the next bank. Enabling the buffers for both banks at the same time will cause bus contention.

System logic can handle consecutive accesses that cross bank boundaries in one of two ways:

- 1. Complete all accesses initiated in the first memory bank before addressing a new bank (Figure 22). This configuration requires only one OE# (Figure 21).
- 2. Before finishing all accesses to the initial memory bank, read cycles targeting a new bank can start as long as its OE# is deactivated. All accesses to the initial bank must finish before activating the OE# to the next bank. The OE# for the next bank is activated t<sub>GHQZ</sub> after the OE# to the initial bank has been deactivated (Figure 23). This configuration requires an OE# for each bank.





Figure 21. Two-Bank 28F016XS Combination, Burst Bus Interface, Single OE #





Figure 22. Consecutive Alternating-A  $_1$  Accesses Crossing Bank Boundaries, One OE # (28F016XS-15, SFI Configuration = 2)





Figure 23. Consecutive *Alternating-A*<sub>1</sub> Accesses Crossing Bank Boundaries, One OE# per Bank (28F016XS-15, SFI Configuration = 2)

## 4.7 Handling Asynchronous Writes

The 28F016XS write interface is asynchronous, similar to other Intel flash memories. The 28F016XS's write interface is not pipelined, therefore a write cycle must complete before another begins.

When the interfacing CPU can execute a burst write cycle, the system logic needs to manage the write cycle, allowing only one write cycle to the 28F016XS at a time. Write-back caches, for example, support burst write cycles. The 28F016XS does support word/byte write queuing, but the Queue Status (QS) bit in the Global Status Register (GSR) should be checked before attempting a second Write operation. If the queue is available, a second Write operation can begin before the Write State Machine (WSM) has completed the initial Write operation. In addition to the command queuing, the 28F016XS has two 256-byte page buffers.

The page buffers allow sequential loading at high speeds. Refer to Intel's 16-Mbit Flash Product Family User's Manual for further information about command queuing and page buffer operations.

When the interfacing CPU does not support burst writes, the 28F016XS's asynchronous write interface is not an issue. The processor will only execute one write cycle at a time.

When executing a write cycle, the interfacing processor or bus will drive a write signal informing the system of the desired operation. Monitoring this signal, the interfacing logic can correctly transition into an appropriate state machine sequence. In this situation, the interfacing logic directly controls the 28F016XS's write control signals (Figure 24), just as with asynchronous Intel flash memories.





Figure 24. Write Timing Waveform with Vpp at 5V or 12V

## 4.8 System Boot from 28F016XS

When booting from the 28F016XS, the interfacing logic must first support the default SFI Configuration value, 4. Depending on the actual CLK frequency however, the SFI Configuration (Section 2.3) may require adjustment to achieve maximum read performance. To achieve this flexibility, the interfacing logic must:

- Support the default SFI Configuration
- Be aware of changes to the SFI Configuration
- Alter the interface accordingly to handle optimized configuration

If a change is made to the SFI Configuration, the interface must be informed so that it can adjust accordingly. If the interface does not adjust, it will continue performing read cycles assuming a default SFI Configuration.



Figure 25 illustrates a possible way of informing the interface of a change to the SFI Configuration, using a general purpose input/output (GPIO). On system power up or reset, the GPIO transitions to a specific logic level (V<sub>IL</sub> or V<sub>IH</sub>), informing the interface of a default SFI Configuration. After altering the SFI Configuration, software changes the GPIO value. This input informs the interface of changes to the SFI Configuration.



Figure 25. Informing Interface of a SFI Configuration Change

Figure 26 illustrates the internal state machine. Depending upon the value of the GPIO (RECONFIG), the state machine will take one of two paths. One path is capable of handling the default SFI Configuration, while the second path supports the optimized SFI Configuration. Supporting the default configuration of SFI Configuration of a SFI Configuration of 4. In the optimized SFI Configuration, the interface can initiate read accesses to the 28F016XS at a faster rate if the SFI Configuration is less than 4. The rate at which the system logic can start read cycles is related to the SFI Configuration value. Refer to section 4.2 and 4.3 for the Alternating-A<sub>1</sub> and Same-A<sub>1</sub> access rules.



Figure 26. State Machine Handling of Boot-Up and Optimized SFI Configuration

## 5.0 DESIGNING A FLEXIBLE INTERFACE FOR THE 28F016XS AND 28F016SA/SV

Designers using the 28F016SA/SV now who are planning a future upgrade to the 28F016XS can design system logic capable of interfacing to both components.

Pinout similarities between the 28F016XS and 28F016XA/SV support a single footprint suitable for both components (see Section 2.1).

Supporting both components, the interface incorporates a state machine designed to control the 28F016SA and a second one to control the 28F016XS enhanced read interface.

The device identifiers can be used to communicate whether the 28F016SA/SV or enhanced 28F016XS device is in the system. The 28F016SA/SV and 28F016XS have distinct device IDs. A jumper configuration can also be used to communicate 28F016SA/SV or 28F016XS presence. Figure 27 illustrates the jumper identification method. The status of the jumper controls state machines within interface logic and/or can be read by system software to set wait state registers within the CPU.

Device ID or jumper identification can also be used to enable system software usage of 28F016XS's Status Register enhancements and the Device Configuration Code.





Figure 27. Jumper Identification of 28F016SA/SV or 28F016XS Presence for Wait State Control



#### 6.0 CONCLUSION

The read performance of the 28F016XS far exceeds that of traditional flash memories. Up to three accesses at a time can execute in parallel. The 28F016XS's synchronous interface makes it highly compatible with CPU and bus architectures that implement an Intel

or linear burst or pipelined bus. This application note has provided the fundamental knowledge that will enable designers to easily interface to the 28F016XS. For further information about the 28F016XS, consult reference documentation for a more comprehensive understanding of device capabilities and design techniques.

#### ADDITIONAL INFORMATION

| Order Number                               | Document/Tool                                                                                    |  |  |  |  |  |
|--------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 290532                                     | 28F016XS Datasheet                                                                               |  |  |  |  |  |
| 297500                                     | "Interfacing the 28F016XS to the i960® Microprocessor Family"                                    |  |  |  |  |  |
| 297504                                     | "Interfacing the 28F016XS to the Intel486™ Microprocessor Family"                                |  |  |  |  |  |
| 292146                                     | AP-600, "Performance Benefits and Power/Energy Savings of 28F016XS Based System Designs"         |  |  |  |  |  |
| 292126                                     | AP-377, "16-Mbit Flash Product Family Software Drivers, 28F016SA/<br>28F016SV/28F016XS/28F016XD" |  |  |  |  |  |
| 297372                                     | 16-Mbit Flash Product Family User's Manual, 28F016SA/28F016SV/<br>28F016XS/28F016XD              |  |  |  |  |  |
| 287508                                     | FlashBuilder Utility                                                                             |  |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Benchmark Utility                                                                       |  |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS iBIS Models                                                                             |  |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS VHDL/Verilog Models                                                                     |  |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Timing Designer Library Files                                                           |  |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Orcad and ViewLogic Schematic Symbols                                                   |  |  |  |  |  |

#### **REVISION HISTORY**

| Number | Description      |
|--------|------------------|
| 001    | Original Version |



### APPENDIX A PLD EQUATIONS FOR CLOCK GENERATION AND **SYNCHRONIZATION**

#### Clock Generation and Synchronization Using a 2x Clock Input

Title

lx Clock Generations & Synchronization

Pattern

PDS

Revision

1

Author Company Name Example Intel

Date

5/26/94

CHIP Clock\_Generation\_Circuit 85C220

;Input assignments

PIN CLK

; 2x CLK input frequency

PIN

RESET : System RESET

PIN SYSCLK ; Synchronized lx CLK output

EQUATIONS

SYSCLK :=/SYSCLK \* /RESET

SYSCLK.CLKF = CLK

#### Clock Generation and Synchronization Using a 4x Clock Input

Title lx Clock Generation and Synchronization

Pattern

PDS 1

Revision Author

Example

Company Name

Intel

Date

5/26/94

CHIP Clock\_Generation\_Circuit 85C220

; Input assignments

PIN CLK ; 4x CLK input frequency ; System RESET PIN RESET

; 2x CLK output PIN CLK2

PIN SYSCLK ; Synchronized lx CLK output

EQUATIONS

CLK2 := /CLK2

CLK2.CLKF = CLK

SYSCLK := CLK2 \* SYSCLK \* /RESET

+ /CLK2 \* /SYSCLK \* /RESET

SYSCLK.CLKF = CLK



### **AP-384**

# APPLICATION NOTE

# Designing with the 28F016XD

BRIAN DIPERT
SENIOR TECHNICAL
MARKETING ENGINEER
SUJAN KAMRAN
TECHNICAL MARKETING
ENGINEER

November 1994

### 3

### **DESIGNING WITH THE 28F016XD**

| CONTENTS                                       | PAGE  | CONTENTS                                    | PAGE  |
|------------------------------------------------|-------|---------------------------------------------|-------|
| 1.0 INTRODUCTION                               | 3-144 | 4.0 DESIGNING 28F016XD<br>COMPATIBILITY AND |       |
| 2.0 28F016XD COMPARISONS TO DRAM               | 3-144 | OPTIMIZATION INTO DRAM<br>CONTROLLERS       | 3-170 |
| 2.1 Voltage and Current Specifications         | 3-144 | 5.0 CONCLUSION                              | 3-171 |
| 2.2 Timing Specifications                      | 3-148 | ADDITIONAL INFORMATION                      | 3-171 |
| 2.3 Package and Pinout                         |       | REVISION HISTORY                            | 3-171 |
| 3.0 28F016XD INTERFACING TO DR. CONTROLLERS    |       |                                             |       |
| 3.1 Configurable Specification Interfacing     | 3-163 |                                             |       |
| 3.2 Non-Configurable Specification Interfacing | 3-164 |                                             |       |

3.3 Additional Circuitry Required to Interface to the 28F016XD ...... 3-167



#### 1.0 INTRODUCTION

This application note discusses comparisons between the 28F016XD and DRAM memories. It also offers recommendations for determining compatibility between the 28F016XD and DRAM controllers, and provides suggestions for designing DRAM controllers with the 28F016XD in mind. The 28F016XD, an Intel 16-Mbit Flash memory component, retains full software backwards-compatibility with the 28F016SA and adds the following features:

- Multiplexed address/address interface with RAS# and CAS# control inputs
- SmartVoltage technology
- Internal V<sub>CC</sub> detection (the 28F016SA's 3/5# pin is no longer needed)

The 28F016XD leverages the existing DRAM controller in system designs and thereby minimizes the glue logic required to interface to flash memory. It is a 16-Mbit device, organized as 1 Mbyte x 16. The 28F016XD has ten row addresses and ten column addresses, multiplexed on inputs  $A_0$ - $A_9$ .

The 28F016XD is fully non-volatile, giving it significant power and performance advantages over the traditional disk-plus-DRAM alternative. The 28F016XD does not lose data when power is removed from the device. By permanently storing and executing programs from the 28F016XD, the inherently slow disk drive-to-DRAM load delay is eliminated. The 28F016XD also does not require refresh cycles (although the 28F016XD will properly ignore any refresh cycles that are issued to it).

### 2.0 28F016XD COMPARISONS TO DRAM

The following sections discuss specific areas of comparison between the 28F016XD and 16-Mbit (1M x 16) DRAMs in 60 ns and 70 ns speed bins. Please reference the 28F016XD datasheet for a full description of the 28F016XD.

### 2.1 Voltage and Current Specifications

One obvious difference between the 28F016XD and DRAMs is that flash memory specifications reference a  $V_{PP}$  voltage, used with Data Write and Erase operations. All Vpp-related voltage and current specifications are unique to the 28F016XD. Note that the 28F016XD offers the option to connect Vpp either to 12.0V  $\pm$  5% or to 5.0V  $\pm$  10% (which may also be the  $V_{CC}$  operating voltage). The 28F016XD includes  $V_{CC}$  current specifications during Data Write, Erase and Erase Suspend operations. These operations are unique to flash memory; therefore, these specifications are not found in DRAM datasheets.

The 28F016XD specifies a  $V_{LKO}$  (lockout) voltage. This specification relates to circuitry within the flash memory that protects it from unwanted data alteration. The  $V_{LKO}$  specification is not found in DRAM datasheets. The 28F016XD also provides the deep powerdown mode, not available on DRAMs. 28F016XD read, standby (CMOS), RAS#-only refresh and CAS#-before-RAS# refresh currents are lower than those seen with DRAMs.

A comparison between the 28F016XD and representative 16-Mbit DRAMs (valid at the time this application note was written) is shown in Table 1.



Table 1. 28F016XD Read, Standby and Refresh Currents Compared to 60-70 ns 16-Mbit DRAM

| Parameter                                              | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |
|--------------------------------------------------------|----------------|--------------------|----------------|--------------------|
| V <sub>CC</sub> Read Current                           | 90-150 mA      | 70 mA              | 90-160 mA      | 120 mA             |
| V <sub>CC</sub> Fast Page Mode Read Current            | 80 mA          | 60 mA              | 70-140 mA      | 110 mA             |
| V <sub>CC</sub> Standby Current (CMOS Inputs)          | 400 μΑ         | 130 μΑ             | 300 μΑ         | 130 μΑ             |
| V <sub>CC</sub> Standby Current (TTL Inputs)           | 2 mA           | 4 mA               | 2 mA           | 4 mA               |
| V <sub>CC</sub> CAS#-Before-RAS# Refresh<br>Current    | 90-160 mA      | 55 mA              | 90-150 mA      | 65 mA              |
| V <sub>CC</sub> RAS#-Only Refresh Current              | 90-150 mA      | 70 mA              | 90-160 mA      | 120 mA             |
| V <sub>CC</sub> Standby Current<br>(Self Refresh Mode) | 5 mA           | 55 mA              | 5 mA           | 65 mA              |

Tables 2 and 3 show added and revised (as compared to 16-Mbit DRAM) 28F016XD DC specifications.

#### Table 2. 28F016XD Added/Revised DC Characteristics

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Sym               | Parameter                                           | Min | Тур | Max | Unit | Test Condition                                                                                                                                                                                                                                               |
|-------------------|-----------------------------------------------------|-----|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>CC</sub> 1 | V <sub>CC</sub> Word Read Current                   |     | 50  | 70  | mA   | $\begin{aligned} & \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ & \text{RAS\#, CAS\#} = \text{V}_{IL} \\ & \text{RAS\#, CAS\#, Addr. Cycling @t}_{RC} = \text{min} \\ & \text{I}_{OUT} = 0 \text{ mA} \\ & \text{Inputs} = \text{TTL or CMOS} \end{aligned}$ |
| I <sub>CC</sub> 2 | V <sub>CC</sub> Standby Current                     |     | 1   | 4   | mA   | $V_{CC} = V_{CC}$ Max<br>RAS#, CAS#, RP# = $V_{IH}$<br>WP# = $V_{IL}$ or $V_{IH}$                                                                                                                                                                            |
| I <sub>CC</sub> 3 | V <sub>CC</sub> RAS#-Only Refresh<br>Current        |     | 50  | 70  | mA   | $\begin{split} & V_{CC} = V_{CC}  \text{Max} \\ & \text{CAS\#} = V_{\text{IH}} \\ & \text{RAS\#} = V_{\text{IL}} \\ & \text{RAS\#, Addr. Cycling @$t_{RC}$} = \text{min} \\ & \text{Inputs} = \text{TTL or CMOS} \end{split}$                                |
| I <sub>CC</sub> 4 | V <sub>CC</sub> Fast Page Mode<br>Word Read Current |     | 40  | 60  | mA   | $\begin{split} &V_{CC} = V_{CC} \text{ Max} \\ &\text{RAS\#, CAS\#} = V_{IL} \\ &\text{CAS\#, Addr. Cycling @t}_{PC} = \text{min} \\ &I_{OUT} = 0 \text{ mA} \\ &\text{Inputs} = V_{IL} \text{ or } V_{IH} \end{split}$                                      |
| I <sub>CC</sub> 5 | V <sub>CC</sub> Standby Current                     | -   | 70  | 130 | μА   | $V_{CC} = V_{CC}$ Max<br>RAS# CAS# RP# = $V_{CC} \pm 0.2$ V<br>WP# = $V_{CC} \pm 0.2$ V or GND $\pm 0.2$ V                                                                                                                                                   |
| I <sub>CC</sub> 6 | V <sub>CC</sub> CAS#-Before-RAS#<br>Refresh Current |     | 40  | 55  | mA   | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ \text{CAS\#, RAS\#} = \text{V}_{IL} \\ \text{CAS\#, RAS\#, Addr. Cycling } @t_{RC} = \text{min} \\ \text{Inputs} = \text{TTL or CMOS} \end{array}$                                            |



## Table 2. 28F016XD Added/Revised DC Characteristics (Continued) $V_{CC}=3.3V~\pm~0.3V,~T_{A}=~0^{\circ}C~to~+70^{\circ}C$

| Sym                | Parameter                                              | Min  | Тур  | Max  | Unit | Test Condition                                                                                                                          |
|--------------------|--------------------------------------------------------|------|------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>CC</sub> 7  | V <sub>CC</sub> Standby Current<br>(Self Refresh Mode) |      | 40   | 55   | mA   | $\begin{aligned} & V_{CC} = V_{CC}  Max \\ & RAS\#, CAS\# = V_{IL} \\ & I_{OUT} = 0  mA \\ & Inputs = V_{IL}  or  V_{IH} \end{aligned}$ |
| ICCD               | V <sub>CC</sub> Deep Power-Down<br>Current             | ,    | 2    | 5    | μΑ   | RP# = GND ± 0.2V                                                                                                                        |
| lccw               | V <sub>CC</sub> Word Write Current                     |      | 8    | 12   | mA   | Word Write in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                                                                                  |
|                    |                                                        |      | 8    | 17   | mA   | Word Write in Progress<br>V <sub>PP</sub> = 5.0V ± 10%                                                                                  |
| ICCE               | V <sub>CC</sub> Block Erase Current                    |      | 6    | 12   | mA   | Block Erase in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                                                                                 |
|                    |                                                        |      | 9    | 17.  | mA   | Block Erase in Progress<br>V <sub>PP</sub> = 5.0V ± 10%                                                                                 |
| ICCES              | V <sub>CC</sub> Erase Suspend<br>Current               |      | 1    | 4    | mA   | RAS#, CAS# = V <sub>IH</sub><br>Block Erase Suspended                                                                                   |
| IPPS               | V <sub>PP</sub> Standby/Read                           |      | ± 1  | ±10  | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                                                       |
|                    | Current                                                |      | 30   | 50   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                                                                                       |
| I <sub>PPD</sub>   | V <sub>PP</sub> Deep Power-Down<br>Current             |      | 0.2  | 5    | μΑ   | RP# = GND ± 0.2V                                                                                                                        |
| I <sub>PPW</sub>   | V <sub>PP</sub> Word Write Current                     |      | 10   | 15   | mA   | V <sub>PP</sub> = 12.0V ± 5%<br>Word Write in Progress                                                                                  |
|                    |                                                        |      | 15   | 25   | mA   | V <sub>PP</sub> = 5.0V ± 10%<br>Word Write in Progress                                                                                  |
| I <sub>PPE</sub>   | V <sub>PP</sub> Block Erase Current                    |      | 4    | 10   | mA   | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress                                                                                 |
|                    |                                                        |      | 14   | 20   | mA   | V <sub>PP</sub> = 5.0V ± 10%<br>Block Erase in Progress                                                                                 |
| IPPES              | V <sub>PP</sub> Erase Suspend<br>Current               |      | 30   | 50   | μΑ   | Block Erase Suspended                                                                                                                   |
| V <sub>PPLK</sub>  | V <sub>PP</sub> Erase/Write Lock<br>Voltage            | 0.0  |      | 1.5  | ٧    |                                                                                                                                         |
| V <sub>PPH</sub> 1 | V <sub>PP</sub> during Write/Erase<br>Operations       | 4.5  | 5.0  | 5.5  | ٧    |                                                                                                                                         |
| V <sub>PPH</sub> 2 | V <sub>PP</sub> during Write/Erase<br>Operations       | 11.4 | 12.0 | 12.6 | ٧    |                                                                                                                                         |
| V <sub>LKO</sub>   | V <sub>CC</sub> Erase/Write Lock<br>Voltage            | 2.0  |      |      | V    |                                                                                                                                         |



Table 3. 28F016XD Added/Revised DC Characteristics  $V_{CC}=5.0V~\pm~0.5V,~T_{A}=0^{\circ}C~to~+70^{\circ}C$ 

| Sym               | Parameter                                              | Min | Тур | Max | Unit    | Test Condition                                                                                                                                                                                                                |
|-------------------|--------------------------------------------------------|-----|-----|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>CC</sub> 1 | V <sub>CC</sub> Word Read Current                      |     | 90  | 120 | mA      | $\begin{array}{l} V_{CC} = V_{CC}  \text{Max} \\ \text{RAS\#, CAS\#} = V_{\text{IL}} \\ \text{RAS\#, CAS\#, Addr. Cycling @t}_{\text{RC}} = \min \\ I_{OUT} = 0  \text{mA} \\ \text{Inputs} = \text{TTL or CMOS} \end{array}$ |
| I <sub>CC</sub> 2 | V <sub>CC</sub> Standby Current                        |     | 2   | 4   | mA<br>· | $V_{CC} = V_{CC} Max$<br>RAS#, CAS#, RP# = $V_{IH}$<br>WP# = $V_{IL}$ or $V_{IH}$                                                                                                                                             |
| I <sub>CC</sub> 3 | V <sub>CC</sub> RAS#-Only<br>Refresh Current           |     | 90  | 120 | mA      | $\begin{array}{l} V_{CC} = V_{CC}Max \\ CAS\# = V_{IH} \\ RAS\# = V_{IL} \\ RAS\#, Addr.Cycling@t_{RC} = min \\ Inputs = TTLorCMOS \end{array}$                                                                               |
| Icc4              | V <sub>CC</sub> Fast Page Mode<br>Word Read Current    |     | 80  | 110 | mA      | $\begin{array}{l} V_{CC} = V_{CC}  \text{Max} \\ \text{RAS\#, CAS\#} = V_{IL} \\ \text{CAS\#, Addr. Cycling @t}_{PC} = \text{min} \\ I_{OUT} = 0  \text{mA} \\ \text{Inputs} = V_{IL}  \text{or}  V_{IH} \end{array}$         |
| I <sub>CC</sub> 5 | V <sub>CC</sub> Standby Current                        |     | 70  | 130 | μΑ      | $\begin{aligned} &V_{CC} = V_{CC}Max \\ &RAS\#,CAS\#,RP\# = V_{CC} \pm 0.2V \\ &WP\# = V_{CC} \pm 0.2V or \\ &GND \pm 0.2V \end{aligned}$                                                                                     |
| I <sub>CC</sub> 6 | V <sub>CC</sub> CAS#-Before-RAS#<br>Refresh Current    |     | 50  | 65  | mA      | $V_{CC} = V_{CC}$ Max $CAS\#$ , $RAS\# = V_{IL}$ $CAS\#$ , $RAS\#$ , $Addr$ . Cycling $@t_{RC} = min$ Inputs = TTL or CMOS                                                                                                    |
| I <sub>CC</sub> 7 | V <sub>CC</sub> Standby Current<br>(Self Refresh Mode) |     | 50  | 65  | mA      | $\begin{aligned} & V_{CC} = V_{CC}  Max \\ & RAS\#, CAS\# = V_{IL} \\ & I_{OUT} = 0  mA \\ & Inputs = V_{IL}  or  V_{IH} \end{aligned}$                                                                                       |
| ICCD              | V <sub>CC</sub> Deep Power-Down<br>Current             |     | 2   | 5   | μΑ      | RP# = GND ± 0.2V                                                                                                                                                                                                              |
| Iccw              | V <sub>CC</sub> Word Write Current                     |     | 25  | 35  | mA      | Word Write in Progress V <sub>PP</sub> = 12.0V ± 5%                                                                                                                                                                           |
|                   |                                                        |     | 25  | 40  | mA      | Word Write in Progress V <sub>PP</sub> = 5.0V ± 10%                                                                                                                                                                           |
| ICCE              | V <sub>CC</sub> Block Erase Current                    |     | 18  | 25  | mA      | Block Erase in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                                                                                                                                                                       |
|                   |                                                        |     | 20  | 30  | mA      | Block Erase in Progress<br>V <sub>PP</sub> = 5.0V ± 10%                                                                                                                                                                       |
| ICCES             | V <sub>CC</sub> Erase Suspend<br>Current               |     | 2   | 4   | mA      | RAS#, CAS# = V <sub>IH</sub><br>Block Erase Suspended                                                                                                                                                                         |



Table 3. 28F016XD Added/Revised DC Characteristics (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Sym                | Parameter                                        | Min  | Тур   | Max  | Unit | Test Condition                                          |
|--------------------|--------------------------------------------------|------|-------|------|------|---------------------------------------------------------|
| IPPS               | V <sub>PP</sub> Standby/Read                     |      | ·± 1· | ± 10 | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                       |
| ٠.                 | Current                                          |      | 30    | 50   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                       |
| I <sub>PPD</sub>   | V <sub>PP</sub> Deep Power-Down<br>Current       |      | 0.2   | 5    | μΑ   | RP# = GND ± 0.2V                                        |
| IPPW               | V <sub>PP</sub> Word Write Current               |      | 7     | 12   | mA   | V <sub>PP</sub> = 12.0V ± 5%<br>Word Write in Progress  |
|                    |                                                  |      | 17    | 22   | mA   | V <sub>PP</sub> = 5.0V ± 10%<br>Word Write in Progress  |
| I <sub>PPE</sub>   | V <sub>PP</sub> Block Erase Current              | ·    | 5     | 10   | mA   | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress |
|                    |                                                  | •    | 16    | 20   | mA   | V <sub>PP</sub> = 5.0V ± 10%<br>Block Erase in Progress |
| I <sub>PPES</sub>  | V <sub>PP</sub> Erase Suspend<br>Current         |      | 30    | 50   | μΑ   | Block Erase Suspended                                   |
| V <sub>PPLK</sub>  | V <sub>PP</sub> Erase/Write Lock<br>Voltage      | 0.0  |       | 1.5  | V    |                                                         |
| V <sub>PPH</sub> 1 | V <sub>PP</sub> during Write/Erase<br>Operations | 4.5  | 5.0   | 5.5  | ٧    |                                                         |
| V <sub>PPH</sub> 2 | V <sub>PP</sub> during Write/Erase<br>Operations | 11.4 | 12.0  | 12.6 | ٧    |                                                         |
| V <sub>LKO</sub>   | V <sub>CC</sub> Erase/Write Lock<br>Voltage      | 2.0  |       |      | V    |                                                         |

#### 2.2 Timing Specifications

28F016XD timing specifications are divided into the following categories in the datasheet.

- Common Parameters
- Read Cycle
- Write Cycle
- Read-Modify-Write Cycle
- Fast Page Mode Cycle (including fast page mode read-modify-write)
- Refresh Cycle (including refresh period)
- Miscellaneous

Many 28F016XD specifications match or improve on those of 60 ns and 70 ns DRAMs. Programming additional DRAM controller wait states will accommodate most slower 28F016XD specs.

In some cases, specifications that have identical values for both reads and writes to DRAM (such as RAS# and CAS# pulse widths and hold times), have been differentiated (separate specs for read and write) on the 28F016XD. This differentiation both accurately reflects 28F016XD functionality and improves the DRAM controller interface to 28F016XD, in some cases.

#### **Common Parameters**

Table 4 compares 28F016XD common parameters to DRAM, with incompatible specifications shaded for emphasis. Areas where the 28F016XD improves upon DRAM specifications are outlined in bold. Notice that the 28F016XD's RAS# precharge time specification is much shorter than that for DRAM, while the 28F016XD's CAS# precharge time specification is slightly longer. Also, the 28F016XD's row address hold time after RAS#, column address hold time after CAS# and CAS#-to-RAS# precharge time are slightly longer than those for DRAM.



Table 4. 28F016XD Common Parameters Compared to 60-70 ns 16-Mbit DRAM

| Symbol           | Description                        | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |  |  |
|------------------|------------------------------------|----------------|--------------------|----------------|--------------------|--|--|
| t <sub>RP</sub>  | RAS# Precharge Time (min)          | 40 ns          | 10 ns              | 40-50 ns       | 10 ns              |  |  |
| t <sub>CP</sub>  | CAS# Precharge Time (min)          | 10 ns          | 15 ns              | 10 ns          | 15 ns              |  |  |
| t <sub>ASR</sub> | Row Address Set-Up Time (min)      | 0 ns           | 0 ns               | 0 ns           | 0 ns               |  |  |
| t <sub>RAH</sub> | Row Address Hold Time (min)        | 10 ns          | 15 ns              | 10 ns          | 15 ns              |  |  |
| t <sub>ASC</sub> | Column Address Set-Up Time (min)   | 0 ns           | 0 ns               | 0 ns           | 0 ns               |  |  |
| t <sub>CAH</sub> | Column Address Hold Time (min)     | 10-15 ns       | 20 ns              | 10-15 ns       | 20 ns              |  |  |
| t <sub>CRP</sub> | CAS# to RAS# Precharge Time (min)  | 5 ns           | 10 ns              | 5 ns           | 10 ns              |  |  |
| t <sub>DZO</sub> | OE# Delay Time from Data-In (min)  | 0 ns           | 0 ns               | 0 ns           | 0 ns               |  |  |
| t <sub>DZC</sub> | CAS# Delay Time from Data-In (min) | 0 ns           | 0 ns               | 0 ns           | 0 ns               |  |  |

#### **Read Cycle Specifications**

28F016XD read cycle specification incompatibilities compared to DRAM can be summarized in the following three points:

- The 28F016XD's access time from column address is longer than that for DRAM
- The 28F016XD's access time from OE# and CAS# active is longer than that for DRAM

 The 28F016XD's data tri-state delay from OE#, RAS# or CAS# inactive is longer than that for DRAM

Table 5 compares 28F016XD read cycle specifications to DRAM, with incompatible specifications shaded for emphasis. Areas where the 28F016XD improves upon DRAM specifications are outlined in bold.



Table 5. 28F016XD Read Cycle Specifications Compared to 60-70 ns 16-Mbit DRAM

| Sym                 | Description                                      | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |
|---------------------|--------------------------------------------------|----------------|--------------------|----------------|--------------------|
| t <sub>HC(H)</sub>  | Random Read Cycle Time (min)                     | 110 ns         | 105 ns             | 110-130 ns     | 95 ns              |
| t <sub>RAS(R)</sub> | RAS# Pulse Width (Reads) (min)                   | 70 ns          | 95 ns              | 60-70 ns       | 85 ns              |
| tCAS(R)             | CAS# Pulse Width (Reads) (min)                   | 15 ns          | 40 ns              | 15-20 ns       | 35 ns              |
| t <sub>RCD(R)</sub> | RAS# to CAS# Delay Time (Reads) (min)            | 15-20 ns       | 15 ns              | 15-20 ns       | 15 ns              |
| t <sub>RSH(R)</sub> | RAS# Hold Time (Reads) (min)                     | 15 ns          | 30 ns              | 15-20 ns       | 30 ns              |
| t <sub>CSH(R)</sub> | CAS# Hold Time (Reads) (min)                     | 70 ns          | 95 ns              | 60-70 ns       | 85 ns              |
| †RAC                | Access Time from RAS# (max)                      | 70 ns          | 95 ns              | 60-70 ns       | 85 ns              |
| †CAC                | Access Time from CAS# (max)                      | 15 ns          | 40 ns              | 15-20 ns       | 35 ns              |
| taa                 | Access Time from Column Address (max)            | 30 ns          | 75 ns              | 30-35 ns       | 65 ns              |
| t <sub>OEA</sub>    | OE# Access Time (max)                            | 13-15 ns       | 40 ns              | 15-20 ns       | 35 ns              |
| tacs                | Read Command Set-Up Time (min)                   | 0 ns           | 5 ns               | 0 ns           | 5 ns               |
| t <sub>RCH</sub>    | Read Command Hold Time Referenced to CAS# (min)  | 0 ns           | 0 ns               | 0 ns           | 0 ns               |
| t <sub>RRH</sub>    | Read Command Hold Time Referenced to RAS# (min)  | 0 ns           | 0 ns               | 0 ns           | 0 ns               |
| t <sub>RAL</sub>    | Column Address to RAS# Lead Time (min)           | 75 ns          | 15 ns              | 30-35 ns       | 15 ns              |
| tCAL                | Column Address to CAS# Lead Time (min)           | 30 ns          | 75 ns              | 30-35 ns       | 65 ns              |
| t <sub>CLZ</sub>    | CAS# to Output in Low-Z (min)                    | 0 ns           | 0 ns               | 0 ns           | 0 ns               |
| toH                 | Output Data Hold Time (min)                      | 0 ns           | 0 ns               | 0 ns           | 0 ns               |
| tоно                | Output Data Hold Time from OE# (min)             | 0 ns           | 0 ns               | 0 ns           | 0 ns               |
| toff                | Output Buffer Turn-Off Delay (max)               | 13-15 ns       | 30 ns              | 15 ns          | 30 ns              |
| toez                | Output Buffer Turn-Off Delay Time from OE# (max) | 13–15 ns       | 30 ns              | 15-20 ns       | 30 ns              |
| tCDD                | CAS# to Data in Delay Time (min)                 | 13–15 ns       | 30 ns              | 15-20 ns       | 30 ns              |



#### **Write Cycle Specifications**

Most 28F016XD write cycle specification incompatibilities compared to DRAM can be summarized by the fact that the 28F016XD CAS# active pulse width during writes is longer than the DRAM requirement. The 28F016XD's data hold time and WE# hold time from CAS# are also longer than that specified for 3.3V DRAM. Table 6 compares 28F016XD write cycle specifications to DRAM, with incompatible specifications shaded for emphasis. Areas where the 28F016XD improves upon DRAM specifications are outlined in bold.

#### **Read-Modify-Write Cycle Specifications**

28F016XD read-modify-write cycle specification incompatibilities compared to DRAM are caused by a combination of the read and write cycle incompatibilities described earlier. Read-modify-cycles are commonly used to "flip bits" in DRAM data tables and video memory. Given the flash memory usage model (read mostly, alter data infrequently), read-modify-write cycles to the 28F016XD will not occur in most applications.

Table 7 compares 28F016XD read-modify-write cycle specifications to DRAM, with incompatible specifications shaded for emphasis.

Table 6. 28F016XD Write Cycle Specifications Compared to 60-70 ns 16-Mbit DRAM

| Sym                 | Description                                      | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |
|---------------------|--------------------------------------------------|----------------|--------------------|----------------|--------------------|
| tac(w)              | Random Write Cycle Time (min)                    | 110 ns         | 90 ns              | 110-130 ns     | 75 ns              |
| t <sub>RAS(W)</sub> | RAS# Pulse Width (Writes) (min)                  | 70 ns          | 80 ns              | 60-70 ns       | 65 ns              |
| tcas(w)             | CAS# Pulse Width (Writes) (min)                  | 15 ns          | 65 ns              | 15-20 ns       | 50 ns              |
| t <sub>RCD(W)</sub> | RAS# to CAS# Delay Time (Writes) (min)           | 15 ns          | 15 ns              | 15 ns          | 15 ns              |
| t <sub>RSH(W)</sub> | RAS# Hold Time (Writes) (min)                    | 15 ns          | 65 ns              | 15-20 ns       | 50 ns              |
| tcsh(w)             | CAS# Hold Time (Writes) (min)                    | 70 ns          | 80 ns              | 60-70 ns       | 65 ns              |
| twcs                | Write Command Set-Up Time (min)                  | 0 ns           | 0 ns               | 0 ns           | 0 ns               |
| twch                | Write Command Hold Time (min)                    | 8-10 ns        | 15 ns              | 10-15 ns       | 15 ns              |
| twcR                | Write Command Hold Time Referenced to RAS# (min) | 30-55 ns       | 30 ns              | 45 ns          | 30 ns              |
| t <sub>WP</sub>     | Write Command Pulse Width (min)                  | 15 ns          | 15 ns              | 15 ns          | 15 ns              |
| t <sub>RWL</sub>    | Write Command to RAS# Lead Time (min)            | 15-20 ns       | 65 ns              | 15-20 ns       | 50 ns              |
| town                | Write Command to CAS# Lead Time (min)            | 15 ns          | 65 ns              | 15-20 ns       | 50 ns              |
| t <sub>DS</sub>     | Data-In Set-Up Time (min)                        | 0 ns           | 0 ns               | 0 ns           | 0 ns               |
| t <sub>DH</sub>     | Data-In Hold Time (min)                          | 10 ns          | 15 ns              | 10-15 ns       | 15 ns              |

Table 7. 28F016XD Read-Modify-Write Cycle Specifications Compared to 60-70 ns 16-Mbit

| Sym              | Description                      | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |
|------------------|----------------------------------|----------------|--------------------|----------------|--------------------|
| t <sub>RWC</sub> | Read-Modify-Write Cycle Time     | 155-160 ns     | 200 ns             | 150–185 ns     | 175 ns             |
| town             | CAS# to WE# Delay Time           | 38-40 ns       | 70 ns              | 35-50 ns       | 65 ns              |
| tawo             | Column Address to WE# Delay Time | 53-55 ns       | 105 ns             | 50-65 ns       | 100 ns             |
| tOEH             | OE# Command Hold Time            | 0-15 ns        | 15 ns              | 15-20 ns       | 15 ns              |



#### **Fast Page Mode Cycle Specifications**

28F016XD fast page mode cycle specification incompatibilities compared to DRAM have the same root causes as the read and write cycle incompatibilities described earlier. Fast page mode read-modify-write cycles to the 28F016XD will not occur in the majority of applications.

Table 8 compares 28F016XD fast page mode cycle specifications to DRAM, with incompatible specifications shaded for emphasis. Areas where the 28F016XD improves upon DRAM specifications are outlined in bold.

#### **Refresh Cycle Specifications**

Flash memory does not require refresh to retain stored data contents. However, by interfacing to a DRAM controller, it will automatically receive the same refresh cycles that DRAM receives. The 28F016XD supports all common refresh cycles; CAS#-before-RAS#, RAS#-only, hidden and self-refresh. In these modes, it will either drive or float the data bus just as a DRAM would. Refresh cycles have no other effect on 28F016XD stored data.

Table 9 compares 28F016XD refresh cycle specifications to DRAM, with incompatible specifications shaded for emphasis. Areas where the 28F016XD improves upon DRAM specifications are outlined in bold.

Table 8. 28F016XD Fast Page Mode Cycle Specifications Compared to 60-70 ns 16-Mbit DRAM

| Sym                  | Description                                          | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |
|----------------------|------------------------------------------------------|----------------|--------------------|----------------|--------------------|
| t <sub>PC(R)</sub>   | Fast Page Mode Cycle Time (Reads) (min)              | 35-45 ns       | 75 ns              | 35-45 ns       | 65 ns              |
| t <sub>PC(W)</sub>   | Fast Page Mode Cycle Time (Writes) (min)             | 35-45 ns       | 80 ns              | 35-45 ns       | 65 ns              |
| t <sub>RASP(R)</sub> | RAS# Pulse Width (Reads) (min)                       | 60-70 ns       | 95 ns              | 60 ns          | 85 ns              |
| <sup>†</sup> RASP(W) | RAS# Pulse Width (Writes) (min)                      | 60-70 ns       | 80 ns              | 60 ns          | 65 ns              |
| t <sub>CPA</sub>     | Access Time from CAS# Precharge (max)                | 35-40 ns       | 85 ns              | 35-40 ns       | 70 ns              |
| t <sub>CPW</sub>     | WE# Delay Time from CAS# Precharge (min)             | 10 ns          | 0 ns               | 10 ns          | 0 ns               |
| <sup>†</sup> CPRH(R) | RAS# Hold Time from CAS# Precharge (reads) (min)     | 35 ns          | 75 ns              | 35-45 ns       | 65 ns              |
| tCPRH(W)             | RAS# Hold Time from CAS# Precharge (writes) (min)    | 35 ns          | 80 ns              | 35–45 ns       | 65 ns              |
| t <sub>PRWC</sub>    | Fast Page Mode Read-Modify-Write Cycle<br>Time (min) | 85 ns          | 170 ns             | 85-100 ns      | 145 ns             |



Table 9. 28F016XD Refresh Cycle Specifications Compared to 60-70 ns 16-Mbit DRAM

| Sym              | Description                                          | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |
|------------------|------------------------------------------------------|----------------|--------------------|----------------|--------------------|
| tcsn             | CAS# Set-Up Time (CAS#-before-RAS#<br>Refresh) (min) | 5 ns           | 10 ns              | 10 ns          | 10 ns              |
| t <sub>CHR</sub> | CAS# Hold Time (CAS#-before-RAS#<br>Refresh) (min)   | 10-15 ns       | 10 ns              | 10-20 ns       | 10 ns              |
| t <sub>WRP</sub> | WE# Set-Up Time (CAS#-before-RAS#<br>Refresh) (min)  | 10 ns          | 10 ns              | 10 ns          | 10 ns              |
| twRH             | WE# Hold Time (CAS#-before-RAS#<br>Refresh) (min)    | 15 ns          | 10 ns              | 10-15 ns       | 10 ns              |
| t <sub>RPC</sub> | RAS# Precharge to CAS# Hold Time (min)               | 5 ns           | 10 ns              | 0-10 ns        | 10 ns              |
| †RASS            | RAS# Pulse Width (Self-Refresh Mode) (min)           | 100 μs         | 0 ns               | 100 µs         | 0 ns               |
| taps             | RAS# Precharge Time (Self-Refresh Mode) (min)        | 40 ns          | 10 ns              | 40-50 ns       | 10 ns              |
| t <sub>CPN</sub> | CAS# Precharge Time (Self-Refresh Mode) (min)        | 10 ns          | 10 ns              | 10 ns          | 10 ns              |
| tcHS             | CAS# Hold Time (Self-Refresh Mode) (min)             | 600 ns         | 0 ns               | 600 ns         | 0 ns               |
| t <sub>REF</sub> | Refresh Period (max)                                 | 16 ms          | 8                  | 16 ms          | 8                  |

#### **Miscellaneous Specifications**

The 28F016XD documentation contains timing specifications not found in DRAM datasheets. These timings relate to the 28F016XD's additional control inputs/

outputs and voltages (WP#, RP#, RY/BY#,  $V_{PP}$ ) as well as minimum Data Write and Erase durations. Tables 10 and 11 show these additional specifications, at 3.3V  $V_{CC}$  and 5.0V  $V_{CC}$  respectively.

Table 10. 28F016XD Added/Revised AC Timings

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Versions                                                             | 28F016XD-95 |     |      |
|----------------------------------------------------------------------|-------------|-----|------|
| Parameter                                                            | Min         | Max | Unit |
| RP# High to RAS# going low                                           | 480         |     | ns   |
| RP# Set-Up to WE# going low                                          | 480         |     | ns   |
| V <sub>PP</sub> Set-Up to CAS# high at end of write cycle            | 100         |     | ns   |
| WE# High to RY/BY# going low                                         |             | 100 | ns   |
| RP# Hold from Valid Status Register Data and RY/BY# high             | 0           |     | ns   |
| V <sub>PP</sub> Hold from Valid Status Register Data and RY/BY# high | 0           |     | ns   |
| V <sub>CC</sub> at 3.0V (minimum) to RP# high                        | 2           |     | μs   |



Table 10. 28F016XD Added/Revised AC Timings (Continued)  $V_{CC}=3.3V~\pm~0.3V,~V_{PP}=5.0V~\pm~0.5V,~T_A=0^{\circ}C$  to  $+70^{\circ}C$ 

| Sym                 | Parameter                   | Min | Тур  | Max | Units |
|---------------------|-----------------------------|-----|------|-----|-------|
|                     | Page Buffer Word Write Time | TBD | 12.1 | TBD | μs    |
| t <sub>WHRH</sub> 1 | Word Write Time             | TBD | 24.0 | TBD | μs    |
| t <sub>WHRH</sub> 3 | Block Write Time            | TBD | 0.8  | TBD | sec   |
|                     | Block Erase Time            | TBD | 1.4  | TBD | sec   |
|                     | Full Chip Erase Time        | TBD | 44.8 | TBD | sec   |

 $V_{CC}$  = 3.3V  $\pm$  0.3V,  $V_{PP}$  = 12.0V  $\pm$  0.6V,  $T_A$  = 0°C to +70°C

| Sym                 | Parameter                   | Min | Тур  | Max | Units |
|---------------------|-----------------------------|-----|------|-----|-------|
|                     | Page Buffer Word Write Time | TBD | 4.4  | TBD | μs    |
| t <sub>WHRH</sub> 1 | Word Write Time             | 5   | 9    | TBD | μs    |
| t <sub>WHRH</sub> 3 | Block Write Time            | TBD | 0.3  | 1.0 | sec   |
|                     | Block Erase Time            | 0.3 | 0.8  | 10  | sec   |
|                     | Full Chip Erase Time        | TBD | 25.6 | TBD | sec   |

## Table 11. 28F016XD Added/Revised AC Timings $V_{CC}=5.0V\,\pm\,0.5V,\,T_{A}=0^{\circ}C$ to $+70^{\circ}C$

| Versions                                                             | 28F016XD-85 |     |      |
|----------------------------------------------------------------------|-------------|-----|------|
| Parameter                                                            | Min         | Max | Unit |
| RP# High to RAS# going low                                           | 300         |     | ns   |
| RP# Set-Up to WE# going low                                          | 300         |     | ns   |
| V <sub>PP</sub> Set-Up to CAS# high at end of write cycle            | 100         |     | ns   |
| WE# High to RY/BY# going low                                         |             | 100 | ns   |
| RP# Hold from Valid Status Register Data and RY/BY# High             | 0           |     | ns   |
| V <sub>PP</sub> Hold from Valid Status Register Data and RY/BY# High | 0           |     | ns   |
| V <sub>CC</sub> at 4.5V (minimum) to RP# High                        | 2           |     | μs   |



#### Table 11. 28F016XD Added/Revised AC Timings (Continued)

 $V_{CC}$  = 5.0V  $\pm$  0.5V,  $V_{PP}$  = 5.0V  $\pm$  0.5V,  $T_A$  = 0°C to +70°C

| Sym                 | Parameter                   | Min | Тур  | Max | Units |
|---------------------|-----------------------------|-----|------|-----|-------|
|                     | Page Buffer Word Write Time | TBD | 12.1 | TBD | μs    |
| t <sub>WHRH</sub> 1 | Word Write Time             | TBD | 16   | TBD | μs    |
| t <sub>WHRH</sub> 3 | Block Write Time            | TBD | 0.6  | TBD | sec   |
| :                   | Block Erase Time            | TBD | 1.0  | TBD | sec   |
|                     | Full Chip Erase Time        | TBD | 32.0 | TBD | sec   |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Sym                 | Parameter                   | Min | Тур  | Max | Units |
|---------------------|-----------------------------|-----|------|-----|-------|
|                     | Page Buffer Word Write Time | TBD | 4.1  | TBD | μs    |
| t <sub>WHRH</sub> 1 | Word Write Time             | 4.5 | 6    | TBD | μs    |
| t <sub>WHRH</sub> 3 | Block Write Time            | TBD | 0.2  | 1.0 | sec   |
|                     | Block Erase Time            | 0.3 | 0.6  | 10  | sec   |
|                     | Full Chip Erase Time        | TBD | 19.2 | TBD | sec   |

#### 2.3 Package and Pinout

Although the 28F016XD includes all necessary inputs and outputs for interfacing to DRAM controllers, its pinout and package do not match those of DRAMs but instead evolve from other 16-Mbit Intel flash memories. The 28F016XD uses a 56-lead TSOP package, with pinout shown in Figure 1 and package dimensions shown in Figure 2.

Comparable 1M x 16 (16-Mbit) DRAMs use two packages, a 42-lead SOJ and 44-lead TSOP. Examples of these DRAM pinouts are shown in Figures 3 and 4.

Table 12 summarizes pinout comparisons between the 28F016XD in 56-lead TSOP and various DRAM package options.

If compatibility between the 28F016XD and DRAM "footprints" is desired, 28F016XD flash memories can be placed on DRAM-compatible SIMMs. Please see the Additional Information section of this application note for documentation that covers this topic in more detail.





Figure 1. 28F016XD 56-Lead TSOP Type I Pinout Configuration





Figure 2. 28F016XD 56-Lead TSOP Type I Package Dimensions

|                | Family: Thin Small Out-Line Package |             |         |       |  |  |  |
|----------------|-------------------------------------|-------------|---------|-------|--|--|--|
| Symbol         |                                     | Millimeters |         |       |  |  |  |
| _              | Minimum                             | Nominal     | Maximum | Notes |  |  |  |
| Α              |                                     |             | 1.20    |       |  |  |  |
| A <sub>1</sub> | 0.50                                |             |         |       |  |  |  |
| A <sub>2</sub> | 0.965                               | 0.995       | 1.025   |       |  |  |  |
| b              | 0.100                               | 0.150       | 0.200   |       |  |  |  |
| С              | 0.115                               | 0.125       | 0.135   |       |  |  |  |
| D <sub>1</sub> | 18.20                               | 18.40       | 18.60   |       |  |  |  |
| E              | 13.80                               | 14.00       | 14.20   |       |  |  |  |
| е              |                                     | 0.50        |         |       |  |  |  |
| D              | 19.80                               | 20.00       | 20.20   |       |  |  |  |
| L              | . 0.500                             | 0.600       | 0.700   |       |  |  |  |
| N              | ,                                   | 56          |         |       |  |  |  |
| Ø              | 0°                                  | 3°          | 5°      |       |  |  |  |
| Υ              |                                     |             | 0.100   |       |  |  |  |
| Z              | 0.150                               | 0.250       | 0.350   |       |  |  |  |





Figure 3. 16-Mbit DRAM 42-Lead SOJ Pinout Configuration



Figure 4. 16-Mbit DRAM 44-Lead TSOP Pinout Configuration



Table 12. 28F016XD Pinout Compared to 16-Mbit DRAM

| Pin Name         | 42-Lead SOJ DRAM<br>Pin Number | 44-Lead TSOP DRAM<br>Pin Number | 56-Lead TSOP<br>28F016XD Pin<br>Number |
|------------------|--------------------------------|---------------------------------|----------------------------------------|
| V <sub>CC</sub>  | 1, 6, 21                       | 1, 6, 22                        | 9, 31, 37, 43                          |
| V <sub>PP</sub>  | _                              | _                               | 15                                     |
| GND              | 22, 37, 42                     | 23, 39, 44                      | 2, 14, 21, 42, 48                      |
| DQ <sub>0</sub>  | 2                              | 2                               | 33                                     |
| DQ <sub>1</sub>  | 3                              | 3                               | 35                                     |
| DQ <sub>2</sub>  | 4                              | 4                               | 38                                     |
| DQ <sub>3</sub>  | 5                              | 5                               | 40                                     |
| DQ <sub>4</sub>  | 7                              | . 7                             | 44                                     |
| DQ <sub>5</sub>  | 8                              | 8                               | 46                                     |
| DQ <sub>6</sub>  | 9                              | 9                               | 49                                     |
| DQ <sub>7</sub>  | 10                             | 10                              | 51                                     |
| DQ <sub>8</sub>  | 33                             | 35                              | 34                                     |
| DQ <sub>9</sub>  | 34                             | 36                              | 36                                     |
| DQ <sub>10</sub> | 35                             | 37                              | 39                                     |
| DQ <sub>11</sub> | 36                             | 38                              | 41                                     |
| DQ <sub>12</sub> | 38                             | 40                              | 45                                     |
| DQ <sub>13</sub> | 39                             | .41                             | - 47                                   |
| DQ <sub>14</sub> | 40                             | 42                              | 50                                     |
| DQ <sub>15</sub> | 41                             | 43                              | 52                                     |
| Α <sub>0</sub>   | 17                             | 18                              | 28                                     |
| A <sub>1</sub>   | 18                             | 19                              | 27                                     |
| A <sub>2</sub>   | 19                             | 20                              | 26                                     |
| A <sub>3</sub>   | 20                             | 21                              | 25                                     |
| A <sub>4</sub>   | 23                             | 24                              | 24                                     |
| A <sub>5</sub>   | - 24                           | 25                              | 8                                      |
| A <sub>6</sub>   | 25                             | 26                              | 7                                      |
| A <sub>7</sub>   | 26                             | 27                              | 6                                      |
| A <sub>8</sub>   | 27                             | 28                              | 5                                      |
| A <sub>9</sub>   | 28                             | 29                              | 4                                      |
| WE#              | 13                             | 14                              | 55                                     |



Table 12. 28F016XD Pinout Compared to 16-Mbit DRAM (Continued)

| Pin Name | 42-Lead SOJ DRAM<br>Pin Number | 44-Lead TSOP DRAM<br>Pin Number | 56-Lead TSOP<br>28F016XD Pin<br>Number              |
|----------|--------------------------------|---------------------------------|-----------------------------------------------------|
| OE#      | 29                             | 30                              | 54                                                  |
| RAS#     | 14                             | 15                              | 10                                                  |
| CAS#     |                                | _                               | 11                                                  |
| CASL#    | 31                             | 32                              | _                                                   |
| CASH#    | 30                             | 31                              | <del>-</del>                                        |
| RP#      | _                              |                                 | 16                                                  |
| RY/BY#   |                                |                                 | 53                                                  |
| WP#      | 11                             | _                               | 55                                                  |
| NC       | 11, 12, 15, 16, 32             | 11, 12, 13, 33, 34              | 1, 3, 12, 13, 17, 18, 19,<br>20, 22, 23, 29, 30, 32 |

#### 2.4 Capacitance

28F016XD input/output capacitance specifications compared to 16-Mbit DRAMs are shown in Table 13.

Table 13. 28F016XD Capacitance Specifications Compared to 16-Mbit DRAM

| Symbol            | Description                             | DRAM<br>(3.3V) | 28F016XD<br>(3.3V) | DRAM<br>(5.0V) | 28F016XD<br>(5.0V) |
|-------------------|-----------------------------------------|----------------|--------------------|----------------|--------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address Pin | 5 pF           | 8 pF               | 5-6 pF         | 8 pF               |
| C <sub>CTRL</sub> | Capacitance Looking into a Control Pin  | 7 pF           | 8 pF               | 7 pF           | 8 pF               |
| C <sub>OUT</sub>  | Capacitance Looking into an Output Pin  | 7 pF           | 12 pF              | 7-10 pF        | 12 pF              |

### 3.0 28F016XD INTERFACING TO DRAM CONTROLLERS

Section 2.0 identified areas of compatibility and incompatibility between the 28F016XD and DRAMs. This section, on the other hand, discusses how to determine the 28F016XD's ability to interface with an already-designed DRAM controller. Section 3.0 is divided into three topics:

- Configurable Specification Interfacing
- Non-Configurable Specification Interfacing
- Additional 28F016XD Interface Hardware

Figure 5 shows an example interface between the 28F016XD and system CPU via a standard DRAM

controller. This interface diagram will be used in the example calculations to follow. The DRAM controller provides no RD# output, so the 28F016XD's OE# input is grounded. CAS# low in conjunction with active WR# is decoded as a write, overriding OE#. Parity is disabled within the DRAM controller (at least for the banks in which the 28F016XD resides).

Note that data buffering is done by the DRAM controller itself. In designs that do not provide this capability or in very high chip count arrays, transceivers can be used to minimize CPU local bus or DRAM bus loading by the DRAM/28F016XD memory subsystem. When determining the need for isolation transceivers, keep in mind that the 28F016XD input and output capacitance are higher than those for comparable DRAM (as explained in Section 2.4).





Figure 5. Example DRAM Controller Interface to the 28F016XD

Please reference Figures 6 and 7 for example DRAM controller waveforms, which will also be used in calculations to follow. These diagrams show timings for a 1x-clock driven (i.e., 25 or 33 MHz) system. For a 2x-clock driven (i.e., 50 or 66 MHz) DRAM controller waveform, the main difference is in the clock period shown; CLK is halved within the DRAM controller to generate its signals. The X-Y-Y-Y format shows how many 1x or 2x clock cycles are used for the first data access (including RAS# transitions) and subsequent accesses (toggling CAS# in fast page mode).

The examples assume that both minimum and maximum delays after CLK edges are provided for RAS#, CAS# and addresses. If minimum delays are not given in DRAM controller documentation, contact the vendor for more information. Alternatively, a 0 ns delay can be assumed, although this may impact interface to the 28F016XD.

X-Y-Y-Y wait-state formats are often shown in conjunction with a clock frequency (i.e., 4-2-2-2 at 33 MHz) in DRAM controller datasheets. This does

not mean that this wait-state setting is unique to the CLK shown; wait-state settings are frequency-independent from the DRAM controller point of view. The wait-state format/clock frequency combination simply indicates a standard DRAM speed bin setting (i.e., 60 or 70 ns DRAM). For DRAM controllers with minimal flexibility in wait-state configuration, the 28F016XD may still be interface-compatible, albeit at a slower frequency.

The following sections will make the assumptions listed below:

- The DRAM controller will not generate read-modify-write cycles to the 28F016XD.
- Only areas in which 28F016XD specifications exceed those for DRAM will be discussed. Compatibility is assumed when 28F016XD specifications match or improve upon DRAM specifications.
- Signal transition times (rise and fall) will not be included in example calculations.





Figure 6. 4-2-2-2 Fast Page Mode DRAM Controller Sequence



Figure 7. 5-3-3-3 Fast Page Mode DRAM Controller Sequence



### 3.1 Configurable Specification Interfacing

Many 28F016XD specification incompatibilities (with respect to DRAM) can be resolved by programming the DRAM controller for additional wait states. Most DRAM controllers have a programmable CAS# low time (and some can be programmed with different settings for reads and writes). Additionally, some DRAM

#### **t**CAC

This specification gives the timing delay from CAS# active to valid data during memory reads. When calculating the required  $t_{\rm CAC}$  setting needed to interface the 28F016XD to the system CPU, include not only the raw memory access time but also the propagation delay of the DRAM controller buffers or transceiver logic, and the data set-up time to CLK of the CPU.

The example shows that at 33 MHz, a 5-3-3-3 DRAM controller setting will accommodate the 28F016XD t<sub>CAC</sub> access time, buffer/transceiver propagation delay and CPU set-up time requirements.

controllers also allow the RAS#-to-CAS# delay to be programmed. Both of these settings automatically extend the RAS# low time.

Focus on the following specifications when determining proper DRAM controller configuration for the 28F016XD. With the exception of specifications discussed in Section 3.2, all other specification incompatibilities between the 28F016XD and DRAM will be satisfied if these four requirements are met.

Example: t<sub>4</sub> = 5 ns (max) t<sub>CLK</sub> = 30 ns (33 MHz CLK) t<sub>PROP</sub> = 8 ns (max) t<sub>SETUP</sub> = 2 ns (min) t<sub>CAC</sub> (required) = (t<sub>CLK</sub> - t<sub>4</sub>) - t<sub>PROP</sub> - t<sub>SETUP</sub> + (wait states)

| DRAM Controller t <sub>CAC</sub> Requirement (4-2-2-2) | DRAM Controller              | 28F016XD t <sub>CAC</sub> | 28F016XD t <sub>CAC</sub> |
|--------------------------------------------------------|------------------------------|---------------------------|---------------------------|
|                                                        | t <sub>CAC</sub> Requirement | Specification             | Specification             |
|                                                        | (5-3-3-3)                    | (5.0V V <sub>CC</sub> )   | (3.3V V <sub>CC</sub> )   |
| 15 ns                                                  | 45 ns                        | 35 ns                     | 40 ns                     |

#### tAA

This specification gives the timing delay from column address stable to valid data during memory reads. The 28F016XD is an enhanced fast page mode memory; a read access begins when column address is stable versus waiting to begin until CAS# transitions low. DRAM controllers that can provide a stable address in advance of CAS#'s active transition will interface to the 28F016XD with minimal additional wait states.

The example shows that at 33 MHz, a 5-3-3-3 DRAM controller setting will accommodate the 28F016XD t<sub>AA</sub> access time, buffer/transceiver propagation delay and CPU set-up time requirements.

Example:  $t_3 = 5$  ns (max)  $t_{CLK} = 30$  ns (33 MHz CLK)  $t_{PROP} = 8$  ns (max)  $t_{SETUP} = 2$  ns (min)  $t_{AA}$  (required) =  $(t_{CLK} + t_{CLK} - t_3) - t_{PROP} - t_{SETUP} +$  (wait states)

| DRAM Controller t <sub>AA</sub> Requirement (4-2-2-2) | DRAM Controller t <sub>AA</sub> | 28F016XD t <sub>AA</sub> | 28F016XD t <sub>AA</sub> |
|-------------------------------------------------------|---------------------------------|--------------------------|--------------------------|
|                                                       | Requirement                     | Specification            | Specification            |
|                                                       | (5-3-3-3)                       | (5.0V V <sub>CC</sub> )  | (3.3V V <sub>CC</sub> )  |
| 45 ns                                                 | 75 ns                           | 65 ns                    | 75 ns                    |



#### **TRAC**

This specification gives the timing delay from RAS# active to valid data during memory reads.

The example shows that at 33 MHz, a 5-3-3-3 DRAM controller setting will accommodate the 28F016XD  $t_{RAC}$  access time, buffer/transceiver propagation delay and CPU set-up time requirements.

| Example:                                               |   |       |
|--------------------------------------------------------|---|-------|
| $t_2 = 5 \text{ ns (max)}$                             |   |       |
| $t_{CLK} = 30 \text{ ns} (33 \text{ MHz CLK})$         |   |       |
| $t_{PROP} = 8 \text{ ns (max)}$                        |   |       |
| $t_{SETUP} = 2 \text{ ns (min)}$                       |   |       |
| $t_{RAC}$ (required) = $(t_{CLK} + t_{CLK} + t_{CLK})$ | - | $t_2$ |
| $-t_{PROP} - t_{SETUP} + (wait states)$                |   |       |

|   | DRAM Controller              | DRAM Controller              | 28F016XD t <sub>RAC</sub> | 28F016XD t <sub>RAC</sub> |
|---|------------------------------|------------------------------|---------------------------|---------------------------|
|   | t <sub>RAC</sub> Requirement | t <sub>RAC</sub> Requirement | Specification             | Specification             |
|   | (4-2-2-2)                    | (5-3-3-3)                    | (5.0V V <sub>CC</sub> )   | (3.3V V <sub>CC</sub> )   |
| I | 75 ns                        | 105 ns                       | 85 ns                     | 95 ns                     |

#### tCAS(W)

This specification defines the minimum CAS#-active time required to successfully write a command to the 28F016XD or to write data to 28F016XD's Page Buffer.

The example shows that at 33 MHz, a 5-3-3-3 DRAM controller setting will accommodate the 28F016XD t<sub>CAS(W)</sub> time at 5.0V V<sub>CC</sub>, but that a 6-4-4-4 setting or lower CLK frequency will be required at 3.3V V<sub>CC</sub>.

| Example:                                       |                 |
|------------------------------------------------|-----------------|
| $t_4 = 5 \text{ ns (max)}$                     |                 |
| $t_5 = 2 \text{ ns (min)}$                     | 7               |
| $t_{CLK} = 30 \text{ ns} (33 \text{ MHz CLK})$ |                 |
| $t_{CAC(W)}$ (required) = $(t_{CLK} + t_5 -$   | $t_4$ ) + (wait |
| states)                                        |                 |

| DRAM Controller                 | DRAM Controller                 | 28F016XD t <sub>CAS(W)</sub> | 28F016XD t <sub>CAS(W)</sub> |
|---------------------------------|---------------------------------|------------------------------|------------------------------|
| t <sub>CAS(W)</sub> Requirement | t <sub>CAS(W)</sub> Requirement | Specification                | Specification                |
| (4-2-2-2)                       | (5-3-3-3)                       | (5.0V V <sub>CC</sub> )      | (3.3V V <sub>CC</sub> )      |
| 27 ns                           | 57 ns                           | 50 ns                        | 65 ns                        |

## 3.2 Non-Configurable Specification Interfacing

Some 28F016XD specification incompatibilities (with respect to DRAM) cannot be resolved by configuring DRAM controller wait states. Determining DRAM controller compatibility with these specifications is crucial for ensuring the ability to interface to the 28F016XD.

Focus on the following non-configurable specifications when determining proper DRAM controller configuration for 28F016XD. In combination with the configurable specifications discussed in Section 3.1, all other specification incompatibilities between the 28F016XD and DRAM will be satisfied if these requirements are met.



#### **tCAH**

This specification describes the minimum column address hold after CAS# active transitions.

dress hold after CAS# active transitions.  $t_{CLK} = 30 \text{ ns } (33 \text{ MHz CLK})$   $t_{CAH} \text{ (required)} = t_{CLK} + t_8 - t_4$ In this example, the 28F016XD successfully interfaces to the DRAM controller.

| Example:                                       |  |
|------------------------------------------------|--|
| $t_4 = 5 \text{ ns (max)}$                     |  |
| $t_8 = 2 \text{ ns (min)}$                     |  |
| $t_{CLK} = 30 \text{ ns} (33 \text{ MHz CLK})$ |  |

DRAM Controller t<sub>CAH</sub>
Requirement

28F016XD t<sub>CAH</sub> Specification
(5.0V V<sub>CC</sub>)

27 ns

20 ns

28F016XD t<sub>CAH</sub> Specification
(3.3V V<sub>CC</sub>)

#### tcp

This specification describes the minimum CAS#-high (inactive) time requirement between consecutive accesses to the 28F016XD.

Example:  $t_4 = 2 \text{ ns (min)}$   $t_5 = 5 \text{ ns (max)}$   $t_{CLK} = 30 \text{ ns (33 MHz CLK)}$  $t_{CP} \text{ (required)} = t_{CLK} + t_4 - t_5$ 

In this example, the 28F016XD successfully interfaces to the DRAM controller.

| DRAM Controller t <sub>CP</sub> Requirement | 28F016XD t <sub>CP</sub> Specification<br>(5.0V V <sub>CC</sub> ) | 28F016XD t <sub>CP</sub> Specification<br>(3.3V V <sub>CC</sub> ) |
|---------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|
| 27 ns                                       | 15 ns                                                             | 15 ns                                                             |

#### **tCRP**

This specification describes the minimum CAS#-high (inactive) to RAS#-low (active) precharge time requirement between consecutive accesses to the 28F016XD.

Example:

 $t_2 = 2 \text{ ns (min)}$  $t_5 = 5 \text{ ns (max)}$ 

 $t_{CLK} = 30 \text{ ns} (33 \text{ MHz CLK})$ 

 $t_{CRP}$  (required) =  $t_{CLK} + t_2 - t_5$ 

In this example, the 28F016XD successfully interfaces to the DRAM controller.

| DRAM Controller t <sub>CRP</sub> Requirement | 28F016XD t <sub>CRP</sub> Specification (5.0V $V_{CC}$ ) | 28F016XD $t_{CRP}$ Specification (3.3V $v_{CC}$ ) |
|----------------------------------------------|----------------------------------------------------------|---------------------------------------------------|
| 27 ns                                        | 10 ns                                                    | 10 ns                                             |



#### **trah**

This specification describes the minimum row address hold after RAS# active transitions.

In this example, the 28F016XD successfully interfaces to the DRAM controller.

| Example:                                       |
|------------------------------------------------|
| $t_2 = 5 \text{ ns (max)}$                     |
| $t_3 = 2 \text{ ns (min)}$                     |
| $t_{CLK} = 30 \text{ ns} (33 \text{ MHz CLK})$ |
| $t_{RAH}$ (required) = $t_{CLK} + t_3 - t_2$   |

| DRAM Controller t <sub>RAH</sub><br>Requirement | 28F016XD t <sub>RAH</sub> Specification (5.0V V <sub>CC</sub> ) | 28F016XD t <sub>RAH</sub> Specification<br>(3.3V V <sub>CC</sub> ) |
|-------------------------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------|
| 27 ns                                           | 15 ns                                                           | 15 ns                                                              |

#### **t**RCS

This specification describes the minimum WE# inactive setup time to CAS# for reads.

Most DRAM controllers available today include a RD# output and support early write cycles. In these

#### toff, toex and todd

 $t_{OFF}$  specifies the maximum delay from CAS# inactive until the 28F016XD outputs transition to high-Z.  $t_{OEX}$  is similar, and specifies delay from OE# inactive.  $t_{CDD}$  specifies the minimum delay from CAS# inactive until the DRAM controller can drive the data bus (for writes to memory). These specifications are closely related to each other.

#### twch

This specification defines the minimum WE# hold time after CAS# active transitions. The vast majority of DRAM controllers will hold WE# active throughout the CAS#-low interval, automatically satisfying twCh. For those that do not, the example below shows how to calculate the timing relationship between CAS# and WE#. When determining specification t6, ensure that it is being specified from the same CLK edge as t4, or add appropriate tCLK periods to adjust t6 appropriately.

In this example, the 28F016XD successfully interfaces to the DRAM controller.

cases, WE# is transitioned inactive within a write, as soon as CAS# is activated "low", or at the conclusion of a write. This guarantees that WE# will be inactive "high" in advance of subsequent reads.

The simplest method of ensuring that system designs accommodate these specifications is to insert a software delay between a read from the 28F016XD and a write to memory in the same bank. This gives the 28F016XD adequate time to disable its outputs and avoids data bus contention. Alternatively, transceivers (with faster output float times) can be placed between 28F016XD data outputs and the DRAM controller data bus.

Example:

 $t_4 = 5 \text{ ns (max)}$ 

 $t_6 = 20 \text{ ns (min)}$ 

 $t_{CLK} = 30 \text{ ns} (33 \text{ MHz CLK})$ 

 $t_{WCH}$  (required) =  $t_6 - t_4$ 

| DRAM Controller t <sub>WCH</sub><br>Requirement | 28F016XD t <sub>WCH</sub> Specification<br>(5.0V V <sub>CC</sub> ) | 28F016XD t <sub>WCH</sub> Specification (3.3V V <sub>CC</sub> ) |
|-------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------|
| 15 ns                                           | 15 ns                                                              | 15 ns                                                           |



#### t<sub>DH</sub>

This specification defines the minimum data hold time after CAS# active transitions. The example below shows how to calculate the timing relationship between CAS# and WE#. When determining specification t<sub>7</sub>, ensure that it is being specified from the same CLK edge as t<sub>4</sub>, or add appropriate t<sub>CLK</sub> periods to adjust t<sub>7</sub> appropriately.

In this example, the 28F016XD successfully interfaces to the DRAM controller.

| Example:                                       |
|------------------------------------------------|
| $t_4 = 5 \text{ ns (max)}$                     |
| $t_7 = 20 \text{ ns (min)}$                    |
| $t_{CLK} = 30 \text{ ns} (33 \text{ MHz CLK})$ |
| $t_{\rm DH}$ (required) = $t_7 - t_4$          |
|                                                |

| DRAM Controller t <sub>DH</sub><br>Requirement | 28F016XD $t_{DH}$ Specification (5.0V $V_{CC}$ ) | 28F016XD $t_{DH}$ Specification (3.3V $V_{CC}$ ) |
|------------------------------------------------|--------------------------------------------------|--------------------------------------------------|
| 15 ns                                          | 15 ns                                            | 15 ns                                            |

#### 3.3 Additional Circuitry Required to Interface to the 28F016XD

A properly-designed system requires minimal circuitry beyond the DRAM controller to interface to the 28F016XD. The following sections discuss this circuitry, much of which is optional.

#### V<sub>PP</sub> Generation

As discussed in Section 2.1, the 28F016XD requires a Vpp voltage for Data Write and Erase operations. Valid Vpp voltage ranges are 5.0V  $\pm$  10% (VppH1) and 12.0V  $\pm$  5% (VppH2). In a 5.0V system design, the Vpp voltage can be supplied by the same power supply that provides V<sub>CC</sub> and switched for write protection purposes. Alternatively, Figure 8 shows an example circuit that generates 12.0V from a 5.0V or 3.3V input.

See the Additional Information section of this document for information on AP-357, which covers the topic of 12.0V generation in great detail.

#### RP# Input

RP# (Reset/Power-Down) has several functions:

- Resets internal automation
- Transitions the 28F016XD to deep power-down mode
- Provides write protection during system power transitions

Circuitry like that shown in Figure 9 should be used to control RP#. Application Note AP-374 covers the topic of flash memory write protection in great detail; see the Additional Information section of this document. GPIO general purpose input/output (for power management) and system RESET# control are optional depending on the application.





Figure 8. 12.0V Converter with Integrated Switch



Figure 9. RP# Control for the 28F016XD



#### WP# Input

WP# allows selective lock of blocks within the 28F016XD to prevent unwanted data alteration. If this functionality is desired, it can be implemented via GPIO control. Otherwise, WP# can be disabled by connecting it to  $V_{CC}$ .

#### RY/BY# Output

RY/BY# provides hardware indication of the status of internal 28F016XD automation, and can be connected to a system interrupt input if desired. Alternatively,

the 28F016XD Status Registers provide identical information and can be read by system software to determine completion of Data Write and/or Erase.

#### **Parity**

The 28F016XD, unlike some DRAMs, does not provide parity information. If parity is required for the DRAM subsystem and the DRAM controller provides only global parity enable/disable (or requires parity), external circuitry such as a PAL or dedicated logic chip can supply parity bits during 28F016XD reads. See Figure 10 for an example.



Figure 10. External Parity Generation



# 4.0 DESIGNING 28F016XD COMPATIBILITY AND OPTIMIZATION INTO DRAM CONTROLLERS

#### **Timing Analysis**

Section 2.2 discussed areas of timing incompatibility between the 28F016XD and 16-Mbit DRAMs. DRAM controllers should provide a range of wait state configurations to ensure that they operate with the 28F016XD at all required CLK frequencies. Additionally, the nonconfigurable specifications of Section 3.2 should be closely reviewed. Finally, for reads, DRAM controllers that provide the column address in advance of CAS# will interface to the 28F016XD with a minimum of additional wait states.

#### Per-Bank Parity and Wait State Control

The 28F016XD is not subject to the same alpha particle "soft errors" that affect DRAM, so it does not provide parity data bits. If parity checking is desired for the DRAM subsystem, per-bank parity control allows the 28F016XD and DRAM to be placed in separate controller banks. Parity can be enabled for those banks containing DRAM and disabled for banks containing the 28F016XD.

Section 2.2 also revealed that read and write timings for the 28F016XD are slower than those for DRAM at high CLK frequencies. Per-bank wait state control allows the 28F016XD and DRAM to be placed in separate banks and individually configured to optimize performance of each.

#### Fast RAS# Precharge

The 28F016XD does not require precharge between accesses when RAS# is toggled. Therefore, its t<sub>RP</sub> (RAS# precharge time) specification is much shorter than that required for DRAM (10 ns for the 28F016XD vs. 40-50 ns for DRAM). A DRAM controller with configurable RAS# precharge delay can exploit this 28F016XD advantage.

#### Refresh Disable

The 28F016XD also does not require refresh to retain stored data contents. Per-bank refresh enable/disable or refresh enable/disable on an address range basis will eliminate unnecessary cycles to the 28F016XD, optimizing performance and lowering power consumption.



#### 5.0 CONCLUSION

This application note has discussed comparisons between the 28F016XD and DRAM, compatibility between the 28F016XD and DRAM controllers, and optimization of new DRAM controllers for the

28F016XD. Consult reference documentation for a more complete understanding of compatibility and device capabilities. Please contact your local Intel or distribution sales office for more information on Intel's flash memory products.

#### ADDITIONAL INFORMATION

| Order Number                               | Document/Tool                                                                                  |
|--------------------------------------------|------------------------------------------------------------------------------------------------|
| 290533                                     | 28F016XD DRAM-Interface Flash Memory Datasheet                                                 |
| 297372                                     | "16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016XS/28F016XD"           |
| 292152                                     | AB-58 "28F016XD-Based SIMM Designs"                                                            |
| 292092                                     | AP-357 "Power Supply Solutions for Flash Memory"                                               |
| 292123                                     | AP-374 "Flash Memory Write Protection Techniques"                                              |
| 292126                                     | AP-377 "16-Mbit Flash Product Family Software Drivers,<br>28F016SA/28F016SV/28F016XS/28F016XD" |
| 297508                                     | FlashBuilder Utility                                                                           |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Benchmarking Utility                                                                  |
| Contact Intel/Distribution<br>Sales Office | 28F016XD iBIS Models                                                                           |
| Contact Intel/Distribution<br>Sales Office | 28F016XD VHDL/Verilog Models                                                                   |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Timing Designer Library Files                                                         |
| Contact Intel/Distribution<br>Sales Office | 28F016XD Orcad and ViewLogic Schematic Symbols                                                 |

#### **REVISION HISTORY**

| Number | Description      |  |
|--------|------------------|--|
| 001    | Original Version |  |

intel®

**AP-600** 

# APPLICATION NOTE

## Performance Benefits and Power/Energy Savings of 28F016XS-Based System Designs

BRIAN DIPERT
SENIOR TECHNICAL
MARKETING ENGINEER
KEN MCKEE
TECHNICAL MARKETING

ENGINEER

November 1994

### 3

# PERFORMANCE BENEFITS AND POWER/ENERGY SAVINGS OF 28F016XS-BASED SYSTEM DESIGNS

| CONTENTS                                                               | PAGE           |
|------------------------------------------------------------------------|----------------|
| 1.0 INTRODUCTION                                                       | 3-174          |
| 2.0 MEMORY PERFORMANCE AND POWER/ENERGY COMPARISONS                    | 3-178          |
| 2.1 Background                                                         | 3-178          |
| 2.2 The Results                                                        | 3-178          |
| 3.0 THE 28F016XS-BASED MEMORY ARCHITECTURE AND ITS POSITIVE S' IMPACTS | YSTEM<br>3-183 |
| 3.1 The Traditional Memory Model Has a Long History                    | 3-183          |
| 3.2 The Traditional Memory Model Hits a Brick Wall                     | 3-184          |
| 3.3 The 28F016XS Flash Memory Architecture Alternative                 | 3-185          |
| 4.0 CONCLUSION                                                         | 3-185          |
| APPENDIX A                                                             | 3-187          |

3-174



#### 1.0 INTRODUCTION



Figure 1. High System Performance Depends on Optimized Operation of All Sub-Systems

Microprocessors today have achieved tremendous levels of performance, with year-to-year gains more exponential than linear in nature. Unfortunately, computer systems have not achieved similar performance leaps. Their performance ties not only to the CPU, but is a composite of all computing subsystems; memory, mass storage, video, networking, etc. See Figure 1 for a block diagram of the traditional Von Neumann-based computing architecture.

Memory, the first-line link between the CPU and the mass storage subsystem, feeds the microprocessor with code and data necessary to do useful work. In this capacity, memory directly impacts system performance. Until the CPU receives the code or data it needs, the system stalls.





Figure 2. Microprocessor Performance Dramatically Improves with Each New Generation

Figure 2 charts microprocessor performance gains over the last two decades, with Figure 3 showing comparative SRAM and DRAM read performance gains for the same time frame. The difference in the slopes of the three curves is obvious and striking. To optimize the CPU-memory interface and minimize CPU performance impact, system designers are resorting to more and more complex multi-memory architectures (see Figure 4 for an example). This complexity results in added system cost, higher power consumption, lower reliability and ruggedness, larger size and greater weight.



Figure 3. Memory Read Performance Improvements Lag behind Those of Microprocessors

What can be done to solve this apparent paradox? How can a system designer address higher performance while simultaneously simplifying the memory architecture, lowering cost, reducing power consumption, increasing reliability and decreasing form factor/weight? The answer lies not in evolutionary, incremental

improvements to existing system architectures, but in revolutionary new architectures based on an equally revolutionary memory alternative, high-density flash memory. Figure 5 shows an example of such a system architecture.





Figure 4. The Traditional System Memory Architecture Adds Complexity in Order to Optimize Performance



Figure 5. A Flash Memory-Based System Memory Architecture
Achieves Performance without Tradeoffs

This application note compares the read performance and power consumption of Intel's 28F016XS Flash memory to that of more traditional memory alternatives, based on specifications available at the time this document was published. The 28F016XS Flash memory is a new member of the Intel 16-Mbit flash memory product family. This device retains full software backwards-compatibility with the 28F016SA/SV. Significant 28F016XS enhancements compared to previous flash memories include:

- A synchronous pipelined read interface that optimizes the performance of today's leading-edge microprocessors and buses, and
- SmartVoltage technology

This analysis focuses on the highest read performance versions of the highest-density products for each memory technology. Also discussed, are 28F016XS-based system memory architecture advantages over traditional alternatives in terms of performance, complexity, cost, power consumption and reliability. For complete information on Intel's 28F016XS flash memory, consult documentation listed in the Additional Information section.



## 2.0 MEMORY PERFORMANCE AND POWER/ENERGY COMPARISONS

This section compares read performance and power/ energy consumption in various operating modes for the following memory technologies:

- 28F016XS flash memory (x16)
- 16-Mbit DRAM (x16)
- 4-Mbit SRAM (two x8)
- 1-Mbit cache SRAM (two x8)
- 16-Mbit paged mask ROM (x16)
- 4-Mbit EPROM (x16)
- 1-Mbit EEPROM (x16)
- 1.8" HDD
- 1.3" HDD

In all cases, representative specifications drawn from a composite of multiple memory vendors (when possible) were used.

#### 2.1 Background

The detailed analyses in the Appendix show read performance both in terms of number of clocks and number of wait states, for a sequence of 256 sequential word (16 bit) reads at 33 MHz. This sequence length was chosen for compatibility with the 512 byte sector

size of a HDD. Different sequence lengths will result in different analysis results. Performance calculations measure time from when the memory receives a valid address until it outputs desired data. They do not take into account any additional delays due to bus complexity (address generation, parity checking, etc.) or glue logic (chip select decode, control signal generation, etc.). Read performance calculations also do not include improvements from system design techniques such as multi-bank interleaving.

Calculations show power consumption in three operating modes, read, standby and sleep (if offered), using maximum current specifications and CMOS levels. Read power consumption calculations use the highest-specified read frequency. Read energy consumption calculations multiply read power consumption by the amount of time required to read the eight word sequence. Therefore, the analysis focuses on read energy consumption, versus read power consumption, to compare relative battery drain for each memory technology during reads.

#### 2.2 The Results

Tables 1-4 and Figures 6-9 summarize the results of these comparisons, with detailed analysis in the Appendix. Section 3 will translate the 28F016XS component strengths into system-level advantages.



#### Read Performance

As Figure 6 reveals, the 28F016XS read performance approaches that of cache SRAM and exceeds that of all other memory technologies, including DRAM. The

28F016XS is significantly faster than any nonvolatile memory technology. Subsequent tables and figures point out that this performance comes with minimal power penalty compared to alternative memories.

Table 1. Read Performance Comparisons (8-Word Transfers at 33 MHz)

| Memory Technology            | 5.0V V <sub>CC</sub> Read<br>Transfer Rate<br>(Byte/sec) | 5.0V Read<br>Transfer Rate<br>Compared to<br>the 28F016XS | 3.3V V <sub>CC</sub> Read<br>Transfer Rate<br>(Byte/sec) | 3.3V Read<br>Transfer Rate<br>Compared to<br>the 28F016XS |
|------------------------------|----------------------------------------------------------|-----------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------|
| 28F016XS Flash Memory (x16)  | 66.1 x 10 <sup>6</sup>                                   | 1x                                                        | 44.3 x 10 <sup>6</sup>                                   | 1x                                                        |
| 16-Mbit DRAM (x16)           | 33.3 x 10 <sup>6</sup>                                   | 0.50x                                                     | 33.3 x 10 <sup>6</sup>                                   | 0.75x                                                     |
| 4-Mbit SRAM (two x8)         | 33.3 x 10 <sup>6</sup>                                   | 0.50x                                                     | 16.7 x 10 <sup>6</sup>                                   | 0.38x                                                     |
| 1-Mbit Cache SRAM (two x8)   | 66.7 x 10 <sup>6</sup>                                   | 1,01x                                                     | 66.7 x 10 <sup>6</sup>                                   | 1.51x                                                     |
| 16-Mbit Paged Mask ROM (x16) | 19 x 10 <sup>6</sup>                                     | 0.29x                                                     | 14 x 10 <sup>6</sup>                                     | 0.32x                                                     |
| 4- Mbit EPROM (x16)          | 13.3 x 10 <sup>6</sup>                                   | 0.20x                                                     | 9.5 x 10 <sup>6</sup>                                    | 0.21x                                                     |
| 1- Mbit EEPROM (x16)         | 16.7 x 10 <sup>6</sup>                                   | 0.25x                                                     | 9.5 x 10 <sup>6</sup>                                    | 0.21x                                                     |
| 1.8" HDD                     | 16.8 x 10 <sup>3</sup>                                   | <<                                                        | N/A                                                      | N/A                                                       |
| 1.3" HDD                     | 32.7 x 10 <sup>3</sup>                                   | <<                                                        | N/A                                                      | N/A                                                       |



Figure 6. 28F016XS 33 MHz Read Performance Exceeds DRAM, Approaches L2 Cache



#### **Read Energy Consumption**

The 28F016XS's high performance (how long it takes to read a sequence of data words), combined with its low power consumption (how much current is consumed at  $5.0V/3.3V\ V_{CC}$  to complete the read) give it the lowest read energy consumption of any memory technology.

HDD was not included in Figure 7 due to its extraordinarily high power and energy consumption. Unlike the 28F016XS, cache SRAM has a poor power/performance ratio. Its high read transfer rate comes at a significant power price and results in very large read energy consumption.

Table 2. Read Energy Consumption Comparisons (8-Word Transfers at 33 MHz)

| Memory Technology            | 5.0V V <sub>CC</sub> Read<br>Energy<br>Consumption<br>(watt-sec) | 5.0V V <sub>CC</sub> Read<br>Energy<br>Compared to<br>the 28F016XS | 3.3V V <sub>CC</sub> Read<br>Energy<br>Consumption<br>(watt-sec) | 3.3V V <sub>CC</sub> Read<br>Energy<br>Compared to<br>the 28F016XS |
|------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------|
| 28F016XS Flash Memory (x16)  | 6.7 x 10 <sup>-6</sup>                                           | 1x                                                                 | 3.2x 10 <sup>-6</sup>                                            | 1x                                                                 |
| 16-Mbit DRAM (x16)           | 9.2 x 10 <sup>-6</sup>                                           | 1.4x                                                               | 4.6 x 10 <sup>-6</sup>                                           | 1.4x                                                               |
| 4-Mbit SRAM (two x8)         | 38 x 10 <sup>-6</sup>                                            | 5.7x                                                               | 40 x 10 <sup>-6</sup>                                            | 12.5x                                                              |
| 1-Mbit Cache SRAM (two x8)   | 17 x 10 <sup>-6</sup>                                            | 2.5x                                                               | 10 x 10 <sup>-6</sup>                                            | 3.1x                                                               |
| 16-Mbit Paged Mask ROM (x16) | 6.8 x 10 <sup>-6</sup>                                           | 1.01x                                                              | 4.8 x 10 <sup>-6</sup>                                           | 1.5x                                                               |
| 4-Mbit EPROM (x16)           | 9.6 x 10 <sup>-6</sup>                                           | 1.4x                                                               | 7.1 x 10 <sup>-6</sup>                                           | 2.2x                                                               |
| 1-Mbit EEPROM (x16)          | 15 x 10 <sup>-6</sup>                                            | 2.2x                                                               | 14 x 10 <sup>-6</sup>                                            | 4.4x                                                               |
| 1.8" HDD                     | 57.8 x 10 <sup>-3</sup>                                          | >>                                                                 | N/A                                                              | N/A                                                                |
| 1.3" HDD                     | 23.5 x 10 <sup>-3</sup>                                          | >>                                                                 | N/A                                                              | N/A                                                                |



Figure 7. The 28F016XS's Low Power/High Performance Combination Result in the Lowest Read Energy of Any Memory Technology



#### Standby Power Consumption

The 28F016XS's standby power is much lower than that of any other updateable memory and compares favorably with that of EPROM and mask ROM. DRAM refresh requirements cause their true standby power consumption to be a combination of the "data-sheet" standby power and much larger refresh power.

The calculations that follow also do not include the power consumption of the DRAM controller refresh circuitry, which would result in even larger effective DRAM subsystem power draw. Figure 8 does not show cache SRAM and HDD due to their very high standby power consumption specifications.

**Table 3. Standby Power Consumption Comparisons** 

| Memory Technology            | 5.0V V <sub>CC</sub><br>Standby<br>Power<br>Consumption<br>(watt) | 5.0V V <sub>CC</sub><br>Standby<br>Power<br>Compared to<br>the 28F016XS | 3.3V V <sub>CC</sub><br>Standby<br>Power<br>Consumption<br>(watt) | 3.3V V <sub>CC</sub> Standby Power Compared to the 28F016XS |
|------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------|
| 28F016XS Flash Memory (x16)  | 650 x 10 <sup>-6</sup>                                            | 1x                                                                      | 429 x 10 <sup>-6</sup>                                            | 1x                                                          |
| 16-Mbit DRAM (x16)           | 50 x 10 <sup>-3</sup>                                             | 76.9x                                                                   | 26.4 x 10 <sup>-3</sup>                                           | 61.5x                                                       |
| 4-Mbit SRAM (two x8)         | 1 x 10 <sup>-3</sup>                                              | 1.5x                                                                    | 528 x 10 <sup>-6</sup>                                            | 1.2x                                                        |
| 1-Mbit Cache SRAM (two x8)   | 400 x 10 <sup>-3</sup>                                            | 615x                                                                    | 198 x 10 <sup>-3</sup>                                            | 461.5x                                                      |
| 16-Mbit Paged Mask ROM (x16) | 500 x 10 <sup>-6</sup>                                            | 0.8x                                                                    | 330 x 10 <sup>-6</sup>                                            | 0.8x                                                        |
| 4-Mbit EPROM (x16)           | 500 x 10 <sup>-6</sup>                                            | 0.8x                                                                    | 330 x 10 <sup>-6</sup>                                            | 0.8x                                                        |
| 1-Mbit EEPROM (x16)          | 2.5 x 10 <sup>-3</sup>                                            | 3.9x                                                                    | 990 x 10 <sup>-6</sup>                                            | 2.3x                                                        |
| 1.8" HDD                     | 750 x 10 <sup>-3</sup>                                            | 1153.9x                                                                 | N/A                                                               | N/A                                                         |
| 1.3" HDD                     | 500 x 10 <sup>-3</sup>                                            | 769.2x                                                                  | N/A                                                               | N/A                                                         |



Figure 8. DRAM Refresh Requirements Significantly Impact Standby Power Consumption



#### **Sleep Power Consumption**

The 28F016XS, DRAM and HDD are the only memory technologies that offer a distinct sleep mode with lower power consumption compared to standby. The 28F016XS in deep power-down mode has much lower power consumption than all other memories. DRAM

still requires refresh (the internal self-refresh operation). The HDD motor is no longer spinning, but control circuitry continues to draw power. Figure 9 does not include cache RAM or HDD due to their very high sleep power consumption specifications.

**Table 4. Sleep Power Consumption Comparisons** 

| Memory Technology            | 5.0V V <sub>CC</sub><br>Sleep Power<br>Consumption<br>(watt) | 5.0V V <sub>CC</sub><br>Sleep Power<br>Compared to<br>the 28F016XS | 3.3V V <sub>CC</sub><br>Sleep Power<br>Consumption<br>(watt) | 3.3V V <sub>CC</sub><br>Sleep Power<br>Compared to<br>the 28F016XS |
|------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------|
| 28F016XS Flash Memory (x16)  | 25 x 10 <sup>-6</sup>                                        | 1x                                                                 | 16.5 x 10 <sup>-6</sup>                                      | 1x                                                                 |
| 16-Mbit DRAM (x16)           | 2 x 10 <sup>-3</sup>                                         | 80x                                                                | 990 x 10 <sup>-6</sup>                                       | 60x                                                                |
| 4-Mbit SRAM (two x8)         | 1 x 10 <sup>-3</sup>                                         | 40x                                                                | 528 x 10 <sup>-6</sup>                                       | 32x                                                                |
| 1-Mbit Cache SRAM (two x8)   | 400 x 10 <sup>-3</sup>                                       | 16,000x                                                            | 198 x 10 <sup>-3</sup>                                       | 12,000x                                                            |
| 16-Mbit Paged Mask ROM (x16) | 500 x 10 <sup>-6</sup>                                       | 20x                                                                | 330 x 10 <sup>-6</sup>                                       | 20x                                                                |
| 4-Mbit EPROM (x16)           | 500 x 10 <sup>-6</sup>                                       | 20x                                                                | 330 x 10 <sup>-6</sup>                                       | 20x                                                                |
| 1-Mbit EEPROM (x16)          | 2.5 x 10−3                                                   | 100x                                                               | 990 x 10 <sup>-6</sup>                                       | 60x                                                                |
| 1.8" HDD                     | 25 x 10 <sup>-3</sup>                                        | 1000x                                                              | N/A                                                          | N/A                                                                |
| 1.3" HDD                     | 15 x 10 <sup>-3</sup>                                        | 600x                                                               | N/A                                                          | N/A                                                                |



Figure 9. The 28F016XS's Deep Power-Down Mode Results in Extremely Low Sleep Power Consumption



# 3.0 THE 28F016XS-BASED MEMORY ARCHITECTURE AND ITS POSITIVE SYSTEM IMPACTS

# 3.1 The Traditional Memory Model Has a Long History

The memory architecture shown in Figure 4, with only minor variation, has appeared for decades in almost every area of computing. This model consists of four basic parts:

- SRAM cache memory (very fast, very expensive, low density, volatile)
- DRAM main memory (moderately fast, moderately expensive, moderate density, volatile)
- ROM boot memory (moderately slow, moderately cheap, low or high density, nonvolatile)
- Magnetic media archive memory (very slow, very cheap, high density, nonvolatile)

Cost-per-bit fundamentally determines the percentage of total system memory budget devoted to each memory type. SRAM delivers very fast reads and writes but achieves this performance through cell and manufacturing process complexity, which impacts cost and density. On the other end of the spectrum, magnetic media gives lower performance but provides very low media cost. Varying amounts of each memory type combine

in a computer system to meet price and performance expectations. Many of today's mainstream desktop PCs, for example, contain a 128-Kbyte cache and a 240-MByte HDD, a ratio of almost 1:2,000!

Volatility provides another important consideration when choosing memories. Volatile memories (RAM) historically have provided higher performance, but lose all data when power is removed. They therefore, must remain powered-up the entire time the system is operational. DRAM additionally must be refreshed periodically to preserve stored data. Lower-performance, non-volatile memories (ROM and magnetic media) retain their contents on power loss, and are needed in a computer to store the operating software between uses.

ROM gives faster read performance than magnetic media (although slower than RAM), but its contents cannot be changed once stored. Systems that contain a relatively small amount of resident code (several megabytes) often keep it in ROM. As resident software size grows, code stability becomes a significantly greater concern. As a result, in these systems ROM often contains only a small kernel of system boot code that will, hopefully, remain usable over the life of the system. The vast majority of software resides on slower, updateable magnetic media. Regardless of the nonvolatile memory chosen, the system copies code and files to DRAM for execution, and the most-commonly accessed data and code execute out of the fast SRAM cache (see Figure 10).



Figure 10. Redundant Memory Stores Common Code and Data in Multiple Locations



The staying power of the traditional memory model is impressive, given the blistering pace and rigorous requirements of the electronics industry. In fact, it is precisely the evolution and innovation of memory technology that has ensured the continued domination of traditional memory types in everything from mainframes to mobile computers to embedded computing systems of all types. However, as microprocessor performance accelerates exponentially and emerging computing models make stringent new demands, the traditional memory model is being challenged.

## 3.2 The Traditional Memory Model Hits a Brick Wall

Users expect next-generation computing systems to improve performance and add features while simultaneously lowering cost, minimizing power consumption, increasing reliability and shrinking form factor and weight. The traditional memory model was not intended for systems with these constraints, and continued innovation within this model produce diminishing returns.

#### Poor System Performance

The performance of the traditional memory hierarchy (where software is copied from nonvolatile media to DRAM and then to SRAM) doesn't optimize the performance of today's fast microprocessors, especially when performance is measured in MIPS-per-watt rather than raw MIPS. Both system boot time and application task switching response slow down because of NVM-to-RAM file load delays, and disk drive spin-up time hinders recovery time from system power savings modes to full operation. Even assuming an aggressive HDD-to-DRAM transfer rate, operating system load delays can take many seconds (or tens or seconds), before execution out of DRAM even begins!

#### Redundant Memory Cost

Component cost alone does not provide adequate criteria for selecting the proper memory subsystem. Memory selection requires first identifying the key-user requirements that the system must satisfy, and then choosing the memory technology that meets or exceeds these requirements at the lowest cost. Unnecessary memory duplication translates to unnecessary additional system cost. When evaluating memory subsystem cost alternatives, remember to include ALL memory in calculations (i.e., not only HDD and/or ROM but also DRAM and SRAM) plus any system control logic needed to interface to the memory.

#### **Short Battery Life**

DRAMs must be constantly refreshed by the memory controller to preserve their stored data. The HDD draws current with every motor rotation and may actually draw more average current if it is "parked" too frequently, since spin-up causes high current draw. As the power draw of other computer subsystems (CPU, screen, etc.) drops with continued innovation, memory subsystem power consumption becomes a greater percentage of the total system drain and significantly impacts battery life.

#### Low Reliability and Unacceptable Ruggedness

Magnetic media alternatives (floppy disk drive, hard disk drive, etc.) contain moving parts, relatively fragile media and narrow operating temperature ranges. These products, though improving, have unacceptably low tolerance to shock, vibration and movement during read/write. A mass storage approach based on a disk rotating at high RPM with a read/write head micrometers above it, capable of colliding at the slightest shock and permanently destroying data, is fundamentally incompatible with the vision of a fully mobile computing machine.

Multiple levels of memory mean multiple levels of potential component failure. Excessive heat generation also impacts system lifetime, and the large number of board traces required is a significant manufacturing challenge and reliability headache.

#### Large Form Factor and Excessive Weight

The traditional memory model contains unnecessary memory duplication. A large portion of DRAM in the system is used only to provide the CPU with access to programs that already exist on ROM or the hard disk or floppy drive. The traditional memory model needs redundant DRAM and magnetic media or ROM because DRAM satisfies the performance needs of the processor while ROM or HDD provides the non-volatility the system requires. This duplication takes up excessive space within the system, impacting its footprint and thickness. The added power consumption requires larger system batteries and power supplies, which make the system unacceptably and unnecessarily heavy.



## 3.3 The 28F016XS Flash Memory Architecture Alternative

Just as today's system designs are revolutionary, so too are their memory architectures. Incremental improvements to the traditional approach no longer measure up to the revolutionary potential of a 28F016XS-based alternative (see Figure 5).

#### **Optimized System Performance**

The 28F016XS provides both high performance, like DRAM and SRAM, and non-volatility, like ROM and HHD. It combines the best qualities of both memory types in one technology. Lengthy software load overhead and task switching delays are eliminated. Code runs as fast or faster than that in DRAM with much less system hardware complexity, and the 28F016XS read transfer rate approaches that of cache SRAM!

#### Low Cost and Flexible

A 28F016XS flash memory array is competitively priced to a DRAM/ROM or DRAM/small HDD combination, especially when the costs of associated memory interface and control circuitry are considered. Unlike ROM, flash memory is in-system updateable. This allows easy code upgrade even after the system is in a customer's hands, to enhance capabilities or correct unintended system shortcomings. This flexibility keeps system costs low both initially and throughout system lifetime.

#### **Minimal Power Consumption**

Flash memory, being nonvolatile, requires no periodic refresh and no constant power to be applied to it in order to retain stored information. The 28F016XS's read energy is the lowest of any memory technology analyzed in this application note. The 28F016XS's standby and sleep power also compare very favorably with alternative approaches. The redundancy of multi-

ple memory technologies in the traditional memory architecture results in multiple sources of power consumption. These multiple memories must be summed to determine the true memory subsystem power draw. With 28F016XS, there is only one very efficient memory technology, consuming very little system power.

#### High Reliability, Solid-State Ruggedness

Solid-state memories such as the 28F016XS are inherently more rugged and shock-resistant than alternatives containing moving parts, like HDDs. The 28F016XS-based memory architecture, being simpler and more integrated than the traditional alternative, also exhibits much higher system reliability. Data reliability studies point to the longevity of data stored in flash memory.

#### Small Form Factor, Light Weight

The 28F016XS's compact TSOP package provides 9.2 MByte/in² density capability, with components mounted on both sides of the system board. The 28F016XS memory subsystem architecture minimizes or eliminates memory duplication, leading to substantial board space savings. 28F016XS's very low power consumption reduces the size and weight of system batteries and power supplies.

#### 4.0 CONCLUSION

This application note has discussed performance and power/energy comparisons between the 28F016XS and other memory technologies, and the positive 28F016XS impacts on system performance and power consumption. Consult reference documentation for a more complete understanding of device capabilities and design techniques. Please contact your local Intel or distribution sales office for more information on Intel's flash memory products.



#### **ADDITIONAL INFORMATION**

| Order Number                               | Document/Tool                                                                       |  |  |
|--------------------------------------------|-------------------------------------------------------------------------------------|--|--|
| 290532                                     | 28F016XS Datasheet                                                                  |  |  |
| 297500                                     | "Interfacing 28F016XS to the i960® Microprocessor Family"                           |  |  |
| 297504                                     | "Interfacing 28F016XS to the Intel486™ Microprocessor Family"                       |  |  |
| 292147                                     | "Designing with the 28F016XS"                                                       |  |  |
| 292127                                     | AP-378, "System Optimization Using the Enhanced Features of the 28F016SA"           |  |  |
| 297372                                     | 16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016XSs/28F016XD |  |  |
| 297508                                     | FlashBuilder Utility                                                                |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Benchmark Utility                                                          |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS iBIS Models                                                                |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS VHDL/Verilog Models                                                        |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Timing Designer Library Files                                              |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Orcad and ViewLogic Schematic Symbols                                      |  |  |

#### **REVISION HISTORY**

| Number | Description      |
|--------|------------------|
| 001    | Original Version |



#### APPENDIX A

#### 28F016XS FLASH MEMORY

The following sections provide detailed analysis of the memory performance and power/energy consumption comparisons discussed in Section 2.0 of this application note.

#### Read Performance (5.0V V<sub>CC</sub>)

The 28F016XS-15 is capable of 3-1-1-1-1-1-1.... read performance at 5.0V  $V_{\rm CC}$  and 33 MHz (2-0-0-0-0-0-0-0.... in terms of wait states). This results in a 66.1 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(258 clocks x 30 ns/clock) = x MByte/sec x = 66.1 MByte/sec

#### Read Performance (3.3V V<sub>CC</sub>)

The 28F016XS-15 is capable of 3-1-2-1-2-1-2-1.... read performance at 3.3V  $V_{\rm CC}$  and 33 MHz (2-0-1-0-1-0-1-0.... in terms of wait states). This results in a 44.3 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(385 clocks x 30 ns/clock) = x MByte/sec x = 44.3 MByte/sec

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 875 mW (5.0V x 175 mA). Read mode energy consumption is 6.7 µJoules (875 mW x 258 clocks x 30 ns/clock).

Standby power consumption is 650  $\mu$ W (5.0V x 130  $\mu$ A). Deep power-down (sleep) power consumption is 25  $\mu$ W (5.0V x 5  $\mu$ A).

#### Power and Energy Consumption (3.3V V<sub>CC</sub>)

Read mode power consumption is 280 mW (3.3V x 85 mA). Read mode energy consumption is 3.2  $\mu$ Joules (280 mW x 385 clocks x 30 ns/clock).

Standby power consumption is 429  $\mu$ W (3.3V x 130  $\mu$ A). Deep power-down (sleep) power consumption is 16.5  $\mu$ W (3.3V x 5  $\mu$ A).



#### 16-Mbit DRAM

16-Mbit DRAMs were, at the time this application note was published, only beginning to ramp into production. Only advance information for the wider x16 16-Mbit DRAMs was available for use in the calculations that follow.

#### Read Performance (5.0V $V_{CC}$ and 3.3V $V_{CC}$ )

Sequential reads allow use of the DRAM fast page mode. Assumed DRAM specifications are shown below:

- 70 ns t<sub>RAC</sub>, 35 ns t<sub>AA</sub> (5.0V V<sub>CC</sub>)
- 80 ns t<sub>RAC</sub>, 45 ns t<sub>AA</sub> (3.3V V<sub>CC</sub>)
- 256-word (512-byte) page buffer

Therefore, 16-Mbit DRAMs are capable of 3-2-2-2-2-2-2-.... read performance at 33 MHz (2-1-1-1-1-1-1 in terms of wait states....). This results in a 33.3 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(513 clocks x 30 ns/clock) = x MByte/sec x = 33.3 MByte/sec

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 600 mW (5.0V x 120 mA). Read mode energy consumption is 9.2 μJoules (600 mW x 513 clocks x 30 ns/clock).

The standby mode power calculation combines both the DRAM standby current and refresh current specifications, in proportion relative to percentage of time in each mode. Standby power consumption is 50 mW (5.0V x 10 mA). Sleep power calculations use the DRAM self-refresh current specification. Sleep power consumption is 2 mW (5.0V x 400  $\mu$ A).

#### Power and Energy Consumption (3.3V V<sub>CC</sub>)

Read mode power consumption is 297 mW (3.3V x 90 mA). Read mode energy consumption is 4.6 μJoules (297 mW x 513 clocks x 30 ns/clock).

Standby power consumption is 26.4 mW (3.3V x 8 mA). Sleep power consumption is 990  $^{\circ}$ W (3.3V x 300  $\mu$ A).



#### 4-Mbit SRAM

4-Mbit SRAMs were, at the time this application note was published, only beginning to ramp into production. Only advance information for the wide x8 4-Mbit SRAMs was available for use in the calculations that follow. This analysis used two 4-Mbit (x8) SRAMs to create the assumed 16-bit system interface.

#### Read Performance (5.0V V<sub>CC</sub>)

The assumed 5.0V  $V_{\rm CC}$  4-Mbit SRAM access time is 55 ns. Therefore, 4-Mbit SRAMs are capable of 2-2-2-2-2-2-2-2-2-2.... read performance at 5.0V  $V_{\rm CC}$  and 33 MHz (1-1-1-1-1-1-1.... in terms of wait states). This results in a 33.3 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(512 clocks x 30 ns/clock) = x MByte/sec x = 33.3 MByte/sec

#### Read Performance (3.3V V<sub>CC</sub>)

The assumed 3.3V  $V_{CC}$  4-Mbit SRAM access time is 100 ns. Therefore, 4-Mbit SRAMs are capable of 4-4-4-4-4-4-4-4-... read performance at 3.3V  $V_{CC}$  and 33 MHz (3-3-3-3-3-3-3.... in terms of wait states). This results in a 16.7 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(1024 clocks x 30 ns/clock) = x MByte/sec x = 16.7 MByte/sec

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 2.5W (5.0V x 250 mA x 2 devices). Read mode energy consumption is 38 μJoules (2.5W x 512 clocks x 30 ns/clock).

Standby power consumption is 1 mW (5.0V x 100  $\mu$ A x 2 devices). Data retention current at 5.0V  $V_{CC}$  is the same as standby current, therefore data retention (sleep) power consumption is 1 mW.

#### Power and Energy Consumption (3.3V V<sub>CC</sub>)

Read mode power consumption is 1.3W (3.3V x 200 mA x 2 devices). Read mode energy consumption is 40  $\mu$ Joules (1.3W x 1024 clocks x 30 ns/clock).

Standby power consumption is 528  $\mu$ W (3.3V x 80  $\mu$ A x 2 devices). Data retention current at 3.3V V<sub>CC</sub> is the same as standby current, therefore data retention (sleep) power consumption is 528  $\mu$ W.



#### 1-Mbit CACHE SRAM

The majority of memories analyzed in this application note were high density. 1-Mbit cache SRAMs were included, however, to compare the read performance and power/energy consumption of 28F016XS with that of L2 cache memory. This analysis used two 1-Mbit (x8) cache SRAMs to create the assumed 16-bit system interface.

#### Read Performance (5.0V V<sub>CC</sub> and 3.3V V<sub>CC</sub>)

Assumed 1-Mbit cache SRAM specifications are shown below:

- 15 ns t<sub>ACC</sub> (5.0V V<sub>CC</sub>)
- 20 ns t<sub>ACC</sub> (3.3V V<sub>CC</sub>)

Therefore, 1-Mbit cache SRAMs are capable of 1-1-1-1-1-1-1-1-1... read performance at 33 MHz (0-0-0-0-0-0-0-0-0.... in terms of wait states). This results in a 66.7 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(256 clocks x 30 ns/clock) = x MByte/sec x = 66.7 MByte/sec

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 2.2W (5.0V x 220 mA x 2 devices). Read mode energy consumption is 17  $\mu$ Joules (2.2W x 256 clocks x 30 ns/clock).

Standby power consumption is 400 mW (5.0V x 40 mA x 2 devices). Data retention current at 5.0V  $V_{\rm CC}$  is the same as standby current, therefore data retention (sleep) power consumption is 400 mW.

#### Power and Energy Consumption (3.3V V<sub>CC</sub>)

Read mode power consumption is 1.3W (3.3V x 200 mA x 2 devices). Read mode energy consumption is 10  $\mu$ Joules (1.3W x 256 clocks x 30 ns/clock).

Standby power consumption is 198 mW (3.3V x 30 mA x 2 devices). Data retention current at 3.3V V<sub>CC</sub> is the same as standby current, therefore data retention (sleep) power consumption is 198 mW.



#### 16-Mbit PAGED MASK ROM

Calculations that follow used the x16 version of the 16-Mbit paged mask ROM, which is not yet widely available from multiple vendors. The x8 16-Mbit paged mask ROM is the more common version today.

#### Read Performance (5.0V V<sub>CC</sub>)

Sequential reads allow use of the mask ROM page mode. The assumed 5.0V  $V_{\rm CC}$  16-Mbit mask ROM random access time is 150 ns, with 75 ns accesses in page mode (4-word page). Therefore, 16-Mbit mask ROMs are capable of 5-3-3-3-5-3-3-.... read performance at 5.0V  $V_{\rm CC}$  and 33 MHz (4-2-2-4-2-2-.... in terms of wait states). This results in a 19 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(900 clocks x 30 ns/clock) = x MByte/sec x = 19 MByte/sec

#### Read Performance (3.3V V<sub>CC</sub>)

The assumed 3.3V  $V_{\rm CC}$  16-Mbit mask ROM random access time is 200 ns, with 100 ns accesses in page mode (4-word page). Therefore, 16-Mbit mask ROMs are capable of 7-4-4-4-7-4-4-4.... read performance at 3.3V  $V_{\rm CC}$  and 33 MHz (6-3-3-3-6-3-3-3.... in terms of wait states). This results in a 14 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(1216 clocks x 30 ns/clock) = x MByte/sec x = 14 MByte/sec

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 250 mW (5.0V x 50 mA). Read mode energy consumption is 6.8  $\mu$ Joules (250 mW x 900 clocks x 30 ns/clock).

Standby power consumption is 500  $\mu$ W (5.0V x100  $\mu$ A). 16-Mbit mask ROM does not provide a sleep mode, so sleep current is equal to standby current, or 500  $\mu$ W.

#### Power and Energy Consumption (3.3V V<sub>CC</sub>)

Read mode power consumption is 132 mW (3.3V x 40 mA). Read mode energy consumption is 4.8  $\mu$ Joules (132 mW x 1216 clocks x 30 ns/clock).

Standby power consumption is 330  $\mu$ W (3.3V x 100  $\mu$ A). 16-Mbit mask ROM does not provide a sleep mode, so sleep current is equal to standby current, or 330  $\mu$ W.



#### 4-Mbit EPROM

Calculations that follow used the x16 version of the 4-Mbit EPROM (Intel 27C400 or equivalent).

#### Read Performance (5.0V V<sub>CC</sub>)

The assumed 5.0V  $V_{CC}$  4-Mbit EPROM random access time is 150 ns. Therefore, 4-Mbit EPROMs are capable of 5-5-5-5-5-5-5.... read performance at 5.0V  $V_{CC}$  and 33 MHz (4-4-4-4-4-4.... in terms of wait states). This results in a 13.3 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(1280 clocks x 30 ns/clock) = x MByte/sec x = 13.3 MByte/sec

#### Read Performance (3.3V V<sub>CC</sub>)

The assumed 3.3V  $V_{CC}$  4-Mbit EPROM random access time is 200 ns. Therefore, 4-Mbit EPROMs are capable of 7-7-7-7-7-7-7.... read performance at 3.3V  $V_{CC}$  and 33 MHz (6-6-6-6-6-6.... in terms of wait states). This results in a 9.5 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(1792 clocks x 30 ns/clock) = x MByte/sec x = 9.5 MByte/sec

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 250 mW (5.0V x 50 mA). Read mode energy consumption is 9.6  $\mu$ Joules (250 mW x 1280 clocks x 30 ns/clock).

Standby power consumption is 500  $\mu$ W (5.0V x 100  $\mu$ A). 4-Mbit EPROM does not provide a sleep mode, so sleep current is equal to standby current, or 500  $\mu$ W.

#### Power and Energy Consumption (3.3V V<sub>CC</sub>)

Read mode power consumption is 132 mW (3.3V x 40 mA). Read mode energy consumption is 7.1  $\mu$ Joules (132 mW x 1792 clocks x 30 ns/clock).

Standby power consumption is 330  $\mu$ W (3.3V x 100  $\mu$ A). 4-Mbit EPROM does not provide a sleep mode, so sleep current is equal to standby current, or 330  $\mu$ W.



#### 1-Mbit EEPROM

This analysis used two 1-Mbit (x8) EEPROMs to create the assumed 16-bit system interface.

#### Read Performance (5.0V V<sub>CC</sub>)

The assumed 5.0V  $V_{\rm CC}$  1-Mbit EEPROM random access time is 120 ns. Therefore, 1-Mbit EEPROMs are capable of 4-4-4-4-4-4-4.... read performance at 5.0V  $V_{\rm CC}$  and 33 MHz (3-3-3-3-3-3-3.... in terms of wait states). This results in a 16.7 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(1024 clocks x 30 ns/clock) = x MByte/sec x = 16.7 MByte/sec

#### Read Performance (3.3V VCC)

The assumed 3.3V  $V_{CC}$  1-Mbit EEPROM random access time is 200 ns. Therefore, 1-Mbit EEPROMs are capable of 7-7-7-7-7-7-7.... read performance at 3.3V  $V_{CC}$  and 33 MHz (6-6-6-6-6-6-6.... in terms of wait states). This results in a 9.5 MByte/sec read transfer rate, as shown by the calculation below:

512 bytes/(1792 clocks x 30 ns/clock) = x MByte/sec x = 9.5 MByte/sec

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 500 mW (5.0V x 100 mA). Read mode energy consumption is 15 μJoules (500 mW x 1024 clocks x 30 ns/clock).

Standby power consumption is 2.5 mW (5.0V x 500  $\mu$ A). 1-Mbit EEPROM does not provide a sleep mode, so sleep current is equal to standby current, or 2.5 mW.

#### Power and Energy Consumption (3.3V V<sub>CC</sub>)

Read mode power consumption is 264 mW (3.3V x 80 mA). Read mode energy consumption is 14  $\mu$ Joules (264 mW x 1792 clocks x 30 ns/clock).

Standby power consumption is 990  $\mu$ W (3.3V x 300  $\mu$ A). 1-Mbit EEPROM does not provide a sleep mode, so sleep current is equal to standby current, or 990  $\mu$ W.



#### 1.8" HDD

Only information for 5.0V  $V_{CC}$  1.8" HDDs was used in the calculations that follow; 3.3V  $V_{CC}$  1.8" HDDs were not yet available.

#### Read Performance (5.0V V<sub>CC</sub>)

The HDD must first locate data stored on its platter(s) and transfer it to the sector buffer before the system can read it. The assumed 5.0V  $V_{\rm CC}$  1.8" HDD seek access time (including rotational latency) is 30 ms. The assumed peak media transfer rate is 2 MByte/sec or 477 ns/byte, and the peak interface transfer rate is 3 MByte/sec or 318 ns/byte. Therefore, 1.8" HDD at 5.0V  $V_{\rm CC}$  can access 256 words (512 bytes) of data in 30.4 ms (1 x 10<sup>6</sup> 33 MHz clocks), resulting in a 16.8 Kbyte/sec read transfer rate, as shown by the calculations below:

Access time = 30 ms + (477 ns/byte x 512 bytes) + (318 ns/byte x 512 bytes) = 30.4 ms (1 clock/30 ns) x (30.4 ms) = 1 x 10<sup>6</sup> 33 MHz clocks 512 bytes/30.4 ms = x MByte/sec x = 16.8 Kbyte/sec

Effective read transfer rate is highly dependent on length of read sequence.

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 1.9 W (5.0V x 380 mA). Read mode energy consumption is 57.8 mJoules ((1.9 W) x (1 x 10<sup>6</sup> clocks) x (30 ns/clock)).

Standby power consumption is 750 mW (5.0V x 150 mA). Sleep power consumption is 25 mW (5.0V x 5 mA).



#### 1.3" HDD

Only information for 5.0V  $V_{CC}$  1.3" HDDs was used in the calculations that follow; 3.3V  $V_{CC}$  1.3" HDDs were not yet available.

#### Read Performance (5.0V V<sub>CC</sub>)

The HDD must first locate data stored on its platter(s) and transfer it to the sector buffer before the system can read it. The assumed 5.0V  $V_{\rm CC}$  1.3" HDD seek access time (including rotational latency) is 15 ms. The assumed peak media transfer rate is 1.5 MByte/sec or 636 ns/byte, and the peak interface transfer rate is also 1.5 MByte/sec or 636 ns/byte. Therefore, 1.3" HDD at 5.0V  $V_{\rm CC}$  can access 256 words (512 bytes) of data in 15.7 ms (522 x  $10^3$  33 MHz clocks), resulting in a 32.7 Kbyte/sec read transfer rate, as shown by the calculations below:

Access time = 15 ms + (636 ns/byte x 512 bytes) + (636 ns/byte x 512 bytes) = 15.7 ms (1 clock/30 ns) x (15.7 ms) = 522 x 10<sup>3</sup> 33 MHz clocks 512 bytes/15.7 ms = x MByte/sec x = 32.7 Kbyte/sec

Effective read transfer rate is highly dependent on length of read sequence.

#### Power and Energy Consumption (5.0V V<sub>CC</sub>)

Read mode power consumption is 1.5W (5.0V x 300 mA). Read mode energy consumption is 23.5 mJoules ((1.5W) x (522 x 10<sup>3</sup> clocks) x (30 ns/clock)).

Standby power consumption is 500 mW (5.0V x 100 mA). Sleep power consumption is 15 mW (5V x 3 mA).



# TECHNICAL PAPER

# Interfacing the 28F016XS to the i960® Microprocessor Family

KEN MC KEE
TECHNICAL MARKETING ENGINEER
TIM KELLY
ENGINEER
RANNA PRAJAPATI
ENGINEER

November 1994

# INTERFACING THE 28F016XS TO THE i960® MICROPROCESSOR FAMILY

| CONTENTS                                                 | PAGE        | CONTENTS                                   | PAGE           |
|----------------------------------------------------------|-------------|--------------------------------------------|----------------|
| 1.0 INTRODUCTION                                         | 3-198       | 4.0 i960® KB-25 MICROPROCI                 |                |
| 2.0 i960® CA-33 MICROPROCESSO INTERFACE                  |             | 4.1 Circuit Description                    | 3-217          |
| 2.1 Circuit Description                                  | 3-199       | 4.2 Software Interface Considerations      | 3-219          |
| 2.2 Software Interface Considerations                    | 3-201       | 4.3 Read Burst Cycle Descrip<br>25 MHz     | otion at 3-219 |
| 2.3 Single and Burst Read Cycle<br>Description at 33 MHz | 3-202       | 4.4 Write Burst Cycle Configu<br>25 MHz    | ration at      |
| 2.4 Single Burst Write Cycle Description at 33 MHz       | 3-206       | 5.0 INTERFACING TO OTHER MICROPROCESSORS   | i960®          |
| 3.0 i960® JF-33 MICROPROCESSOI INTERFACE                 |             | 6.0 CONCLUSION                             | 3-225          |
| 3.1 Circuit Description                                  | 3-209       | ADDITIONAL INFORMATION                     | 3-226          |
| 3.2 Software Interface Considerations                    | 3-210       | REVISION HISTORY                           |                |
| 3.3 Burst Read Cycle Description a 33 MHz                | at<br>3-211 | APPENDIX A: PLD FILES                      | 3-227          |
| 3.4 Burst Write Cycle Description a 33 MHz               | nt<br>3-215 | APPENDIX B: BENCHMARK PERFORMANCE ANALYSIS | 3-236          |



#### 1.0 INTRODUCTION

This technical paper describes several designs interfacing the high-performance 28F016XS Flash memory to the i960® microprocessor family. All designs are based on preliminary 28F016XS specifications. These designs have been fully simulated but no yet taken to lab prototype. Please contact your Intel or distribution sales office for up-to-date information. Do not finalize a design based on the specifications in this document.

The 28F016XS is a 16-Mbit flash memory with a high-performance synchronous pipelined read interface. The 28F016XS combines ROM-like non-volatility, DRAM-like read performance and in-system update ability in one memory technology. These characteristics enable code execution directly from the 28F016XS memory space, replacing the costly practice of shadowing code from HDD or ROM to DRAM for increased performance. The 28F016XS improves system performance, ruggedness and cost of any burst microprocessor, such as the i960 microprocessor, base design. The i960 microprocessor family sees widespread use in various applications, including imaging and data communications.

The 28F016XS performs synchronous pipelined reads. Up to three accesses can be initiated before reading data output from the initial cycle. This pipelined structure is ideal for use with the i960 microprocessor's burst transfer mechanism. The 28F016XS brings significant system performance enhancements to an i960 microprocessor-based environment. This technical paper describes processor-to-memory interfaces that exploit these capabilities to achieve maximum system performance. Figures 1 and 2 illustrate relative system performance enhancements that the 28F016XS brings to an i960 microprocessor-based environment, compared to other memory technologies. The benchmark parameters are documented in Appendix B.



Figure 1. Relative System Performance Enhancement of the 28F016XS Compared to Other Memory Technologies in an i960® KB-25 Microprocessor-Based Design



Figure 2. Relative System Performance Enhancement of the 28F016XS Compared to Other Memory Technologies in an i960® CA-33 Processor-Based Design



#### 2.0 i960® CA-33 MICROPROCESSOR INTERFACE



Figure 3. Minimal Logic Required Interfacing the 28F016XS-15 to the i960 CA-33 Microprocessor

Using this interface, the 28F016XS-15/i960 CA-33 microprocessor system achieves 3-0-0-2-0-0-0... waitstate read performance, supporting burst transfers and address pipelining.

#### 2.1 Circuit Description

This section describes the 28F016XS-15/i960 CA-33 microprocessor interface block diagram in Figure 3.

#### **Memory Configuration**

This design uses two 28F016XS-15s, in x16 mode, to match the i960 CA microprocessor's 32-bit data bus, providing 4 Mbytes of flash memory. Signals  $A_{21.4}$  from the i960 CA microprocessor and CTR<sub>1-0</sub> from the PLD select locations within the 28F016XS memory space, arranged as 1-Meg double words. The two-bit counter implemented in the PLD loads addresses  $A_{3.2}$  at the beginning of each memory cycle and generates the lower two bits of the burst addresses on its outputs

CTR<sub>1-0</sub>. The counter feeds burst addresses to the 28F016XS, so that they do not stall waiting for the processor to supply the next address.

#### Chip Select Logic

Chip select decode logic may use  $A_{31-22}$  to generate an active low chip select signal, CS#, for the 28F016XS-15 memory space and other system peripherals. The chip select drives  $CE_0\#$  on each 28F016XS-15 and a control input to the PLD. The 28F016XS-15's  $CE_1\#$  input is grounded.

In support of address pipelining, the chip select logic latches CS#, holding it active throughout the duration of the memory access. This will prevent potential CS# problems caused by using combinatorial logic when utilizing the address pipelining capability of i960 CA microprocessor.

If address pipelining functionality is not implemented, simple combinatorial logic can be utilized in generating



the system CS# for the 28F016XS memory space, and the chip select logic shown in Figure 3 does not examine BLAST# and ADS#. For many systems using the upper address bits in a linear selection scheme may provide a sufficient number of chip select signals, thus eliminating system chip select decode logic. (See

Figure 4 for an example of using linear selection for chip selects.) When using a linear chip select scheme however, the software must avoid using addresses that may select more than one device, which could result in bus contention.



Figure 4. Example of Using Linear Chip Selection



Figure 5. Example RESET Generation Circuitry



#### **CLK Option**

A 33 MHz clock signal drives the i960 CA microprocessor CLKIN input. Driving CLKMODE to "1" configures the i960 CA microprocessor for a x1 CLK input. The i960 CA microprocessor outputs an internally-referenced 33 MHz clock on its PCLK1 and PCLK2 pins (the signals on PCLK1 and PCLK2 are identical), which drives the CLK inputs of the PLD and the 28F016XS-15s.

#### Reset

An active-low reset signal, RESET#, connects to the RESET# inputs of the i960 CA microprocessor, and the PLD, and to the RP# input of the 28F016XS-15s. Figure 5 illustrates a suggested logic configuration for generating RESET#.

#### **Interface Control Signals**

The i960 CA-33 microprocessor external bus signals, BLAST#, ADS# and W/R#, serve as inputs to the state machine, which controls the two-bit counter and generates OE#, WE# and ADV#. The counter is loaded at the beginning of the memory access, generating the burst addresses to the 28F016XS-15s. ADV# indicates that a valid address is available to the 28F016XS-15. Addresses are latched and a read cycle is initiated on a rising CLK edge. WE# controls writes to the 28F016XS-15, latching data into the 28F016XS-15 on its rising edge if the applicable timing requirements are satisfied. (Data is latched on the falling edge of WE# during page buffer writes.)

#### Configuration Signal

A general purpose input/output (GPIO) generates the configuration signal input to the state machine. The configuration signal must reset to logic "0" on power-up and system reset to ensure that the operation of the state machine matches the initial configurations of the 28F016XS-15s and the i960 CA microprocessor. After optimizing the 28F016XS-15s and i960 CA microprocessor, the configuration signal must switch to logic "1."

#### Additional 28F016XS Control Signals

The BYTE# input to the 28F016XS-15s is tied to 5.0V to configure the 28F016XS-15s for x16 mode, and A<sub>0</sub> is tied to GND (A<sub>0</sub> is only used for byte addressing). A GPIO controls the write protect input, WP#, to the 28F016XS-15s. As shown in Figure 3, the 28F016XS-15 is compatible with either a 5.0V or

a 12.0V V<sub>PP</sub> voltage and is completely write protected by switching V<sub>PP</sub> to GND. When V<sub>PP</sub> voltage drops below V<sub>PPLK</sub>, the 28F016XS-15 will not successfully complete Program and Erase operations. Figure 3 also illustrates the 28F016XS-15 RY/BY# output connected to a system interrupt for background erase operation. RY/BY#, WP#, and V<sub>PP</sub> implementation are application dependent. See the Additional Information section of this technical paper for documentation that cover these topics in more detail.

#### 2.2 Software Interface Considerations

#### Boot-up Capability / Configuration

This interface supports processor boot from the 28F016XS memory space after power-up or reset. However, the boot code must follow some restrictions until it has properly configured the 28F016XS-15s, the i960 CA microprocessor and the CFG state machine input valve. In the default configuration state, the i960 CA microprocessor supports only non-burst reads and writes. Program control should jump to an area of RAM to execute the configuration sequence. The code must configure the 28F016XS-15s and all necessary i960 CA microprocessor programmable attributes before setting the CFG input to logic "1." Table 1 illustrates the required configuration settings for both the 28F016XS-15s and the i960 CA-33 microprocessor.

Table 1. Configuration Settings for the 28F016XS-15 and i960 CA-33 Microprocessor Employing Address Pipelining at 33 MHz

| Part                                 | Parameter            | Setting          |
|--------------------------------------|----------------------|------------------|
| 28F016XS-15<br>(5V V <sub>CC</sub> ) | SFI Configuration    | 2                |
| i960 CA-33<br>Microprocessor         | Ready Inputs         | OFF              |
|                                      | Byte Ordering        | LITTLE<br>ENDIAN |
|                                      | Bus Width            | 32-BIT           |
|                                      | Wait States:<br>Nrad | -3               |
|                                      | Nrdd                 | 0                |
| 1                                    | Nwad                 | 2                |
|                                      | Nwdd                 | 2                |
| ·                                    | Nxda                 | 0                |
|                                      | Address Pipelining   | ON               |
|                                      | Burst mode           | ON               |



# 2.3 Single and Burst Read Cycle Description at 33 MHz

Refer to the read cycle timing diagrams (Figures 7 and 8) and the state diagram (Figure 6) for the following read cycle discussion.



Figure 6. Read State Diagram of Single and Address Pipelined Burst Control Interface Shown in Figure 3



#### **Initial Configuration**

Figure 7 illustrates a read cycle with the 28F016XS-15s and i960 CA microprocessor in a reset/power-up configuration state. The initial configuration permits only non-burst transfers. The i960 CA microprocessor initiates a read cycle by asserting ADS# with W/R# = "0," presenting the valid address and control signals. At N = 1, the two-bit counter loads the values on address bits  $A_{3-2}$ . The state machine asserts ADV# for the next clock edge (N = 2), where the 28F016XS-15 will clock in the address if CS# is asserted. If CS# is not asserted, the state machine returns to inactive state at N = 2. The state machine asserts ADV# for only

one clock edge before entering a hold state to await the assertion of BLAST# by the i960 CA microprocessor. The state machine asserts OE# (to meet timing requirements OE# is falling-edge triggered) on the falling edge between N=2 and N=3 to enable the 28F016XS-15 data output buffers. With SFI Configuration = 4, the data will be valid at the N=7. The 28F016XS-15s will hold data on the bus until the i960 CA microprocessor asserts BLAST#. During the clock period following N=y, the state machine returns to its inactive state, de-asserting OE# to tri-state the 28F016XS-15 data outputs.



Figure 7. Example Read Cycle, Initial Configuration, Showing Key Specifications Requiring Consideration



#### **Optimized Configuration**

Figure 8 illustrates a two double-word burst read followed by a four double-word burst read with the 28F016XS-15s, i960 CA microprocessor and state machine configured for optimum read performance. With CFG = 1, the counter increments the two lower bits of the address at N = 2, N = 3 and N = 4, and ADV # remains asserted so that the 28F016XS-15 latches in four successive addresses at N = 2 through 5. With SFI Configuration = 2, the first data will be valid at N = 5. If a second read cycle follows the current read cycle, the i960 CA microprocessor will assert ADS# one clock after asserting BLAST#. The state machine will respond by immediately re-entering the read

cycle. After detecting the assertion of BLAST#, the state machine will return to its inactive state waiting for a new access targeting the 28F016XS memory space.

When implementing the i960 CA microprocessor address pipelining capability, the state machine controlling CS# monitors the upper address lines, ADS# and BLAST#. CS# is held active upon detecting an access targeting the flash memory space until BLAST# is asserted with ADS# de-asserted. When BLAST# and ADS# are active at the same time, a pipelined read access is in progress. The CS# state machine examines the upper address lines to determine whether or not the current pipelined access is aimed at the 28F016XS memory space.



Figure 8. Example Two Double-Word Burst Read Followed by Pipelined Four Double Word Burst Read Showing Key Specifications Requiring Consideration



#### **Critical Timings**

Table 2 describes the critical timings illustrated in Figures 7 and 8. One particularly critical timing in this designs, is the data hold time. The i960 CA-33 microprocessor requires a 5 ns hold time after the clock edge. The 28F016XS-15 guarantees a 5 ns data hold after clock, meeting the processor's hold requirement with 0 ns of margin.

This design provides 7 ns of margin in meeting the 3 ns setup time of the i960 CA-33 microprocessor data inputs, outputting data  $t_{CHOV}$  after a rising CLK edge.

Another critical area concerns CS# during pipelined read accesses. Since the 28F016XS-15 specifies zero

data hold from CE# going high, the chip select state machine must hold CS# active for 5 ns to satisfy the i960 CA-33 microprocessor data input hold specification of 5 ns. Hence, the chip select state machine holds CS# active for an additional clock period after detecting BLAST# active.

The i960 CA-33 microprocessor control outputs ADS# and W/R# have 3 ns of margin and BLAST# has 5 ns of margin to meeting the 85C22V10-15 input setup requirement.

Consult the appropriate datasheets for full timing information.

Table 2. Example Read Cycle Timing Specifications at 5V V<sub>CC</sub>

| Part                                  | Symbol            | Parameter                     | Minimum Specified<br>Value (ns) |
|---------------------------------------|-------------------|-------------------------------|---------------------------------|
| 85C22V10-15                           | t <sub>SU1</sub>  | Input Setup Time to CLK       | 9                               |
| i960 CA-33 Microprocessor             | T <sub>IS1</sub>  | Input Setup D <sub>31-0</sub> | 3                               |
| · · · · · · · · · · · · · · · · · · · | T <sub>IH1</sub>  | Input Hold D <sub>31-0</sub>  | 5                               |
| 28F016XS-15                           | t <sub>ELCH</sub> | CE# Setup to CLK              | 25                              |
|                                       | t <sub>VLCH</sub> | ADV# Setup to CLK             | 15                              |
|                                       | tavch             | Address Setup to CLK          | 15                              |
|                                       | <sup>t</sup> GLCH | OE# Setup to CLK              | 15                              |

#### NOTE:

Consult appropriate datasheets for up-to-date specifications.



# 2.4 Single Burst Write Cycle Description at 33 MHz

Refer to the write cycle timing diagrams and the state diagram (Figure 9) for the following write cycle discussion.



Figure 9. Write State Diagram of Control Interface Shown in Figure 3

#### **Initial Configuration**

Figure 10 illustrates a write cycle. In the reset/power-up configuration state, the interface supports only non-burst writes. The 1960 CA microprocessor initiates a write cycle by asserting ADS# with W/R# = "1," presenting a valid address and control signals. At N = 1, the two-bit counter loads the values on address bits  $A_{3-2}$ . The state machine asserts WE# (to meet timing requirements, WE# is falling-edge triggered) on the falling edge between N = 1 and N = 2. WE# remains asserted for two clock periods, in order to meet the 28F016XS-15 timing requirements. The state machine then enters a holding state until the processor asserts BLAST#, after which time the interface state machine will return to S0.

#### **Optimized Configuration**

Figure 11 illustrates a two double-word burst write with CFG = "1." When the first data write is complete at N = 4, the counter increments the two lower address bits, and the state machine asserts WE# on the next falling clock edge to begin the next the 28F016XS-15 data write. The i960 CA microprocessor must provide the next data during the clock period following N = 4. The data writes continue to the next consecutive addresses until the i960 CA microprocessor asserts BLAST#, indicating the end of the burst write cycle.





Figure 10. Example Write Cycle, Initial Configuration, Showing Key Specifications Requiring Consideration



Figure 11. Example Two Double-Word Burst Write Illustrating Key Specifications Requiring Considerations



#### **Critical Timings**

Table 3 describes the critical timings illustrated in Figures 10 and 11.

One critical hold time to notice is  $t_{WHAX}$ . WE# is guaranteed to transition within 8 ns from the falling clock edge. Therefore, the  $t_{WHAX}$  requirement has 2 ns of margin on CTR<sub>1-0</sub>, and 5 ns of margin on  $A_{31-4}$ .

Also notice that  $CTR_{1-0}$  must be valid before WE# is asserted.  $CTR_{1-0}$  are guaranteed valid 8 ns after the rising clock edge, providing 9 ns of margin.

Consult the appropriate datasheets for full timing information.

Table 3. Example Write Cycle Timing Parameters at 5V V<sub>CC</sub>

| Part        | Symbol            | Parameter                      | Minimum Specified Value (ns) |
|-------------|-------------------|--------------------------------|------------------------------|
| 85C22V10-15 | t <sub>SU1</sub>  | Input Setup Time to CLK        | 9                            |
| 28F016XS-15 | t <sub>ELWL</sub> | CE# Setup to WE# Going Low     | 0                            |
|             | t <sub>AVWL</sub> | Address Setup to WE# Going Low | 0                            |
|             | <sup>t</sup> wLWH | WE# Pulse Width                | 50                           |
|             | t <sub>DVWH</sub> | Data Setup to WE# Going High   | 50                           |
|             | twHDX             | Data Hold from WE# High        | 0                            |
|             | twhax             | Address Hold from WE# High     | 5                            |
|             | twheh             | CE# Hold from WE# High         | 5                            |

#### NOTE:

Consult appropriate datasheets for up-to-date specifications.



#### 3.0 i960® JF-33 MICROPROCESSOR INTERFACE



Figure 12. Minimal Interface Logic Required in Interfacing the 28F016XS-15 to the i960 JF-33 Microprocessor

Using this interface, the 28F016XS-15/i960 JF-33 microprocessor system can achieve 3-0-0-0 wait state read performance, supporting burst transfers.

#### 3.1 Circuit Description

This design (Figure 12) uses two 28F016XS-15s to match the 32-bit data bus of the i960 JF microprocessor, providing 4 Mbytes of flash memory. Four octal latches, enabled by the ALE signal, de-multiplex the 32-bit address from the AD bus. The latched address bits QAD<sub>21-4</sub> and the counter outputs CTR<sub>1-0</sub> from the PLD select locations within the 28F016XS memory space. The two-bit counter implemented in the PLD loads the address bits on A<sub>3-2</sub>, at the beginning of each memory cycle, and generates the lower two bits of the burst addresses on its outputs CTR<sub>1-0</sub> to the 28F016XS-15.

#### **CLK Option**

A 33 MHz clock signal drives the i960 JF microprocessor CLKIN input and the PLD and 28F016XS-15s CLK input.

#### Reset

An active-low reset signal, RESET#, connects to the RESET# inputs of the i960 JF microprocessor and PLD and to the RP# input of the 28F016XS-15. Figure 5 illustrates a suggested logic configuration for generating RESET#.

#### **Interface Control Signals**

ADS# and W/R# i960 JF microprocessor signals, just as in the i960 CA microprocessor design, serve as inputs to the state machine, which controls the two-bit counter and generates the OE#, WE# and ADV# signals for the 28F016XS-15s. The state machine also generates the RDYRCV# signal for the i960 JF microprocessor to control the insertion of wait states during data transfers.



#### **Configuration Signal**

A general purpose input/output (GPIO) generates the configuration signal for input to the state machine. The configuration signal must be reset to logic "0" on power-up and system reset to ensure that the operation of the state machine matches the 28F016XS-15s. After optimizing the 28F016XS-15s, the reconfiguration signal must switch to a logic "1" to take advantage of the new configuration.

#### **Additional Control Signals**

For information regarding BYTE#, WP#, RY/BY# and Vpp, see Section 2.1.

# 3.2 Software Interface Considerations

#### **Boot-up Capability**

This interface supports processor boot-up from the 28F016XS-15 memory space after power-up or reset. Burst reads and writes may commence with no configuration. However, read wait state performance will be 5-1-1-1 until the SFI Configuration is set to 2 and the CFG input is set to logic "1." Program control should jump to an area of RAM to execute the configuration sequence. A pseudocode flow for this configuration sequence is shown below.

Execute Device Configuration command sequence Activate CFG signal End

The SFI Configuration must be set to 2 before the CFG input is set to logic "1." Thereafter, burst read wait state performance will improve to 3-0-0-0.



## 3.3 Burst Read Cycle Description at 33 MHz

Refer to the read cycle timing diagrams and state diagram (Figure 13) for the following discussions of the read cycle.



Figure 13. Read State Diagram of Burst Control Interface Shown in Figure 12





Figure 14. Example Four Double-Word Burst Read in Initial Configuration
Showing Key Specifications Requiring Consideration

#### **Initial Configuration**

Figure 14 illustrates a four double-word burst read cycle with the 28F016XS-15s and the state machine in the reset/power-up configuration state. The i960 JF microprocessor initiates a read cycle by asserting ADS# with W/R # = "0", presenting a valid address and control signals. At N = 1 with ADS # = "0", the two-bit counter loads the values on the address bits  $A_{3,2}$ .

The state machine asserts ADV # after clock edge N=1 where the 28F016XS-15s will clock in the first address at the next rising clock edge (N=2), if CS # is asserted. If CS # is not asserted, the state machine will return to its inactive state at N=2.

The state machine deactivates ADV# at N=2. The state machine then asserts ADV# at N=3 to load the next read address into the 28F016XS-15s. De-asserting ADV# for one clock cycle (at N=2, 4, 6 and 8) between accesses forces the 28F016XS-15s to hold data output for two clock cycles (access stretching), which allows time for the data to stabilize and meet the timing requirements of the i960 JF microprocessor bus.

The counter increments the two lower bits of the address at N=3, 5 and 7 to provide the four successive burst addresses. The state machine asserts OE# (to meet timing requirements OE# is falling-edge triggered) on the falling edge between N=4 and N=5 to enable the 28F016XS-15 data output buffers. With the SFI Configuration = 4, the data will be valid at the i960 JF microprocessor data inputs at N=7.

The state machine asserts RDYRCV# to inform the i960 JF microprocessor that the data is valid. RDYRCV# is returned active at N=7,9,11 and 12. The interface will follow this methodology until the processor asserts BLAST#, which identifies the end of the burst transaction. BLAST# is examined at N=7,9,11 and 13. The interface will transition to its inactive state, S0, after the assertion of BLAST#.



## **Optimized Configuration**

Figure 15 illustrates a four double-word burst read with the 28F016XS-15s and state machine configured for optimum read performance. With the SFI Configuration = 2, ADV# is held active and the counter increments at N = 2, 3 and 4, supplying the 28F016XS-15s with four consecutive accesses. Data from the initial access

will be valid for transfer at N=5. Subsequent data will be valid at N=6, 7 and 8. This interface and 28F016XS-15 configuration improve read wait-state performance to 3-0-0-0. All other signal monitoring and generation are identical to the reset/power-up configuration read cycle documented in the preceding section.



Figure 15. Example Four Double-Word Burst Read Illustrating Important Timing Parameters Requiring Consideration



## **Critical Timings**

Table 4 describes the critical timings illustrated in Figures 14 and 15. One particularly critical timing in this design is the data hold time, which the 28F016XS-15 meets with 0 ns margin. The 28F016XS holds data for 5 ns after a rising clock.

The 28F016XS-15 will provide data 10 ns before the rising edge of the system clock, which satisfies the i960 JF-33 microprocessor's data input requirement.

ADV# and CTR<sub>1-0</sub> are guaranteed valid 8 ns after the rising clock edge. Setup times for these inputs to 28F016XS-15 are each 15 ns. Since the clock period is 30 ns, this allows 7 ns margin for these timings.

RDYRCV# is guaranteed valid 8 ns after the rising clock edge to met the microprocessor's setup time to rising clock edge.

Consult the appropriate datasheets for full timing information.

Table 4. Example Write Cycle Timing Parameters at 5V V<sub>CC</sub>

| Part        | Symbol Parameter  |                         | Minimum Specified<br>Value (ns) |  |  |
|-------------|-------------------|-------------------------|---------------------------------|--|--|
| 85C22V10-15 | tsu1              | Input Setup Time to CLK | 9 •                             |  |  |
| 28F016XS-15 | t <sub>ELCH</sub> | CE# Setup to CLK        | 25                              |  |  |
| •           | tvLCH             | ADV# Setup to CLK       | 15                              |  |  |
|             | t <sub>AVCH</sub> | Address Setup to CLK    | 15                              |  |  |
|             | tGLCH             | OE# Setup to CLK        | 15                              |  |  |

## NOTE:

Consult appropriate datasheets for up-to-date specifications.



## 3.4 Burst Write Cycle Description at 33 MHz



Figure 16. Write State Diagram of Burst Control Interface Shown in Figure 12

#### Write Configuration

Figure 17 illustrates a two double-word burst write cvcle. The i960 JF microprocessor initiates a write cycle by asserting ADS# with W/R# = 1 and presenting a valid address and control signals. At N = 1 with ADS# = 0, the two-bit counter loads the values on the address bits A<sub>3-2</sub>. The state machine asserts WE# (to meet timing requirements, WE# is falling-edge triggered) on the falling edge between N = 1 and N = 2. WE# remains asserted for four clock periods, in order to meet 28F016XS-15 timing requirements. The state machine asserts RDYRCV # for N = 4 to inform the i960 JF microprocessor to supply the next data. At N = 4, the counter increments the two lower address bits, and the state machine asserts WE# on the next falling clock edge to begin the next data write to the 28F016XS-15s. The data writes continue until the processor asserts BLAST#, noting the end of the current write transaction. The SFI Configuration has no effect on the write cycle.



Figure 17. Two Double-Word Burst Write



## **Critical Timings**

Table 5 describes the critical timings illustrated in Figure 17.

Notice that  $CTR_{1-0}$ , and CS# must be valid before WE# is asserted.  $CTR_{1-0}$  are guaranteed valid 8 ns after the rising clock edge, providing 12 ns of margin.

Consult the appropriate datasheets for full timing information.

Table 5. Example Write Cycle Timing Parameters at 5V V<sub>CC</sub>

| Part        | Part Symbol Parameter |                                | Minimum Specified Value (ns) |  |
|-------------|-----------------------|--------------------------------|------------------------------|--|
| 85C22V10-15 | t <sub>SU1</sub>      | Input Setup Time to CLK        | 9                            |  |
| 28F016XS-15 | t <sub>ELWL</sub>     | CE# Setup to WE# Going Low     | 0                            |  |
|             | t <sub>AVWL</sub>     | Address Setup to WE# Going Low | 0                            |  |
|             | twLWH                 | WE# Pulse Width                | 50                           |  |
|             | t <sub>DVWH</sub>     | Data Setup to WE# Going High   | 50                           |  |
|             | twHDX                 | Data Hold from WE# High        | 0                            |  |
|             | twhax                 | Address Hold from WE# High     | 5                            |  |
|             | twhEH                 | CE# Hold from WE# High         | 5                            |  |

#### **NOTES:**

Consult appropriate datasheets for up-to-date specifications.



## 4.0 i960 KB-25 MICROPROCESSOR INTERFACE



Figure 18. Minimal Logic Required in Interfacing 28F016XS-20 to the i960 KB-25 Microprocessor

Using this interface, the 28F016XS-20/i960 KB-25 microprocessor system can achieve 3-0-0-0 wait state read performance (5-1-1-1 read performance) in terms of the CPU's internal 25 MHz CLK, supporting burst cycles. This design operates the logic and 28F016XS-20s at 25 MHz.

## 4.1 Circuit Description

This interface uses two 28F016XS-20s to match the 32-bit data bus of the i960 KB microprocessor, providing access to 4 Mbytes of flash memory. Like the 28F016XS-20 interface to the i960 JF microprocessor, four octal latches de-multiples the 32-bit address from the LAD bus. The latches are enabled by an inverted ALE# signal from the microprocessor. The latched address and two-bit counter integrated into the PLD select locations with the flash memory space. The two-bit counter loads the address bits on LAD<sub>3-2</sub> at the beginning of each memory cycle, and generates the lower two bits of the burst addresses on its outputs CTR<sub>1-0</sub>.

## **CLK Option**

In this interface, a 50 MHz clock signal drives the i960 KB microprocessor CLK2 input, and an external 25 MHz clock signal, synchronized to the i960 KB microprocessor internal 25 MHz clock, drives the CLK inputs for the 28F016XS-20s and the PLD. The reduced clocking frequency places a less stringent demand on the PLD to meet setup times, thereby allowing the usage of a slower PLD.

External 25 MHz CLK generation and synchronization can be accomplished using simple flip-flop logic. The i960 KB microprocessor synchronizes its internal 25 MHz clock on the falling edge of RESET.

Two different methods for generating a 25 MHz CLK are illustrated in Figure 19, and the PLD equations are located in the Appendix A.



The two 1X clock generation methods in Figure 19 will produce a different amount of clock skew between the 2x and 1x CLK. Clock generation method (A) will have

a maximum skew of T<sub>CO1</sub>, while method (B) will have little to no clock skew because the 2x and 1x CLKs are exposed to the same PLD delay (see Figure 20).



Figure 19. Example 1x CLK Generation and Synchronization Circuitry



Figure 20. CLK Skew Produced by the Two Different CLK Generation Methods Illustrated in Figure 19



## 4.2 Software Interface Considerations

## **Boot-up Capability**

This interface supports processor boot-up from the 28F016XS-20 memory space after power-up or reset. Burst reads and writes may commence with no configuration. However, read wait-state performance will be 5-0-2-0 until the SFI Configuration is set to 2 and the CFG input is set to logic "1." Thereafter, burst transfers will improve to 3-0-0-0 wait state perform-

ance. Program control should jump to an area of RAM to execute the configuration sequence. The code must set the SFI Configuration to 2 before setting the CFG input to logic "1."

## 4.3 Read Burst Cycle Description at 25 MHz

Refer to the read cycle timing diagrams and the state diagram (Figure 21) for the following discussion of the read cycle.



Figure 21. Read State Diagram of Burst Control Interface Logic Shown in Figure 18





Figure 22. Example Four Double-Word Burst Read in Initial Configuration Showing Key Specifications Requiring Consideration

## **Initial Configuration**

Figure 22 illustrates a four double-word burst read cycle with the 28F016XS-20s and state machine in the reset/power-up configuration state. The i960 KB microprocessor initiates a read cycle by asserting ADS# with W/R# = "0," presenting valid address and control signals.

At N = 1, the two-bit counter loads the values on address bits  $A_{3-2}$ . The state machine asserts ADV# at the next clock edge (N = 2), where 28F016XS-20 will latch in the address if CS# is asserted. If CS# is not asserted, the state machine will return to its inactive state at N = 2. The counter increments the two lower bits of the address at N = 2 and ADV# remains asserted so that the 28F016XS-20 clocks in the first two burst addresses at N = 2 and 3.

With the SFI Configuration = 4, the state machine must wait 4 clock periods between loading two even or two odd addresses into 28F016XS-20. Therefore, the state machine asserts ADV# at N=6 and N=7 to latch the third and fourth addresses, respectively,

into 28F016XS-20. The state machine asserts OE# (to meet timing requirements OE# is falling-edge triggered) on the falling edge between N=4 and N=5 to enable the 28F016XS-20 data output buffers. Data will be valid at the i960 KB microprocessor data inputs at N=7.

The state machine asserts READY# to inform the i960 KB microprocessor that the data is valid. To compensate for the delayed third and fourth burst addresses, the state machine must de-assert READY# for N third and fourth addresses, respectively, N=9 and N=10 before again asserting READY# for N=11 and N=12, when the third and fourth data, respectively, become valid.

The i960 KB microprocessor encodes the length of the burst transfer onto the two lowest bits of the initial address. Therefore, the state machine decodes QAD<sub>1-0</sub> to determine the end of the burst transfer. At this point, the state machine will return to its inactive state, S0, de-asserting OE# to tri-state the 28F016XS-20's data outputs.





Figure 23. Example Four Double-Word Burst Read Illustrating Key Specifications Requiring Consideration

## **Optimized Configuration**

Figure 23 illustrates a four double-word burst read with the 28F016XS-20s and state machine configured for optimum read performance. With the SFI Configuration = 2, 28F016XS-20 can accept addresses with only two clock periods between each even address and two clock periods between each odd address. Therefore, the four burst addresses flow into SFI on successive rising clock edges and the four data become valid for transfer on successive rising clock edges with the first data valid by N=5. Otherwise, the transaction is similar to the reset/power-up configuration read cycle.

## **Critical Timings**

Table 6 describes the critical timings illustrated in Figures 22 and 23. One particularly critical timing in this design is the data hold time. The i960 KB-25 microprocessor requires a 5 ns hold time after the clock edge. The 28F016XS-20 guarantees a 5 ns data hold after

clock, meeting the setup requirement with 0 ns of margin. This design provides:

$$1/25 \text{ MHz} - t_{10} = 7 \text{ ns}$$

of margin to meeting the 3 ns setup time of the i960 KB-25 microprocessor data inputs.

Another critical area concerns CS# and QA<sub>21-4</sub> setup time to 28F016XS-20. This design allows two clock periods (80 ns) for these signals to stabilize and meet the 28F016XS-20 setup time. Since the i960 KB-25 microprocessor guarantees ALE# and LAD<sub>31-0</sub> 18 ns after the rising clock edge and the 28F016XS-20 setup time is 30 ns, this leaves:

$$2*1/25 \text{ MHz} - t_6 - t_{ELCH} = 32 \text{ ns}$$

for the propagation delays of the inverter plus the latch plus the chip select decode logic (if applicable, for CS#).



READY# is guaranteed valid 8 ns after the falling clock edge, providing 5 ns of margin on the 7 ns setup required by the i960 KB-25 microprocessor.

Consult the appropriate datasheets for full timing information.

OE# is also guaranteed valid 8 ns after the falling clock edge, providing 0 ns of margin on the 12 ns setup requirement.

Table 6. Example Read Burst Cycle Timing Parameters at 5V V<sub>CC</sub>

| Part                      | Symbol Paramete  |                         | r Minimum Specific Value (ns) |  |
|---------------------------|------------------|-------------------------|-------------------------------|--|
| 85C22V10-15               | t <sub>SU1</sub> | Input Setup Time to CLK | 9                             |  |
| i960 KB-25 Microprocessor | T <sub>10</sub>  | Input Setup 1           | 3                             |  |
|                           | T <sub>11</sub>  | Input Hold              | 5                             |  |
|                           | T <sub>12</sub>  | Input Setup 2           | 7                             |  |
| 28F016XS-20               | tELCH            | CE# Setup to CLK        | 30                            |  |
|                           | tvLCH            | ADV# Setup to CLK       | 20                            |  |
|                           | tavch            | Address Setup to CLK    | 20                            |  |
|                           | tGLCH            | OE# Setup to CLK        | 20                            |  |



## 4.4 Write Burst Cycle Configuration at 25 MHz



Figure 24. Write State Diagram of Burst Control Interface Logic in Figure 18





Figure 25. Example Two Double-Word Burst Write Showing Key Timing Parameters Requiring

Consideration

#### Write Considerations

The i960 KB microprocessor initiates a write cycle by asserting ADS# with W/R# = 1 and presenting a valid address and control signals. At N = 1 with ADS# = 0, the two-bit counter loads the values on the address bits LAD<sub>3-2</sub>. The state machine asserts WE# (to meet timing requirements, WE# is falling-edge triggered) on the falling edge between N = 1 and N = 2. WE# remains asserted for two clock periods, in order to meet the 28F016XS-20 timing requirements. The state machine asserts READY# for N = 4 to inform the i960 KB microprocessor to supply the next data. At N = 4, the counter increments the two lower address bits, and the state machine asserts WE# on the next falling clock edge to begin the next data write to the 28F016XS-20s. The data writes continue until the burst cycle is complete. The state machine determines the length of the burst cycle by decoding QAD<sub>1-0</sub>. The 28F016XS-20 Configuration has no effect on the write cycle.

#### **Critical Timings**

Table 7 describes the critical timings illustrated in Figure 25.

One critical hold time to notice is  $t_{WHAX}$ . WE# is guaranteed to transition with 8 ns from the falling clock edge. Therefore, the  $t_{WHAX}$  requirement has 7 ns of margin on  $CTR_{1-0}$  and 9 ns of margin on  $A_{31-4}$ .

Also notice that  $CTR_{1-0}$  must be valid before WE# is asserted.  $CTR_{1-0}$  are guaranteed valid 8 ns after the rising clock edge, providing 12 ns of margin.

Consult the appropriate datasheets for full timing information.



|                              | Table 7. Example write burst Cycle Tilling Parameters at 5V VCC |                                |                                 |  |  |  |
|------------------------------|-----------------------------------------------------------------|--------------------------------|---------------------------------|--|--|--|
| Part                         | Symbol                                                          | Parameter                      | Minimum Specified<br>Value (ns) |  |  |  |
| 85C22V10-15                  | tsu1                                                            | Input Setup Time to CLK        | 9                               |  |  |  |
| i960 KB-25<br>Microprocessor | T <sub>11</sub>                                                 | Input Hold                     | 5                               |  |  |  |
|                              | T <sub>12</sub>                                                 | Input Setup 2                  | 7                               |  |  |  |
| 28F016XS-20                  | tELWL                                                           | CE# Setup to WE# Going Low     | 0                               |  |  |  |
|                              | t <sub>AVWL</sub>                                               | Address Setup to WE# Going Low | 0                               |  |  |  |
|                              | twLwH                                                           | WE# Pulse Width                | 50                              |  |  |  |
|                              | t <sub>DVWH</sub>                                               | Data Setup to WE# Going High   | 50                              |  |  |  |
|                              | t <sub>WHDX</sub>                                               | Data Hold from WE# High        | 0                               |  |  |  |
|                              | twhax                                                           | Address Hold from WE# High     | 5                               |  |  |  |
|                              | twheh                                                           | CE# Hold from WE# High         | 5                               |  |  |  |

Table 7. Example Write Burst Cycle Timing Parameters at 5V Voc

## 5.0 INTERFACING TO OTHER 1960 **MICROPROCESSORS**

i960®CF-16, i960®CF-25 and i960®CF-33 Microprocessors

The i960 CF microprocessor bus interface is completely compatible with the i960 CA microprocessor bus interface. Therefore, the 28F016XS-15 interfaces described above for the i960 CA-33 microprocessor work equally well with the i960 CF-25 and 33 MHz microprocessors.

At 16 MHz, the interface requires a slight modification because the SFI Configuration value at 16 MHz equals 1. The 28F016XS-15 will begin driving the data pin 1 CLK period after initiating a read access. The interface returns READY # to the i960 CF-16 microprocessor, 1 CLK cycle earlier. Therefore, the 28F016XS-15 interface to the i960 CF-16 microprocessor will deliver 3-0-0-0 wait-state read performance.

#### i960® SA Microprocessor, i960® SB Microprocessor

The 28F016XS's interface to the i960® Sx microprocessor series will be similar to the i960 KB microprocessor interfaces, with the following differences:

• The i960 Sx microprocessor series has a 16-bit data bus multiplexed with the lower 16 of 32 address bits. Therefore, a single 28F016XS will match the width of the data bus.

- Two octal latches will de-multiplex the address/data bus, and the ALE signal, without inversion, will properly enable the latches.
- The i960 Sx microprocessor series supports eight double-word burst transfers. Therefore, 28F016XS interface will require a three-bit counter to generate the lower three bits of the burst address-
- The interface state machine must use the i960 Sx microprocessor BLAST# signal to recognize the end of a burst cycle (see the i960 CA microprocessor state diagrams).

## 6.0 CONCLUSION

This technical paper has described the interface between the 28F016XS 16-Mbit Flash memory component and the i960 microprocessor family. This simple design has been implemented with a minimal number of components and achieves exceptional read performance. The 28F016XS provides the microprocessor with the non-volatility and update ability of flash memory and the performance of DRAM. For further information about 28F016XS, consult reference documentation for a more comprehensive understanding of device capabilities and design techniques. Please contact your local Intel or distribution sales office for more information on Intel's flash memory products.



## **ADDITIONAL INFORMATION**

| Order Number                               | Document/Tools                                                                           |  |  |
|--------------------------------------------|------------------------------------------------------------------------------------------|--|--|
| 290532                                     | 28F016XS Datasheet                                                                       |  |  |
| 297500                                     | "Interfacing 28F016XS to the Intel486™ Microprocessor Family"                            |  |  |
| 292147                                     | AP-398, "Designing with the 28F016XS"                                                    |  |  |
| 292146                                     | AP-600, "Performance Benefits and Power/Energy Savings of 28F016XS Based System Designs" |  |  |
| 297372                                     | 16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016XS/28F016XD       |  |  |
| 297508                                     | FlashBuilder Utility                                                                     |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Benchmark Utility                                                               |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS iBIS Models                                                                     |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS VHDL/Verilog Models                                                             |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Timing Designer Library Files                                                   |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Orcad and ViewLogic Schematic Symbols                                           |  |  |

## **REVISION HISTORY**

| Number | Description      |
|--------|------------------|
| 001    | Original Version |



# APPENDIX A PLD FILES

PLD File for the 28F016xs Interface to the i960 CA-33 Microprocessor

28F016XS/ i960 CA Microprocessor Interface State Machine Title Pattern **PDS** Revision Authors Example Intel Corporation - Folsom, California Company Date 1-25-94 CHIP STATEMACHINE 85C22V10 ; inputs PIÑ CLK . PIN ADS\_n ; address status - i960 CA microprocessor PIN  $W_R_n$ ; W/R# - i960 CA microprocessor PIN BLAST\_n ; burst last - i960 CA microprocessor PIN ; chip select - 28F016XS CS\_n ; 28F016XS/i960 CA microprocessor config status set input PIN CFG PIN A2 : LAD bit 2 PIN : LAD bit 3 **A3** PIN RESET ; resets all FFs in device **PIN 25 GLOBAL** ; virtual pin to implement reset ; outputs PIN CTR<sub>0</sub> ; burst counter out - 28F016XS-A1 : burst counter out - 28F016XS-A2 PIN CTR1 PIN /WE ; write enable - 28F016XS PIN OE/ ; output enable - 28F016XS PIN Q0 : state variables PIN Q1 /ADV PIN ; state variable and address valid - 28F016XS PIN Q3 : burst counter control signals STRING LD '(/ADS\_n)' ; load STRING INC '(ADV \*/Q1 \*/O0 + 03 \* ADV \* /01 + O3 \* /O1 \* /O0)' ; increment STATE MOORE\_MACHINE **DEFAULT\_BRANCH SO** 

297500-26



```
; state assignments
           S0 = /O3 * /ADV * /O1 * /O0
           S1 = /O3 * ADV * /Q1 * /Q0
           S2 = O3 * ADV * /O1 * /O0
           S3 = O3 * ADV * /Q1 * Q0
           S4 = /Q3 * ADV * /Q1 * Q0
           S5 = /Q3 * /ADV * /Q1 * Q0
           S6 = /Q3 * /ADV * Q1 * /Q0
           S7 = Q3 * /ADV * Q1 * /Q0
           S8 = O3 * /ADV * /Q1 * /Q0
: state transitions
S0 := (/ADS_n * /W_R_n)
                            -> S1
                                       : READ cycle
       (/ADS_n * W_R_n)
                             -> S6
                                       ; WRITE cycle
                         +-> S0
                                       ; else, stay
       (/CS_n * /CFG)
                             -> S5
                                       ; 28F016XS selected, initial configurations
S1 :=
                                       : 28F016XS selected, 28F016XS and i960 CA microprocessor configured
       (/CS_n * CFG)
                             -> S2
                        +-> S0
                                       : else, return to idle state
S2 :=
        VCC
                             -> S3
S3 :=
       VCC
                             -> S4
                                       ; 28F016XS is configured to wait 4 clocks
                                       : I double word read
S4 :=
       (/BLAST_n * ADS_n) -> S0
                                       ; pipelined read
        (/BLAST_n * /ADS_n) -> S1
                                       ; else, continue
                         +-> S5
                                       ; burst read finished
       (/BLAST n * ADS_n) -> S0
S5 :=
                                       ; pipelined read
        (/BLAST_n * /ADS_n) -> S1
                                       ; else, continue
                         +-> S5
                                       : 28F016XS selected, continue
                             -> S7
S6 :=
       /CS_n
                       +-> S0
                                  ; else, return to idle state
S7 :=
       VCC
                             -> S8
       (BLAST_n * CFG)
                             -> S6
                                       ; continue burst
S8 :=
        (BLAST_n * /CFG)
                            -> S8
                                       : pre-config write
                        +-> S0
                                       : write is finished
; transition outputs
               /OE * /WE
S0.OUTF :=
                /OE * /WE
S1.OUTF :=
                OE * /WE
S2.OUTF :=
                OE * /WE
S3.OUTF :=
                OE * /WE
S4.OUTF :=
                OE * /WE
S5.OUTF :=
                OE * /WE
S6.OUTF :=
S7.OUTF :=
                /OE * WE
               /OE * WE
S8.OUTF :=
                /OE * /WE
S9.OUTF :=
EQUATIONS
  : implement RESET
      GLOBAL.RSTF = /RESET
  : implement 2-bit burst counter - registered counter equations
      CTR1 := (LD * A3) + (/LD * INC * CTR0 * /CTR1)
            + (/LD * INC * /CTR0 * CTR1) + (/LD * /INC * CTR1)
      CTR0 := (LD * A2) + (/LD * INC * /CTR0) + (/LD * /INC * CTR0)
  ; flop OE and WE on falling edge
      OE.CLKF = /CLK
      WE.CLKF = /CLK
                                                                                                297500-27
```



## PLD File for the 28F016XS Interface to the i960 JF-33 Microprocessor

```
28F016XS/i960 JF Microprocessor Interface State Machine
Title
Pattern
Revision
Authors
                    Example
                    Intel Corporation - Folsom, California
Company
                    8-16-94
Date
            STATEMACHINE
                                     85C22V10
CHIP
; inputs
                    CLK
PIN
                                         ; address status - i960 FJ microprocessor
PIN
                    ADS
                    W_R
                                         ; W/R# - i960 FJ microprocessor
PIN
                                         ; burst last - i960 JF microprocessor
PIN
                    BLAST
                                         ; chip setect
PIN
                    CS
                    CFG
                                         : 28F016XS/i960 JF microprocessor config status set input
PIN
                                         : A bit 2
                    A2
PIN
                                         ; A bit 3
                    A3
PIN
                    RESET
                                         ; resets all FFs in device
PIN
                    GLOBAL
                                         ; virtual pin to implement reset
PIN 25
: outputs
                                         : burst counter out - 28F016XS-A1
                    CTR<sub>0</sub>
PIN
                                         : burst counter out - 28F016XS-A2
PIN
                     CTRI
                                         ; write enable - 28F016XS
                     /WE
PIN
                                         ; output enable - 28F016XS
                     OE/
PIN
                    /RDYRCV
                                         ; wait-state control
PIN
                                         ; state variables
PIN
                     00
PIN
                     Q1
                                         ; state variable and address valid - 28F016XS
PIN
                    /ADV
                     O3
PIN
 ; burst counter control signals
STRING LD'(/ADS)'
                                         : load
STRING INC '(ADV
               + RDYRCV * Q3 * Q1 * Q0)' ; increment
STATE
MOORE_MACHINE
DEFAULT BRANCH SO
                                                                                                297500-28
```



```
; state assignments
           S0 = /RDYRCV * /O3 * /ADV * /O1 * /O0
           S1 = /RDYRCV * /O3 * ADV * /O1 * /O0
           S2 = /RDYRCV * /O3 * ADV * /O1 * O0
           S3 = /RDYRCV * /Q3 * ADV * Q1 * /Q0
           S4 = RDYRCV * /O3 * ADV * O1 * O0
           S5 = RDYRCV * /Q3 * /ADV * /Q1 * O0
           S6 = /RDYRCV * /Q3 * /ADV * Q1 * /Q0
           S7 = /RDYRCV * Q3 * ADV * /Q1 * /Q0
           S8 = /RDYRCV * /Q3 * /ADV * Q1 * Q0
           S9 = /RDYRCV * Q3 * ADV * /Q1 * Q0
           S10 = RDYRCV * Q3 * /ADV * /Q1 * /Q0
           S11 = /RDYRCV * Q3 * ADV * Q1 * /Q0
           S12 = /RDYRCV * Q3 * /ADV * /Q1 * Q0
           S13 = /RDYRCV * Q3 * /ADV * Q1 * /Q0
           S14 = /RDYRCV * Q3 */ADV * Q1 * Q0
           S15 = RDYRCV * Q3 */ADV * Q1 * Q0
; state transitions
       (/ADS * /W_R)
                            -> S1
S0 :=
                                      ; READ cycle
       (/ADS * W_R)
                            -> S13
                                      ; WRITE cycle
                        +-> S0
                                      ; else, stay
       (/CS * /CFG)
S1 :=
                            -> S6
                                      ; 28F016XS selected, init configurations
                            -> S2
       (/CS * CFG)
                                      ; 28F016XS selected, optimized configured
                        +-> S0
                                      ; else, return to idle state
       VCC
S2 :=
                            -> S3
       VCC
                            -> S4
                                      ; 28F016XS is configured to wait 4 clocks
S3 :=
       (/BLAST * ADS)
                            -> S0
                                      ; I double word read
S4 :=
                        +-> S5
                                      ; else, continue
S5 :=
       /BLAST
                            -> S0
                                      ; burst read finished
       (BLAST * CFG)
                            -> S5
                                      ; continue, optimized configuration
       (BLAST * /CFG)
                            -> S12
                                      ; continue, initial configuration
S6 :=
       VCC
                            -> S7
                            -> S8
       VCC
S7 :=
S8 :=
       VCC
                            -> S9
S9 :=
        VCC
                             -> S10
S10:=
       /BLAST
                             -> S0
                                      : BLAST - end of the burst read transaction
       BLAST
                             -> S11
S11:=
        VCC
                             -> S5
                             -> S5
S12:=
        VCC
S13:=
       CS
                             -> S0
                                      ; write cycle control
       /CS
                             -> S14
S14:=
        VCC
                             -> S15
       BLAST
                             -> S13
                                      ; BLAST - end of burst write transaction
S15:=
       /BLAST
                             -> S0
; transition outputs
S0.OUTF :=
               /OE * /WE
S1.OUTF :=
               /OE * /WE
S2.OUTF :=
                OE * /WE
S3.OUTF :=
                OE * /WE
S4.OUTF :=
                OE * /WE
                OE * /WE
S5.OUTF :=
               /OE * /WE
S6.OUTF :=
               /OE * /WE
S7.OUTF :=
                OE * /WE
S8.OUTF :=
                OE * /WE
S9.OUTF :=
                                                                                             297500-29
```



```
OE * /WE
S10.OUTF :=
S11.OUTF :=
               OE * /WE
S12.OUTF :=
               OE * /WE
S13.OUTF :=
              /OE * WE
              /OE * WE
S14.OUTF :=
S15.OUTF :=
              /OE * /WE
EQUATIONS
 : implement RESET
     GLOBAL.RSTF = /RESET
 ; implement 2-bit burst counter - registered counter equations
     CTR1 := (LD * A3) + (/LD * INC * CTR0 * /CTR1)
            + (/LD * INC * /CTR0 * CTR1) + (/LD * /INC * CTR1)
     CTR0 := (LD * A2) + (/LD * INC * /CTR0) + (/LD * /INC * CTR0)
 ; flop OE and WE on falling edge
     OE.CLKF = /CLK
     WE.CLKF = /CLK
                                                                                   297500-30
```



## PLD File for the 28F016XS Interface to the i960 KB-25 Microprocessor

```
28F016XS/i960 KB Microprocessor Interface State Machine - 25MHz Version
Title
Pattern
                   PDS
Revision
                   1
Authors
                   Example
                   Intel Corporation - Folsom, California
Company
                   1-18-94
Date
CHIP
           STATEMACHINE
                                   85C22V10
; inputs
PIN 1
                   CLK
PIN
                   ADS
                                       ; address status - i960 KB microprocessor
                   QA0
                                       : latched LAD bit 0
PIN
PIN
                   QAI
                                       ; latched LAD bit I
                                       ; W/R# - i960 KB microprocessor
PIN
                   W_R
                   CS
                                       ; chip select - 28F016XS
PIN
                   CFG
                                       ; 28F016XS config status input
PIN
                                       ; CFG=0 => 28F016XS config=4 (initial config)
                                       : CFG=1 => 28F016XS config=2
                                       : LAD bit 2
PIN
                   A2
                   A3
                                       : LAD bit 3
PIN
                   RESET
                                       : resets all FFs in device
PIN
    25
                   GLOBAL
                                       ; virtual pin to implement reset
PIN
; outputs
                                       : burst counter out - 28F016XS-A1
PIN
                    CTR0
                    CTR1
                                       ; burst counter out - 28F016XS-A2
PIN
                                       ; output enable - 28F016XS
PIN
                   /OE
                                       ; write enable - 28F016XS
PIN
                   /WE
                                       ; i960 KB microprocessor
PIN
                   /READY
PIN
                   /ADV
                                       ; state register and address valid - 28F016XS
PIN
                    00
                                       : state registers
PIN
                    Q1
                    Q2
PIN
                    Q3
PIN
 ; burst counter control signals
STRING LD '(S0 * /ADS)'
                                        : load
STRING INC '(S1 + S2 + S3
              + S9 + S13 + S16 + S19)'
                                       ; increment
STATE
MOORE_MACHINE
DEFAULT_BRANCH SO
; state assignments
            SO = ADV * /O3 * /O2 * /O1 * /O0
            S1 = ADV * /Q3 * /Q2 * /Q1 * /Q0
            S2 = ADV */Q3 */Q2 */Q1 * Q0
            S3 = ADV * /Q3 * /Q2 * Q1 * Q0
            S4 = ADV */Q3 */Q2 * Q1 */Q0
            S5 = ADV * Q3 * Q2 * Q1 * Q0
            S6 = ADV * Q3 * /Q2 * Q1 * /Q0
            S7 = /ADV * /Q3 * /Q2 * /Q1 * Q0
            S8 = /ADV * /Q3 * Q2 * Q1 * Q0
                                                                                              297500-31
```



```
S9 = ADV */Q3 * O2 * O1 * O0
            S10 = ADV * /Q3 * Q2 * Q1 * /Q0
            S11 = /ADV * Q3 * /Q2 * /Q1 * /Q0
            S12 = /ADV * Q3 * /Q2 * /Q1 * Q0
            S13 = /ADV * Q3 * /Q2 * Q1 * Q0
            S14 = /ADV * Q3 * /Q2 * Q1 * /Q0
            S15 = /ADV * Q3 * Q2 * Q1 * /Q0
            S16 = /ADV * Q3 * Q2 * Q1 * Q0
            S17 = /ADV * Q3 * Q2 * /Q1 * Q0
            S18 = ADV * Q3 * Q2 * /Q1 * Q0
            S19 = /ADV * Q3 * Q2 * /Q1 * /Q0
            S20 = /ADV * /Q3 * Q2 * /Q1 * /Q0
            S21 = ADV * /Q3 * Q2 * /Q1 * /Q0
            S22 = /ADV * /Q3 * Q2 * /Q1 * Q0
            S23 = ADV * Q3 * Q2 * Q1 * Q0
            S24 = /ADV * /Q3 * /Q2 * Q1 * Q0
            S25 = ADV * Q3 * Q2 * Q1 * /Q0
; state transitions
        (/ADS * /W_R_n)
S0 :=
                              -> S1
                                       ; READ cycle
        (/ADS * W_R_n)
                              -> S11
                                       ; WRITE cycle
                          +-> S0
                                       ; else, stay
        /CS
S1 :=
                              -> S2
                                        : continue if 28F016XS is selected
                          +-> S0
                                        ; else, return to idle state
S2 :=
        /CFG
                             -> S24
                                       ; 28F016XS is configured to wait 4 clocks
                          +-> S3
                                        ; else, continue
        VCC
S3 :=
                              -> S4
                                        ; else, continue
        (/QA1 * /QA0)
S4 :=
                             -> S0
                                        : 1 double word read
                          +-> S5
                                        ; else, continue
S5 :=
        (/QA1 * QA0)
                              -> S0
                                       ; 2 double word burst read
                             -> S23
        (QA1 * /CFG)
                                        ; SFI Configuration = 4
                          +-> S6
                                        ; else, continue
S6 :=
        (QA1 * /QA0)
                             -> S0
                                        : 3 double word burst read
                          +-> S7
                                        : else, continue
S7 :=
        VCC
                                        : 4 double word burst read
                             -> S0
S8 :=
        VCC
                              -> S9
S9 :=
        VCC
                          +-> S5
                                        ; else, continue
S11 := /CS
                              -> S12
                                        : continue if 28F016XS is selected
                          +-> S0
                                        : else, return to idle state
S12 := VCC
                              -> S13
S13 := (/QA1 * /QA0)
                              -> S0
                                        : I double word write
                          +-> S14
                                        ; else, continue
S14 := VCC
                             -> S15
S15 := VCC
                              -> S16
S16 := (/QA1 * QA0)
                              -> SO
                                        ; 2 double word burst write
                          +-> S17
                                        ; else, continue
S17 := VCC
                              -> S18
S18 := VCC
                             -> S19
S19 := (QA1 * /QA0)
                              -> S0
                                        ; 3 double word burst write
                          +-> S20
                                        ; else, continue
S20 := VCC
                              -> S21
S21 := VCC
                              -> S22
S22 := VCC
                              -> S0
                                        : 4 double word burst write
S23 := VCC
                              -> S25
S24 := VCC
                              -> S8
S25 := VCC
                              -> S6
                                                                                              297500-32
```



```
: transition outputs
              /WE * /OE * /READY
S0.OUTF :=
S1.OUTF :=
              /WE * /OE * /READY
              /WE * /OE * /READY
S2.OUTF :=
S3.OUTF :=
              /WE * OE * /READY
S4.OUTF :=
              /WE * OE * READY
S5.OUTF :=
              /WE * OE * READY
S6.OUTF :=
              /WE * OE * READY
              /WE * OE * READY
S7.OUTF :=
S8.OUTF :=
              /WE * OE * /READY
              /WE * OE * /READY
S9.OUTF :=
              /WE * OE * READY
S10.OUTF :=
              WE * /OE * /READY
S11.OUTF :=
S12.OUTF :=
              WE * /OE * /READY
              /WE * /OE * READY
S13.OUTF :=
              WE * /OE * /READY
S14.OUTF :=
S15.OUTF :=
              WE * /OE * /READY
S16.OUTF :=
              /WE * /OE * READY
              WE * /OE * /READY
S17.OUTF :=
S18.OUTF :=
              WE * /OE * /READY
              /WE * /OE * READY
S19.OUTF :=
               WE * /OE * /READY
S20.OUTF :=
S21.OUTF :=
               WE * /OE * /READY
              /WE * /OE * READY
S22.OUTF :=
S23.OUTF :=
              /WE * OE * /READY
S24.OUTF :=
              /WE * /OE * /READY
S25.OUTF :=
              /WE * OE * /READY
EQUATIONS
 ; implement RESET
     GLOBAL.RSTF = RESET
 ; implement 2-bit burst counter - registered counter equations
     CTR1 := (LD * A3) + (/LD * INC * CTR0 * /CTR1)
            + (/LD * INC * /CTR0 * CTR1) + (/LD * /INC * CTR1)
     CTR0 := (LD * A2) + (/LD * INC * /CTR0) + (/LD * /INC * CTR0)
 ; flop WE, OE, and READY on falling edge
     WE.CLKF = /CLK
     OE.CLKF = /CLK
     READY.CLKF = /CLK
                                                                                 297500-33
```



## PLD File for the 1x CLK Generation and Synchronization

Title

1x Clock Generations & Sychronization

Pattern

PDS

Revision

Author Company Name Example Intel

Date

5/26/94

CHIP Clock\_Generation\_Circuit 85C220

; input pins

PIN PIN CLK RESET

; clk frequency 33MHz

; output pins

PIN

SYSCLK

**EQUATIONS** 

SYSCLK := /SYSCLK \* /RESET

SYSCLK.CLKF = CLK

297500-34

## PLD File for th1 1x and 2x CLK Generation and Synchronization

Title

1x and 2x Clock Generation and Synchronization

Pattern

PDS

Revision

Author Company Name

Example Intel

Date

5/26/94

CHIP Clock\_Generation\_Circuit 85C220

; input pins

CLK PIN

; clk frequency 4x

RESET PIN

; System RESET

; output pins

PIN

CLK2

; 2x CLK output

SYSCLK PIN

: Sychronized 1x CLK output

**EQUATIONS** 

CLK2 := /CLK2

CLK2.CLKF = CLK

SYSCLK := CLK2 \* SYSCLK \* /RESET +/CLK2 \*/SYSCLK \*/RESET

SYSCLK.CLKF = CLK

297500-35



# APPENDIX B BENCHMARK PERFORMANCE ANALYSIS

The following section provides detailed memory technology information used in the performance analysis (UDP/IP Networking and Imaging Benchmarks) contained in the introduction. The performance analysis was based on actual memory component performance in an i960 processor-based environment. System interface delay between microprocessor and memory was not included in the analysis. The two benchmarks illustrate relative system memory performance.

## A. 28F016XS Flash Memory

28F016XS is capable of 3-1-1-1-1-1-1-1... read performance at 5.0V  $V_{CC}$  and 33 MHz or 25 MHz (2-0-0-0-0-0-0... in terms of wait states). The benchmarking analysis is shown below:

|                              | UDP/IP Networking Benchmark | Imaging Benchmark |  |  |
|------------------------------|-----------------------------|-------------------|--|--|
| 1                            | Time (sec)                  | Time (sec)        |  |  |
| i960 KB-25<br>Microprocessor | 1.30                        | 1.64              |  |  |
| i960 CA-33<br>Microprocessor | .89                         | .89               |  |  |
| i960 CF-33<br>Microprocessor | .53                         | .59               |  |  |

#### B. 16-Mbit DRAM

16-Mbit DRAMs were, at the time this technical paper was published, only beginning to ramp into production. Only advance information for the wider x16, 16-Mbit DRAMs was available for use in the calculations that follow.

Sequential reads allow use of the DRAM fast page mode. Assumed DRAM specifications are shown below:

- 80 ns t<sub>RAC</sub>, 40 ns t<sub>AA</sub> (5.0V V<sub>CC</sub>)
- 256 word (512 byte) page buffer

Therefore, 16-Mbit DRAMs are capable of 3-2-2-2-2-2... read performance at 33 MHz and 25 MHz (2-1-1-1-1-1-1-1). The benchmarking analysis is shown below:

|                              | UDP/IP Networking Benchmark | Imaging Benchmark |
|------------------------------|-----------------------------|-------------------|
|                              | Time (sec)                  | Time (sec)        |
| i960 KB-25<br>Microprocessor | 1.88                        | 1.89              |
| i960 CA-33<br>Microprocessor | 1.06                        | 1.03              |
| i960 CF-33<br>Microprocessor | .59                         | .64               |



## C. 4-Mbit EPROM

Calculations that follow used the x16 version of the 4-Mbit EPROM (Intel 27C400 or equivalent).

The assumed 5.0V  $V_{CC}$  4-Mbit EPROM random access time is 150 ns. Therefore, 4-Mbit EPROMs are capable of 5-5-5-5-5-5-5 . . . read performance at 5.0V  $V_{CC}$  and 33 MHz (4-4-4-4-4-4 . . . in terms of wait states). The benchmarking analysis is shown below:

|                              | UDP/IP Networking Benchmark | Imaging Benchmark |  |
|------------------------------|-----------------------------|-------------------|--|
|                              | Time (sec)                  | Time (sec)        |  |
| i960 KB-25<br>Microprocessor | NA NA                       | NA                |  |
| i960 CA-33<br>Microprocessor | 1.56                        | 1.49              |  |
| i960 CF-33<br>Microprocessor | .78                         | .81               |  |

## D. 16-Mbit PAGED MASK ROM

Calculations that follow used the x16 version of the 16-Mbit paged mask ROM, which is not yet widely available from multiple vendors. The x8, 16-Mbit paged mask ROM is the more common version today.

Sequential reads allow use of the mask ROM page mode. The assumed 5.0V  $V_{CC}$  16-Mbit mask ROM random access time is 150 ns, with 75 ns accesses in page mode (4-word page). Therefore, 16-Mbit mask ROMs are capable of 5-3-3-3-5-3-3-3... read performance at 5.0V  $V_{CC}$  and 33 MHz (4-2-2-2-4-2-2... in terms of wait states). The benchmarking analysis is shown below:

|                              | UDP/IP Networking Benchmark | Imaging Benchmark |  |  |
|------------------------------|-----------------------------|-------------------|--|--|
|                              | Time (sec)                  | Time (sec)        |  |  |
| i960 KB-25<br>Microprocessor | NA                          | NA                |  |  |
| i960 CA-33<br>Microprocessor | 1.35                        | 1.30              |  |  |
| i960 CF-33<br>Microprocessor | .71                         | .73               |  |  |



## TECHNICAL PAPER

# Interfacing the 28F016XS to the Intel486<sup>TM</sup> Microprocessor Family

KEN MCKEE
TECHNICAL MARKETING
ENGINEER
PHILIP BRACE
APPLICATIONS ENGINEER

December 1994

## 3

## Interfacing the 28F016XS to the Intel486™ Microprocessor Family

| CONTENTS                             | PAGE  | CONTENTS                              | PAGE  |
|--------------------------------------|-------|---------------------------------------|-------|
| 1.0 INTRODUCTION                     | 3-240 | 5.0 READ CYCLE CONTROL FOR            |       |
| 2.0 INTERFACE CIRCUITRY DESCRIPTION  | 0.041 | SINGLE AND BURST<br>TRANSACTIONS      | 3-245 |
|                                      | 3-241 | 6.0 WRITE CYCLE CONTROL               | 3-250 |
| 3.0 INTERFACING SIGNAL DEFINITIONS   | 3-243 | 7.0 INTERFACING TO OTHER              |       |
| 3.1 28F016XS Signal Descriptions     |       | INTEL486 <sup>™</sup> MICROPROCESSORS | 3-252 |
| 3.2 Intel486™ SX Signal Descriptions | 3-244 | 8.0 CONCLUSION                        | 3-252 |
| 4.0 SYSTEM INTERFACE REQUIREMENT     | 0.044 | ADDITIONAL INFORMATION                | 3-253 |
| REQUIREMENT                          | 3-244 | REVISION HISTORY                      | 3-253 |



## 1.0 INTRODUCTION

This technical paper describes designs interfacing the high performance 28F016XS flash memory to the Intel486™ microprocessor. These designs are based on preliminary 28F016XS specifications. Please contact your Intel or distribution sales office for up-to-date information. Do not finalize a design based on the specifications in this document. These designs have been fully simulated by not yet taken to lab prototype.

The 28F016XS is a 16-Mbit flash memory with a synchronous pipelined read interface. This enhanced flash memory interface delivers equivalent or better read performance compared to DRAM. The 28F016XS combines ROM-like non-volatility, DRAM-like read performance and in-system updateability into one memory technology. These inherent capabilities will improve performance and lower the over-all system cost of a burst microprocessor, such as the Intel486 microprocessor based design. The Intel486 microprocessor sees widespread use in a variety of applications ranging from the PC to numerous embedded products, while providing code compatibility with thousands of commercially available software packages and the performance necessary for today's leading-edge systems. The Intel486 microprocessor's bus interface provides a burst transfer mechanism whereby four consecutive data items are fetched in one access sequence. The 28F016XS's synchronous pipelined read interface makes special use of the burst transfer mechanism to achieve extremely high read performance.

When interfacing the 28F016XS to a processor that executes an Intel or linear burst cycle, up to three simultaneous read accesses can be piped into the 28F016XS. At 33 MHz, the 28F016XS-15 delivers zero wait-state performance after the initial pipeline fill. This enhanced

read performance eliminates the costly expense of shadowing code from slow non-volatile memory (ROM, hard disk drive, etc.) to fast DRAM for increased system performance. The 28F016XS enables direct code execution out of the flash memory array, eliminating unnecessary software and hardware overhead involved in shadowing code.

In an Intel486 microprocessor-based environment, BAPCo benchmarking analysis revealed a 13% system performance improvement using the 28F016XS-15 over 70 ns DRAM.

In addition to the increased read performance, the 28F016XS offers an Intel486 microprocessor-based system a low power, non-volatile memory that is electrically updateable via local processor control. The 28F016XS's low power consumption reduces system power dissipation and heat emission, and its updateability increases code flexibility and system reliability. Combined, the 28F016XS and the Intel486 microprocessor deliver a high performance, low power and cost-effective system solution.

The Intel486 interface to the 28F016XS requires minimal logic while offering significant system enhancements. One programmable logic device (PLD), a 85C22V10-15, generates and monitors all 28F016XS and Intel486 microprocessor control signals. This technical paper explores the interface between the 28F016XS-15 and the Intel486 SX-33, describing the interface circuitry, explaining the read and write cycles and providing the interfacing PLD equations. It also provides detailed design suggestions for interfacing the 28F016XS to other Intel486 microprocessors.





Figure 1. Minimal Glue Logic in Interfacing the 28F016XS-15/Intel486TM SX-33

## 2.0 INTERFACE CIRCUITRY DESCRIPTION

The 28F016XS-15 interface to the Intel486 SX-33 illustrated in Figures 1 delivers 3-0-0-0 wait-state read performance.

## **Memory Configuration**

This design uses two 28F016XS-15s, each configured in x16 mode and arranged in parallel to match the Intel486 SX's 32-bit data bus, providing 4 MBytes of flash memory. Signals  $A_{21-4}$  from the Intel486 SX and  $CTR_{1-0}$  from the PLD select locations within the

28F016XS memory space, arranged as 1 Meg double words. The two-bit counter implemented in the PLD loads addresses  $A_{3-2}$  at the beginning of each memory cycle and increments through the Intel burst order, feeding consecutive addresses to the 28F016XSs.

## Reset

The Intel486 SX requires an active high reset signal, while the 28F016XSs use an active low RESET#. Figure 2 illustrates a suggested logic configuration for generating both an active high and low reset signal. The active high RESET controls the Intel486 SX and PLD RESET inputs, while the active low RESET# drives the 28F016XS RP# input.





Figure 2. RESET Generation Method

## **Chip Select Logic**

Chip select decode logic may use  $A_{31-22}$  to generate active low chip select signals, CEx#, for the 28F016XS memory space and other system peripherals. The chip select addressing the 28F016XS memory space drives CE<sub>0</sub># on each 28F016XS-15 and a control input to the PLD. The 28F016XS-15s' CE<sub>1</sub># inputs are grounded. For many systems, using the upper address bits in a linear selection scheme may provide a sufficient number of chip select signals, thus eliminating chip select decode logic. (See Figure 3 for an example of using linear selection for chip selects.) When using a linear chip select scheme however, software must avoid using addresses that may select more than one device, which could result in bus contention. For example, addresses 01000000H through 010FFFFFH drive both A22 and A<sub>23</sub> to a logic "0," which inadvertently selects two peripheral devices.



Figure 3. Example of Using Linear Chip Selection with Active Low Chip Select Signals



## **CLK Option**

A 33 MHz CLK drives the Intel486 SX, the PLD and the 28F016XS-15s. Position the PLD and the 28F016XS-15s within close proximity to the microprocessor to minimize CLK skew between CPU, interface logic and flush memory components.

## **Interface Control Signals**

The interfacing state machine monitors the Intel486 SX's external bus signals to control the two-bit counter and generate OE#, WE# and ADV# signals to the 28F016XS-15s. At the beginning of the burst cycle, the interface logic loads the two-bit counter and generates burst addresses to the 28F016XS-15s. The state machine also generates KEN#, BRDY# and RDY# signals, informing the Intel486 SX of the nature of the bus cycle.

## **Configuration Signal**

A general purpose input/output (GPIO) generates the configuration signal input to the state machine. The configuration signal must reset to logic "0" on power-up and system reset to ensure that the operation of the state machine matches the initial SFI Configuration of the 28F016XS-15s. After optimizing the SFI Configuration, the GPIO must switch to logic "1." See Section 4 for more information regarding the configuration signal.

## **Additional 28F016XS Control Signals**

The BYTE# input to the 28F016XS-15s is tied to 5.0V to configure the 28F016XS-15s for x16 mode, and A<sub>0</sub> is tied to GND (A<sub>0</sub> is only used for byte addressing). A GPIO controls the write protect input, WP#, to the 28F016XS-15s. The 28F016XS is compatible with either a 5.0V or a 12.0V Vpp voltage and is completely protected from data alteration when VPP is switched below  $V_{PPLK}$ . With  $V_{PP} \leq V_{PPLK}$ , the 28F016XS will not successfully complete Data Write and Erase operations, resulting in absolute flash memory data protection. Figure 1 also illustrates the 28F016XS-15's RY/ BY # output connecting directly to a system interrupt, which enables background Write/Erase operations. RY/BY#, WP#, and Vpp implementations are application dependent. Consult the Additional Information section of this technical paper for documentation covering these topics in more detail.

## 3.0 INTERFACING SIGNAL DEFINITIONS

The interface logic that controls the 28F016XS-15 Intel486 SX-33 interface monitors and regulates specific signals. The next two sections describe these signals.

## 3.1 28F016XS Signal Descriptions

This section describes the 28F016XS signals that are pertinent to this design.

## ADV # — Address Valid (Input)

This active low signal informs the 28F016XS that a valid address is present on its address pins. ADV#, in conjunction with a rising CLK edge, initiates a read access to the 28F016XS. This signal is ignored during write operations.

## CLK—Clock (Input)

CLK provides the fundamental timing and internal operating read frequency for the 28F016XS. CLK initiates read accesses (in conjunction with ADV#), times out the SFI Configuration, and synchronizes device outputs. CLK can be slowed or stopped with no loss of data synchronization. This signal, like ADV#, is ignored during write operations.

## OE#—Output Enable (Input)

This active low signal activates the 28F016XS's output buffers when OE# equals "0". The outputs tri-state when OE# is driven to "1".

## WE#—Write Enable (Input)

This active low signal controls access to the Control User Interface (CUI), Page Buffers, Data Queue Registers and Address Queue Latches. Addresses (command or array) and data are latched on the rising edge of WE# during write cycles, while page buffer addresses are latched on the falling edge of WE#.



## 3.2 Intel486TM SX Signal Descriptions

This section describes the Intel486 SX signals that are relevant to this interface. This interface assumes processor inputs are driven by only one controlling device (the PLD). If more than one device drives a processor input, the PLD output should be configured as open drain to avoid signal contention. Many PLDs, FPGAs and ASICs provide output configuration capability.

## ADS#—Address Status (Output)

This active low output signal from the Intel486 SX processor indicates the presence of valid bus cycle and address signals on the bus. ADS# is driven in the same clock as the address signals. Typically, external circuitry uses ADS# to indicate the beginning of a bus cycle.

## KEN#—Cache Enable (Input)

This active low input to the Intel486 SX determines whether data being returned in the current bus cycle will be cached. In order for the current data to be cached, KEN# must be returned active in the clock prior to the first RDY# or BRDY# of the cycle and must also be returned active in the last clock of the data transfer.

#### RDY # -- Non-Burst Ready (Input)

RDY# indicates the completion of the current bus cycle. During a read, the assertion of RDY# indicates to the microprocessor that valid data exists on the data bus. During a write, RDY# indicates that the external device has accepted the data being supplied by the microprocessor.

## BRDY #-Burst Ready (Input)

This active low input to the microprocessor performs the same function during a burst cycle as RDY# performs during a non-burst cycle. During a burst cycle, BRDY# is sampled on the rising edge of every clock. Upon sampling BRDY# active, the data on the data bus will be latched into the microprocessor (for burst reads). ADS# will be negated during the second transfer of the burst cycle; however, the lower address lines and byte enables may change to indicate the next data item requested by the processor.

## BLAST#-Burst Last (Output)

This active low output from the microprocessor signals the final transfer in a burst cycle. The next time BRDY# is returned, it will be treated the same as RDY# and thus terminate any multiple cycle transfers.

## 4.0 SYSTEM INTERFACE REQUIREMENT

The system logic controlling the 28F016XS-15/Intel486 SX interface has both an initial and an optimized read configuration, correlating to specific SFI Configuration values. The interface read configuration is dependent upon the value of RECONFIG (PLD input), which informs the interface of the SFI Configuration status. Note, the SFI Configuration status does not affect Write operations.

## **Initial Read Configuration**

Upon power-up/reset, the 28F016XS-15 defaults to a SFI Configuration value of 4, and the interface logic supports single read accesses to the 28F016XS-15 memory space. The interface returns RDY# to inform the processor that the interface does not support burst cycles. A general purpose input/output (GPIO) informs the system interface of the status of the SFI Configuration.

The GPIO, RECONFIG, must be set to logic "0" on power-up/reset. With RECONFIG driven low, the state machine correctly matches the 28F016XS-15's default configuration.

## **Optimized Read Configuration**

At 33 MHz, the 28F016XS-15 operates at highest performance with a SFI Configuration value set to 2. Reconfiguring the 28F016XS-15, program control should jump to an area of RAM to execute the configuration sequence. After reconfiguring the 28F016XS-15, the GPIO value must change to logic "1," in order to take advantage of the 28F016XS-15's optimized configuration. A pseudocode flow for this configuration sequence is shown below.

Execute Device Configuration command sequence Activate RECONFIG signal End

In the optimized read configuration, the system logic supports burst cycles by generating BRDY#, which informs the microprocessor that the memory subsystem



is capable of handling a burst transfer. The 28F016XS-15 memory array, when executing burst cycles, transfers data to the processor at a rate of 132 MBytes/sec.

# 5.0 READ CYCLE CONTROL FOR SINGLE AND BURST TRANSACTIONS

The read state machine (Figure 4) performs one of two different read cycles, initial or optimized configuration, depending upon the RECONFIG input value.

## **Read Abort Condition**

A read cycle will abort only when an external system bus master asserts BOFF#, which forces the processor to give immediate bus control to the requester. When this situation occurs, the Intel486 SX floats the address bus, which will cause the address decode logic to de-select the 28F016XS memory space. The interfacing logic, monitoring BOFF#, will transition to an idle state waiting for the processor to re-initiate the interrupted bus cycle after the bus master has relinquished the bus to the processor. OE# is immediately driven high, deactivating the 28F016XS-15's output buffers, upon detecting BOFF# driven active. This BOFF# condition can occur in both the initial and optimized configurations described in the paragraphs that follow.

#### **Initial Configuration**

Refer to Figures 4 and 5 for the following read cycle discussion.

With RECONFIG set to logic "0," the interfacing read state machine executes single non-cacheable read cycles. This configuration occurs upon power-up and reset.

The microprocessor initiates a read access to the 28F016XS memory space by providing an address, driving W/R # low and activating ADS#. Monitoring the external bus of the Intel486 SX, the state machine transitions into read control.

If ADS# = 0 and W/R# = 0 then READ CONTROL

At this point, RECONFIG and CE# are examined to determine the configuration status of the 28F016XS-15s, and whether or not the current address targets the 28F016SX memory space. If CE# = "1," the state machine returns to an idle state waiting for a new access. In the initial configuration (RECONFIG = "0"), read control regulates ADV#, RDY# and OE#.

At N=1 (Figure 5), the counter loads address bits  $A_{3\cdot 2}$  and transitions ADV# low. With ADV# at logic "0," the interface initiates a read access to the 28F016XS-15s at N=2. After initiating the read access, ADV# immediately switches to a logic "1" at N=2 and remains at this value throughout the rest of the access.

In the default SFI Configuration (SFI Configuration = 4), data will be accessible to the processor at N=7. The 28F016XS-15's output buffers are enabled at N=4 and RDY# is driven low at N=6. The processor will sample RDY# active and latch the information residing on the data bus at N=7, marking the completion of the read access. The Intel486 SX requires a 3 ns hold time after sampling RDY# active, therefore, the state machine transitions to a state where it holds OE# active to force the 28F016XS-15s to hold the data on their output pins. At N=8, the state machine transitions to an idle state where it deactivates OE# and waits for the Intel486 SX to initiate a new bus cycle targeting the 28F016XS memory space.

## **Initial Configuration Timing Consideration**

In the initial read configuration, CE# setup is a key system timing parameter.

To satisfy the 28F016XS-15 setup requirement, CE# must be valid 25 ns prior to the first rising CLK edge with ADV# = "0." Therefore, the maximum time allotted for the address decoding logic to generate CE# equals:

$$2 * 1/33 \text{ MHz} - t_6 - t_{ELCH} = 19 \text{ ns}$$

Consult the appropriate datasheets for full timing information.





Figure 4. State Diagram of Single and Burst Read Control (Interface Shown in Figure 1)





Figure 5. Example Non-Burst Read Cycle Showing Key Timing Specifications Requiring Consideration

Table 1. Example Initial Read Cycle Timing Specifications at 5V V<sub>CC</sub>

| Symbol            | Description                                       | Min | Max | Unit |
|-------------------|---------------------------------------------------|-----|-----|------|
| <b>t</b> 6        | ADS# Delay (Intel486™ SX-33)                      | 3   | 16  | ns   |
| t <sub>16</sub>   | RDY# Setup Time (Intel486™ SX-33)                 | 5   |     | ns   |
| t <sub>22</sub>   | D <sub>31-0</sub> Setup Time (Intel486™ SX-33)    | 5   |     | ns   |
| t <sub>ELCH</sub> | CE <sub>X</sub> # Setup Time to CLK (28F016XS-15) | 25  |     | ns   |
| tvlch             | ADV# Setup Time to CLK (28F016XS-15)              | 15  |     | ns   |
| t <sub>GLCH</sub> | OE# Setup Time to CLK (28F016XS-15)               | 15  |     | ns   |
| tchav             | CLK to Data Delay (28F016XS-15)                   |     | 20  | ns   |
| t <sub>PZX</sub>  | CLK Output Delay (85C22V10-15)                    | 2   | 8   | ns   |

## NOTE:

Consult appropriate datasheets for up-to-date specifications.



#### **Optimized Configuration**

Refer to Figures 4 and 6 for the following discussion:

With the 28F016XS-15s in the optimized configuration (SFI Configuration = 2 at 33 MHz), and RECONFIG set to a logic "1" value, the system interface executes cacheable burst cycles.

The Intel486 SX processor drives ADS# low, notifying the interface logic that a valid address is on the address bus. Monitoring the external bus of the Intel486 SX, the state machine then transitions into read control.

If ADS# = 0 and W/R# = 0 then READ CONTROL

In optimized read control, the state machine drives OE#, KEN# and BRDY#. If CE# = "0," the state machine at N = 1 loads the two-bit counter  $(A_{3-2})$  and activates ADV# (ADV# = "0") for the next four consecutive clock periods (N = 1 through 5). While ADV# is driven low, the counter increments through the Intel burst order (Table 2), supplying the 28F016XS-15s with a new address at N = 2, 3, 4 and 5. If CE# = "1," the state machine returns to an idle state waiting for a new memory access.

Table 2. Intel Burst Order  $(A_{3-2})$ 

| First<br>Address | Second<br>Address | Third<br>Address | Fourth<br>Address |
|------------------|-------------------|------------------|-------------------|
| 0                | 4                 | 8                | С                 |
| 4                | 0                 | С                | 8                 |
| 8                | С                 | 0                | 4                 |
| C                | 8                 | 4                | 0                 |

At N = 3, the state machine drives KEN# active and holds it active until the end of the burst cycle, thereby executing a cache line fill.

The state machine activates the 28F016XS-15 output buffers (OE# driven to a logic "0" value) at N=3 and holds them active throughout the burst read cycle.

With the SFI Configuration value set to 2, new data will be available on the 28F016XS-15 output pins at  $N=5,\,6,\,7$  and 8. Driving BRDY# low at N=4, the Intel486 SX microprocessor will sample BRDY# active at N=5, which informs the processor of valid information on data pins  $D_{31-0}$  and that the 28F016XS memory space supports a burst read transfer. BRDY# is held low until the end of the burst cycle while the processor retrieves data on every rising clock edge. BRDY# is driven high upon sampling BLAST# low, marking the end of the burst cycle.

The Intel486 SX requires a 3 ns hold time after sampling the last BRDY# active in a burst cycle. Therefore, the state machine transitions to a state where it holds OE# active, which forces the 28F016XS-15s to hold the data on their output pins. At N = 9, the state machine transitions to an idle state, where it deactivates OE# and waits for the Intel486 SX to initiate a new bus cycle targeting the 28F016XS memory space.

#### **Optimized Configuration Timing Considerations**

In the optimized configuration, CE# setup time is again a key system timing parameter. For information regarding the CE# setup time requirement, see the Initial Configuration Timing Considerations Timing section.





Figure 6. Example Burst Read Cycle Showing Key Timing Specifications Requiring Consideration

Table 3. Example Optimized Read Cycle Specifications at 5V V<sub>CC</sub>

| Symbol            | Description                                       | Min | Max | Unit |
|-------------------|---------------------------------------------------|-----|-----|------|
| t <sub>6</sub>    | ADS# Delay (Intel486™ SX-33)                      | 3   | 16  | ns   |
| t <sub>8a</sub>   | BLAST# Delay (Intel486™ SX-33)                    | 3   | 20  | ns   |
| t <sub>22</sub>   | D <sub>31-0</sub> Setup Time (Intel486™ SX-33)    | 5   |     | ns   |
| t <sub>ELCH</sub> | CE <sub>X</sub> # Setup Time to CLK (28F016XS-15) | 25  |     | ns   |
| t <sub>VLCH</sub> | ADV# Setup Time to CLK (28F016XS-15)              | 15  |     | ns   |
| t <sub>GLCH</sub> | OE# Setup Time to CLK (28F016XS-15)               | 15  |     | ns   |
| t <sub>CHQV</sub> | CLK to Data Delay (28F016XS-15)                   |     | 20  | ns   |
| t <sub>PZX</sub>  | CLK Output Delay (85C22V10-15)                    | 2   | 8   | ns   |

#### NOTE:

Consult appropriate datasheets for up-to-date specifications.



#### 6.0 WRITE CYCLE CONTROL

Refer to Figures 7 and 8 for the following write cycle discussion:

#### **Write Abort Condition**

A write cycle will abort only when an external system bus master asserts BOFF#, which forces the processor to give immediate bus control to the requester. When this situation occurs, the Intel486 SX will float the address bus, causing the address decode logic to de-select the 28F016XS memory space. The interfacing logic, monitoring BOFF#, will transition to an idle state waiting for the processor to re-initiate the interrupted bus cycle after the bus master has relinquished the bus to the processor. WE# is immediately deactivated upon sensing BOFF# low.



Figure 7. Non-Burst Write State Diagram Controlling the Interface Shown in Figure 1

#### **Write Cycle Description**

The 28F016XS-15 executes asynchronous write cycles like traditional flash memory components such as the 28F016SA/SV. The SFI Configuration does not influence write operations; therefore, the interfacing state machine does not examine RECONFIG once detecting a write cycle.

During the first clock period, the Intel486 SX microprocessor drives ADS# low and W/R# high. The state machine detects a write cycle, loads the two-bit counter, activates WE# and transitions to write control at N=1 (Figure 8). The counter only supplies the 28F016XS-15 with one address. A write transaction must compete fully before issuing a second write operation.

In write control, the state machine performs WE#-Controlled Command Write operations to the 28F016XS-15s. Data is written to the 28F016XS-15 memory space via processor control. The interface only supports double word writes.

For the next three clock periods, N=2 through 4, the state machine holds WE# low to satisfy the 28F016XS-15's WE# active requirement. At N=4, WE# transitions to a logic "1," which latches the address and data into the 28F016XS-15s.

RDY# is not returned to the processor at N=4 because the Intel486 SX will only hold an address 3 ns after sampling RDY# low. Instead, the interface activates RDY# after N = 4, causing the processor to hold the address valid for an additional clock cycle, which satisfies the 28F016XS-15's address hold specification ( $t_{WHAX}$ ). The state machine then returns to an inactive state at N = 5, waiting for a new memory access.

#### **Write Timing Consideration**

When performing a write operation, CE# is a critical system timing parameter, which must satisfy the interface logic's required setup time. The 85C22V10-15 requires a 9 ns setup time to CLK. Therefore, the system decode logic must generate a valid CE# to the interface within:

$$2 * 1/33 \text{ MHz} - t_6 - t_{SU} = 35 \text{ ns}$$

Consult the appropriate datasheets for full timing information.





Figure 8. Example Write Cycle Showing
Key Timing Specifications Requiring Consideration

Table 4. Example Write Cycle Timing Specifications at 5V V<sub>CC</sub>

| Symbol            | Description                                | Min | Max | Unit |
|-------------------|--------------------------------------------|-----|-----|------|
| t <sub>6</sub>    | ADS# Delay(Intel486™ SX-33)                | 3   | 16  | ns   |
| t <sub>10</sub>   | Data Write Valid Delay (Intel486™ SX-33)   | 3   | 18  | ns   |
| t <sub>11</sub>   | Data Write Float Delay (Intel486™ SX-33)   |     | 20  | ns   |
| twLWH             | WE# Pulse Width (28F016XS-15)              |     | 50  | ns   |
| t <sub>DVWH</sub> | Data Setup to WE# Going High (28F016XS-15) |     | 50  | ns   |
| t <sub>PZX</sub>  | CLK Output Delay (85C22V10-10)             | 2   | 8   | ns   |

#### NOTE

Consult appropriate datasheets for up-to-date specifications.



# 7.0 INTERFACING TO OTHER INTEL486TM MICROPROCESSORS

The Intel486 microprocessor family provides designers a large and diverse selection of CPUs, which offers designers different performance points to meet different market segment needs. Throughout the product family, the external bus architecture has remained consistent, which makes the 28F016XS interface to the entire Intel486 microprocessor family similar, if not identical, to the Intel486 SX interface described in Sections 2 through 6. The 28F016XS-15 Intel486 SX-33 interface works equally well for the following Intel486 microprocessors at 5.0V V<sub>CC</sub>.

- Intel486 SX-20, 25
- Intel486 SX2TM-50
- Intel486 DX-25, 33
- Intel486 DX2TM-40, 50, 66
- IntelDX4TM-75, 100 (I/O buffers configured for 5.0V,  $V_{CC5} = 5.0V$ )

The 28F016XS-15 Intel486 SX-33 interface also works well for the following Intel486 microprocessors at 3.3V  $V_{CC}$ . The 3.3V  $V_{CC}$  design utilizes a iPLD22V10-15 low voltage PLD to control the interface between the 28F016XS-15 (operating at 3.3V  $V_{CC}$ ) and the processor

- Intel486 SX-20, 25
- Intel486 DX-25
- Intel486 DX2-40, 50
- IntelDX4-75 (I/O buffers configured for 3.3V, V<sub>CC5</sub> = 3.3V)

When the external bus frequency falls outside the 16.7 MHz through 33 MHz frequency range at 5.0V  $V_{\rm CC}$  (12.5 MHz through 25 MHz at 3.3V  $V_{\rm CC}$ ), the optimized SFI Configuration value for the 28F016XS-15 differs in respect to the Intel486 SX-33 design documented earlier. The state machine, therefore, requires slight modifications to accommodate the different SFI Configuration. Note, the initial read configuration and write control state machine remains consistent throughout all designs because they are not affected by the optimized SFI Configuration.

#### Intel486™ SX-16 Interface at 5.0V V<sub>CC</sub>

The 28F016XS-15's optimized SFI Configuration at 16 MHz equals 1. Therefore, 28F016XS-15 will begin driving data one CLK period after initiating the first read access. The optimized state machine must drive

BRDY# and OE# active upon initiating the first access to the 28F016XS-15. BRDY# and OE# remain low throughout the burst cycle. At 16 MHz, this interface delivers 2-0-0-0 wait-state performance.

#### Intel486™ DX-50 Interface at 5V V<sub>CC</sub>

Operating at 50 MHz, the 28F016XS-15's optimized SFI Configuration equals 3. The interface loads the two-bit counter and drives ADV# active at the first rising CLK edge after the processor initiates the read access. The optimized read state machine increments the two-bit counter and drives ADV# low every other CLK, thereby adhering to the Alternating-A<sub>1</sub> and Same-A<sub>1</sub> access rules (see Additional Information). The 28F016XS-15 Intel486 DX-50 interface delivers 5-1-1-1 wait-state read performance.

## Intel486™ DX-33 and IntelDX4™-100 Interface at 3.3V V<sub>CC</sub>

Operating at 33 MHz with 3.3V V<sub>CC</sub>, the 28F016XS-15's optimized SFI Configuration equals 3. The interface loads the two-bit counter and drives ADV# active at the first rising CLK edge after the processor initiates the read access. The optimized read state machine increments the two-bit counter and drives ADV# low for two CLK periods and then strobes ADV# high for one CLK periods finishing the burst cycle. Refer to the *Alternating-A*<sub>1</sub> and *Same-A*<sub>1</sub> access rules (see Additional Information) for further information on consecutive accesses. The 28F016XS-15 Intel486 DX-33 interface at 3.3V V<sub>CC</sub> delivers 4-0-1-0 wait-state read performance.

#### 8.0 CONCLUSION

This technical paper has described the interface between the 28F016XS 16-Mbit flash memory component and the Intel486 microprocessor. This simple design has been implemented with a minimal number of components and achieves exceptional read performance. The 28F016XS provides the microprocessor with the non-volatility and updateability of flash memory and the performance of DRAM. For further information about 28F016XS-15, consult reference documentation for a more comprehensive understanding of device capabilities and design techniques. Please contact your local Intel or distribution sales office for more information on Intel's flash memory products.



### **ADDITIONAL INFORMATION**

| Order Number                               | Document/Tools                                                                           |
|--------------------------------------------|------------------------------------------------------------------------------------------|
| 290532                                     | 28F016XS Datasheet                                                                       |
| 297500                                     | "Interfacing 28F016XS to the i960® Microprocessor Family"                                |
| 292147                                     | AP-398, "Designing with the 28F016XS"                                                    |
| 292146                                     | AP-600, "Performance Benefits and Power/Energy Savings of 28F016XS Based System Designs" |
| 297372                                     | 16-Mbit Flash Product User's Manual,<br>28F016SA/28F016SV/28F016XS/28F016XD              |
| 297508                                     | FlashBuilder Utility                                                                     |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Benchmark Utility                                                               |
| Contact Intel/Distribution<br>Sales Office | 28F016XS iBIS Models                                                                     |
| Contact Intel/Distribution<br>Sales Office | 28F016XS VHDL/Verilog Models                                                             |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Timing Designer Library Files                                                   |
| Contact Intel/Distribution<br>Sales Office | 28F016XS Orcad and ViewLogic Schematic Symbols                                           |

## **REVISION HISTORY**

| Number | Description      |  |
|--------|------------------|--|
| 001    | Original Version |  |



# APPENDIX A PLD FILE FOR THE 28F016XS INTEL486™ INTERFACE

```
28F016XS-15 / 486™ Interface
Title
Pattern
                   PDS
Revision
Author
                   Example
Company Name
                   Intel Corporation
Date
                   2/14/94
CHIP SFI_486_Interface 85C22V10 ; 85C22V10-15
; input pins
           CLK
PIN
                            : clk frequency 33MHz
PIN
           ADS
                            : address strobe from 486
PIN
           WR
                            multiplexed read/write strobe
PIN
           BLAST
                            : BLAST from the 486
PIN
           CE
                             CE from the address decoding logic
           RECONF
PIN
                             informs interface to changes to the SFI
                             Configuration
PIN
           A2
                             lower address lines from the 486 used
                            in loading the counter
PIN
           A3
PIN
           RESET
                            : system reset
PIN
            GLOBAL
      25
; output pins
PIN
          /ADV
                            : address valid input to 28F016XS
PIN
                            : cache control
          /KEN
PIN
          /AU
                            output enable input to 28F016XS
PIN
          WE
                            ; write enable input to 28F016XS
PIN
          /BRDY
                            ; initiating a burst cycle, 486 input
                            ; non-burst cycle ready, again 486 input
PIN
          /RDY
                            : state variable
PIN
           Q0
PIN
                            : state variable
           Q1
                            ; lower bit of the 2-bit counter
PIN
           CONT0
PIN
           CONT1
                            ; higher bit of the 2-bit counter
STATE MOORE_MACHINE
DEFAULT BRANCH SO
                                                                                   297504-9
```



```
: state assignments
S0 = /ADV * /KEN * /AU * /WE * /BRDY * /RDY * /Q0 * /Q1
S1 = ADV * /KEN * /AU * /WE * /BRDY * /RDY * /Q0 * /Q1
S2 = ADV */KEN */AU */WE */BRDY */RDY */Q0 * Q1
S3 = ADV * KEN * AU * /WE * /BRDY * /RDY * /Q0 * /Q1
S4 = ADV * KEN * AU * /WE * BRDY * /RDY * /Q0 * /Q1
S5 = /ADV * KEN * AU * /WE * BRDY * /RDY * /Q0 * /Q1
S6 = /ADV * /KEN * AU * /WE * /BRDY * /RDY * Q0 * Q1
S7 = /ADV * /KEN * /AU * /WE * /BRDY * /RDY * /Q0 * Q1
S8 = /ADV * /KEN * /AU * /WE * /BRDY * /RDY * Q0 * /Q1
S9 = /ADV * /KEN * AU * /WE * /BRDY * /RDY * /Q0 * /Q1
S10 = /ADV * /KEN * AU * /WE * /BRDY * /RDY * /Q0 * Q1
S11 = /ADV * /KEN * AU * /WE * /BRDY * RDY * /Q0 * /Q1
S12 = /ADV * /KEN * /AU * WE * /BRDY * /RDY * /Q0 * /Q1
S13 = /ADV * /KEN * /AU * WE * /BRDY * /RDY * /Q0 * Q1
S14 = /ADV * /KEN * /AU * WE * /BRDY * /RDY * Q0 * /Q1
S15 = /ADV * /KEN * /AU * /WE * /BRDY * RDY * /Q0 * /Q1
; state transitions
S0 := ADS * BOFF
                                    -> S0
                                                ; start of an access
   + /ADS * /BOFF * /WR
                                    -> S1
   + /ADS * /BOFF * WR
                                    -> S12
S1 := /RECONF * /CE
                                    -> S7
                                                ; not reconfigured
                                    -> S2
   + RECONF */CE
                                                ; reconfig active low
                                    -> S0
   + BOFF + CE
S2 := /BOFF
                                    -> S3
                                                ; if BOFF is asserted,
                                    -> S0
   + BOFF
                                                : quit the access and return
S3 := /BOFF
                                    -> S4
                                                : to state S0. The 486 will
   + BOFF
                                  -> S0
                                                : re-initiate the access.
                                    -> S5
S4 := /BOFF
                                   -> S0
   + BOFF
S5 := BLAST
                                    -> S5
                                                : continuos cycling until BLAST is
   + /BLAST + BOFF
                                    -> S6
                                                : presented - end the burst cycle
S6 := ADS * BOFF
                                    -> S0
                                                ; holds OE# active for one additional
   + /ADS * /BOFF * /WR
                                    -> S1
                                                ; CLK to satisfy the 486's data hold
   + /ADS * /BOFF * WR
                                    -> S12
                                                : time.
                                    -> S8
S7 := /BOFF
                                    -> S0
   + BOFF
                                    -> S9
S8 := /BOFF
                                                ; if BOFF is activated,
   + BOFF
                                    -> S0
                                                ; guit the access and return
                                    -> S10
                                                : to state S0. The 486 will
S9 := /BOFF
                                    -> S0
   + BOFF
                                                ; re-initiate the access.
                                    -> S11
S10 := /BOFF
   + BOFF
                                    -> S0
                                    -> $6
S11 := VCC
                                    -> S13
S12 := /BOFF
                                                ; write cycle
                                    -> S0
   + BOFF
S13 := /BOFF
                                    -> S14
                                    -> S0
   + BOFF
S14 := /BOFF
                                    -> S15
                                    -> S0
   + BOFF
S15 := VCC
                                    -> S0
                                                                                    297504-10
```



```
EQUATIONS
CONT1 := (/ADS * /CE * A3) + (CONT1 * S1)
        + (/CONT1 * S2) + (CONT1 * S3)
        + (CONT1 * S12) + (CONT1 * S13) + (CONT1 * S14)
CONTO := (/ADS * /CE * A2) + (/CONTO * S1)
        + (/CONT0 * S2) + (/CONT0 * S3)
        + (CONTO * S12) + (CONTO * S13) + (CONTO * S14)
CONTO.CLKF
                 = CLK
CONT1.CLKF
                 = CLK
                 = CLK
ADV.CLKF
OE.CLKF
                 = CLK
WE.CLKF
                 = CLK
                 = CLK
BRDY.CLKF
RDY.CLKF
                 = CLK
KEN.CLKF
                 = CLK
                 = CLK
Q0.CLKF
Q1.CLKF
                 = CLK
GLOBAL.RSTF
                 = RESET
                                                                        297504-11
```



## DD28F032SA 32-MBIT (2 MBIT X 16, 4 MBIT X 8) FlashFile™ MEMORY

- User-Selectable 3.3V or 5V V<sub>CC</sub>
- User-Configurable x8 or x16 Operation
- 70 ns Maximum Access Time
- 0.43 MB/sec Write Transfer Rate
- 1 Million Typical Erase Cycles per Block
- 56-Lead, 1.2 x 14 x 20mm Advanced Dual Die TSOP Package Technology
- 64 Independently Lockable Blocks

- Revolutionary Architecture
  - 100% Backwards-Compatible with Intel 28F016SA
  - Pipelined Command Execution
  - Write during Erase
- 2 mA Typical I<sub>CC</sub> in Static Mode
- 2 µA Typical Deep Power-Down
- State-of-the-Art 0.6 μm ETOX™ IV Flash Technology

Intel's DD28F032SA 32-Mbit FlashFile<sup>TM</sup> memory is a revolutionary architecture which enables the design of truly mobile, high performance, personal computing and communication products. With innovative capabilities, low power operation and very high read/write performance, the DD28F032SA is also the ideal choice for designing embedded mass storage flash memory systems.

The DD28F032SA is the result of highly advanced packaging innovation which encapsulates two 28F016SA die in a single Dual Die Thin Small Outline Package (DDTSOP).

The DD28F032SA is the highest density, highest performance nonvolatile read/write solution for solid-state storage applications. Its symmetrically blocked architecture (100% compatible with the 28F016SA 16-Mbit FlashFile memory), very high cycling, low power 3.3V operation, very fast write and read performance and selective block locking provide a highly flexible memory component suitable for high density memory cards, Resident Flash Arrays and PCMCIA-ATA Flash Drives. The DD28F032SA's dual read voltage enables the design of memory cards which can interchangeably be read/written in 3.3V and 5.0V systems. Its x8/x16 architecture allows the optimization of memory to processor interface. The flexible block locking option enables bundling of executable application software in a Resident Flash Array or memory card. The DD28F032SA will be manufactured on Intel's 0.6 µm ETOX IV technology.



290490-2

| <b>CONTENTS</b> PAGE                                                                                                                                   | <b>CONTENTS</b> PAGE                                                                                                                           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0 PRODUCT OVERVIEW 3-259                                                                                                                             | 6.0 ELECTRICAL SPECIFICATIONS 3-273                                                                                                            |
| 2.0 DEVICE PINOUT       3-260         2.1 Lead Descriptions       3-262         3.0 MODES OF OPERATION       3-264         4.0 MEMORY MAPS       3-265 | 6.1 Absolute Maximum Ratings* 3-273 6.2 Capacitance 3-274 6.3 Timing Nomenclature 3-275 6.4 DC Characteristics (V <sub>CC</sub> = 3.3V) 3-278  |
| 4.1 Extended Status Registers Memory Map for Either Upper or Lower 28F016SA                                                                            | 6.5 DC Characteristics (V <sub>CC</sub> = 5.0V)                                                                                                |
| 5.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS                                                                                           | 6.7 Power-Up and Reset Timings 3-286 6.8 AC Characteristics for WE#— Controlled Command Write Operations                                       |
| Mode (BYTE# = V <sub>IH</sub> )                                                                                                                        | 6.9 AC Characteristics for CE <sub>X</sub> #— Controlled Write Operations 3-290 6.10 AC Characteristics for Page Buffer Write Operations 3-293 |
| Command Bus Definitions 3-268 5.4 28F016SA-Performance Enhancement Command Bus Definitions                                                             | 6.11 Erase and Word/Byte Write Performance, Cycling Performance and Suspend Latency                                                            |
| 5.5 Compatible Status Register 3-270 5.6 Global Status Register 3-271 5.7 Plack Status Register 3.270                                                  | <b>7.0 DERATING CURVES</b>                                                                                                                     |
| 5.7 Block Status Register 3-272                                                                                                                        | DEVICE NOMENCLATURE/ORDERING INFORMATION                                                                                                       |
|                                                                                                                                                        | ADDITIONAL INFORMATION 3-301                                                                                                                   |
|                                                                                                                                                        | DATA CHEET DEVICION HICTORY                                                                                                                    |



#### 1.0 PRODUCT OVERVIEW

The DD28F032SA is a high-performance 32-Mbit (33,554,432-bit) block erasable nonvolatile random access memory organized as either 2 Mword x 16, or 4 Mbyte x 8. The DD28F032SA is built using two 28F016SA chips encapsulated in a single 56L-TSOP Type I package. The DD28F032SA includes sixty-four 64-KB (65,536) blocks or sixty-four 32-KW (32,768) blocks.

The DD28F032SA architecture allows operations to be performed on a single, 16-Mbit chip at a time.

The implementation of a new architecture, with many enhanced features, will improve the device operating characteristics and results in greater product reliability and ease of use.

Among the significant enhancements on the DD28F032SA:

- 3.3V Low Power Capability
- Improved Write Performance
- Dedicated Block Write/Erase Protection

A 3/5# input pin reconfigures the device internally for optimized 3.3V or 5.0V Read/Write operation.

The DD28F032SA will be available in a 56-lead, 1.2mm thick, 14mm x 20mm Dual Die TSOP Type I package. This form factor and pinout allow for very high board layout densities. The DD28F032SA is pinout and footprint compatible with the 28F016SA.

Two Command User Interfaces (CUI) serve as the system interface between the microprocessor or microcontroller and the internal memory operation.

Internal Algorithm Automation allows Word/Byte Writes and Block Erase operations to be executed using a Two-Write command sequence to the CUI in the same way as the 28F016SA 16-Mbit FlashFile memory.

A super-set of commands has been added to the basic 28F008SA (8-Mbit FlashFile memory) command-set to achieve higher write performance and provide additional capabilities. These new commands and features include:

- Page Buffer Writes to Flash
- Command Queueing Capability
- Automatic Data Writes during Erase

- · Software Locking of Memory Blocks
- Two-Byte Successive Writes in 8-bit Systems
- Erase All Unlocked Blocks

Note that these operations can only be performed on one 16-Mbit device at a time. If the WSM is busy performing an operation, the system should not attempt to select the other device.

Writing of memory data is performed in either byte or word increments typically within 6  $\mu$ s, a 33% improvement over the 28F008SA. A Block Erase operation erases one of the 64 blocks in typically 0.6 sec, independent of the other blocks, which is about a 65% improvement over the 28F008SA.

Each block can be written and erased a minimum of 100,000 cycles. Systems can achieve typically 1 million Block Erase Cycles by providing graceful block retirement. This technique is already employed in hard disk drive designs. Additionally, wear leveling of block erase cycles can be used to minimize the write/erase performance differences across blocks.

The DD28F032SA incorporates two Page Buffers of 256 Bytes (128 Words) on each 28F016SA to allow page data writes. This feature can improve a system write performance by up to 4.8 times over previous flash memory devices.

All operations are started by a sequence of Write commands to the device. Three Status Registers (described in detail later) and a RY/BY# output pin provide information on the progress of the requested operation.

The DD28F032SA allows queueing of the next operation while the memory executes the current operation. This eliminates system overhead when writing several bytes in a row to the array or erasing several blocks at the same time. The DD28F032SA can also perform Write operations to one block of memory while performing Erase of another block. However, simultaneous Write and/or Erase operations are not allowed on both 28F016SA devices. See Modes of Operation, Section 3.0.

The DD28F032SA provides user-selectable block locking to protect code or data such as Device Drivers, PCMCIA card information, ROM-Executable O/S or Application Code. Each block has an associated nonvolatile lock-bit which determines the lock status of the block. In addition, the DD28F032SA has a master Write Protect pin (WP#) which prevents any modifications to memory blocks whose lock-bits are set.



The DD28F032SA contains three types of Status Registers to accomplish various functions:

- A Compatible Status Register (CSR) which is 100% compatible with the 28F008SA FlashFile memory's Status Register. This register, when used alone, provides a straightforward upgrade capability to the DD28F032SA from a 28F008SAbased design.
- A Global Status Register (GSR) which informs the system of command Queue status, Page Buffer status, and overall Write State Machine (WSM) status.
- 64 Block Status Registers (BSRs) which provide block-specific status information such as the block lock-bit status.

The GSR and BSR memory maps for Byte-Wide and Word-Wide modes are shown in Figures 4 and 5.

The DD28F032SA incorporates an open drain RY/BY# output pin. This feature allows the user to ORtie many RY/BY# pins together in a multiple memory configuration such as a Resident Flash Array. Other configurations of the RY/BY# pin are enabled via special CUI commands and are described in detail in the 28F016SA User's Manual.

The DD28F032SA also incorporates three chip-enable input pins,  $CE_0\#$ ,  $CE_1\#$  and  $CE_2\#$ . The active low combination of  $CE_0\#$  and  $CE_1\#$  controls the upper 28F016SA. The active low combination of  $CE_0\#$  and  $CE_2\#$  controls the lower 28F016SA.

The BYTE# pin allows either x8 or x16 read/writes to the DD28F032SA. BYTE# at logic low selects 8-bit mode with address  $A_0$  selecting between low byte and high byte. On the other hand, BYTE# at logic high enables 16-bit operation with address  $A_1$  becoming the lowest order address and address  $A_0$  is not used (don't care). A device block diagram is shown in Figure 1.

The DD28F032SA incorporates an Automatic Power Saving (APS) feature which substantially reduces the active current when the device is in static mode of operation (addresses not switching).

A deep power-down mode of operation is invoked when the RP# (called PWD on the 28F008SA) pin is driven low. This mode provides additional write protection by acting as a device reset pin during power transitions. n the Deep Power-Down state, the WSM is reset (any current operation will abort) and the CSR, GSR and BSR registers are cleared.

A CMOS standby mode of operation is enabled when either  $CE_0\#$ , or both  $CE_1\#$  and  $CE_2\#$ , transition high and RP# stays high with all input control pins at CMOS levels.

#### 2.0 DEVICE PINOUT

The DD28F032SA Standard 56L-Dual Die TSOP Type I pinout configuration is shown in Figure 2.





Figure 1. Block Diagram of 16-Mbit Devices
Architectural Evolution Includes Page Buffers, Queue Registers and Extended Registers



## 2.1. Lead Descriptions

| Symbol                                                                       | Туре         | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub>                                                               | INPUT        | <b>BYTE-SELECT ADDRESS:</b> Selects between high and low byte when device is in x8 mode. This address is latched in x8 Data Writes. Not used in x16 mode (i.e., the A <sub>0</sub> input buffer is turned off when BYTE# is high).                                                                                                                                                                                                                                                                                                                           |
| A <sub>1</sub> -A <sub>15</sub>                                              | INPUT        | <b>WORD-SELECT ADDRESSES:</b> Select a word within one 64-Kbyte block. $A_{6-15}$ selects 1 of 1024 rows, and $A_{1-5}$ selects 16 of 512 columns. These addresses are latched during Data Writes.                                                                                                                                                                                                                                                                                                                                                           |
| A <sub>16</sub> -A <sub>20</sub>                                             | INPUT        | <b>BLOCK-SELECT ADDRESSES:</b> Select 1 of 32 Erase blocks. These addresses are latched during Data Writes, Erase and Lock-Block operations.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| DQ <sub>0</sub> –DQ <sub>7</sub>                                             | INPUT/OUTPUT | LOW-BYTE DATA BUS: Inputs data and commands during CUI write cycles. Outputs array, buffer, identifier or status data in the appropriate read mode. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                                                                                                                                                                                                                        |
| DQ <sub>8</sub> -DQ <sub>15</sub>                                            | INPUT/OUTPUT | HIGH-BYTE DATA BUS: Inputs data during x16 Data-Write operations. Outputs array, buffer or identifier data in the appropriate read mode; not used for Status register reads. Floated when the chip is deselected or the outputs are disabled.                                                                                                                                                                                                                                                                                                                |
| CE <sub>0</sub> # CE <sub>X</sub> # = CE <sub>1</sub> # or CE <sub>2</sub> # | INPUT        | CHIP ENABLE INPUTS: Activate the device's control logic, input buffers, decoders and sense amplifiers. CE <sub>0</sub> # or CE <sub>1</sub> # enable/disable the first 28F016SA (16 Mbit No. 1) while CE <sub>0</sub> #, CE <sub>2</sub> # enable/disable the second 28F016SA (16 Mbit No. 2). CE <sub>0</sub> # active low enables chip operation while CE <sub>1</sub> # or CE <sub>2</sub> # select between the first and second device, respectively. CE <sub>1</sub> # or CE <sub>2</sub> # must not be active low simultaneously. Reference Table 3.0. |
| RP#                                                                          | INPUT        | RESET/POWER-DOWN: RP# low places the device in a Deep Power-Down state. All circuits that burn static power, even those circuits enabled in standby mode, are turned off. When returning from Deep Power-Down, a recovery time of 400 ns is required to allow these circuits to power-up. When RP# goes low, any current or pending WSM operation(s) are terminated, and the device is reset. All Status registers return to ready (with all status flags cleared).                                                                                          |
| OE#                                                                          | INPUT        | OUTPUT ENABLE: Gates device data through the output buffers when low. The outputs float to tri-state off when OE# is high.  NOTE:  CE <sub>x</sub> # overrides OE#, and OE# overrides WE#.                                                                                                                                                                                                                                                                                                                                                                   |
| WE#                                                                          | INPUT        | WRITE ENABLE: Controls access to the CUI, Page Buffers, Data Queue Registers and Address Queue Latches. WE# is active low, and latches both address and data (command or array) on its rising edge.                                                                                                                                                                                                                                                                                                                                                          |



## 2.1. Lead Descriptions (Continued)

| Symbol          | Туре              | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RY/BY#          | OPEN DRAIN OUTPUT | <b>READY/BUSY:</b> Indicates status of the internal WSM. When low, it indicates that the WSM is busy performing an operation. RY/BY# high indicates that the WSM is ready for new operations (or WSM has completed all pending operations), or Erase is Suspended, or the device is in deep power-down mode. This output is always active (i.e., not floated to tri-state off when OE# or CE <sub>0</sub> #, CE <sub>1</sub> # are high), except if a RY/BY# Pin Disable command is issued. |
| WP#             | INPUT             | WRITE PROTECT: Erase blocks can be locked by writing a nonvolatile lock-bit for each block. When WP# is low, those locked blocks as reflected by the Block-Lock Status bits (BSR.6), are protected from inadvertent Data Writes or Erases. When WP# is high, all blocks can be written or erased regardless of the state of the lock-bits. The WP# input buffer is disabled when RP# transitions low (deep power-down mode).                                                                |
| BYTE#           | INPUT             | <b>BYTE ENABLE:</b> BYTE# low places device in x8 mode. All data is then input or output on $DQ_{0-7}$ , and $DQ_{8-15}$ float. Address $A_0$ selects between the high and low byte. BYTE# high places the device in x16 mode, and turns off the $A_0$ input buffer. Address $A_1$ , then becomes the lowest order address.                                                                                                                                                                 |
| 3/5#            | INPUT             | 3.3/5.0 VOLT SELECT: 3/5 # high configures internal circuits for 3.3V operation. 3/5 # low configures internal circuits for 5.0V operation.  NOTES:  Reading the array with 3/5 # high in a 5.0V system could damage the device.  There is a significant delay from 3/5 # switching to valid data.                                                                                                                                                                                          |
| V <sub>PP</sub> | SUPPLY            | ERASE/WRITE POWER SUPPLY: For erasing memory array blocks or writing words/bytes/pages into the flash array.                                                                                                                                                                                                                                                                                                                                                                                |
| V <sub>CC</sub> | SUPPLY            | <b>DEVICE POWER SUPPLY (3.3V <math>\pm</math> 0.3V, 5.0V <math>\pm</math> 0.5V):</b> Do not leave any power pins floating.                                                                                                                                                                                                                                                                                                                                                                  |
| GND             | SUPPLY            | <b>GROUND FOR ALL INTERNAL CIRCUITRY:</b> Do not leave any ground pins floating.                                                                                                                                                                                                                                                                                                                                                                                                            |
| NC              |                   | <b>NO CONNECT:</b> No internal connection to die, lead may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                      |





Figure 2. Dual Die TSOP Pinout Configuration

#### 3.0 MODES OF OPERATION

| RP# | CE <sub>0</sub> # | CE <sub>1</sub> # | CE <sub>2</sub> # | 28F016SA No. 1    | 28F016SA No. 2 | DD28F032SA Chip |  |  |  |
|-----|-------------------|-------------------|-------------------|-------------------|----------------|-----------------|--|--|--|
| 0   | Х                 | . X               | Х                 | DPD               | DPD DPD        |                 |  |  |  |
| 1   | 1                 | Х                 | Х                 | Standby           | Standby        | Standby         |  |  |  |
| 1   | 0                 | 0                 | 1                 | Active            | Standby        | Active          |  |  |  |
| 1   | 0                 | 1                 | 0                 | Standby           | Active         | Active          |  |  |  |
| 1   | 0                 | 1                 | 1                 | Standby Standby   |                | Standby         |  |  |  |
| 1   | 0                 | 0 + ,-            | 0                 | Illegal Condition |                |                 |  |  |  |

#### NOTES:

X = Don't Care

DPD = Deep Power-Down

28F016SA No. 1 = First 16 Mbit device

28F016SA No. 2 = Second 16 Mbit device



## 4.0 MEMORY MAPS

| * |                            | <u> </u>          |               |                            |                |    |           |  |
|---|----------------------------|-------------------|---------------|----------------------------|----------------|----|-----------|--|
|   | 1FFFFF<br>1F0000           | 64 KByte Block 31 |               | 1FFFFF<br>1F0000           | 64 KByte Block | 63 |           |  |
|   | 1EFFFF<br>1E0000           | 64 KByte Block 30 |               | 1EFFFF<br>1E0000           | 64 KByte Block | 62 |           |  |
|   | 1DFFFF<br>1D0000           | 64 KByte Block 29 |               | 1DFFFF<br>1D0000           | 64 KByte Block | 61 |           |  |
|   | 1CFFFF<br>1C0000           | 64 KByte Block 28 |               | 1CFFFF<br>1C0000           | 64 KByte Block | 60 |           |  |
|   | 1BFFFF<br>1B0000           | 64 KByte Block 27 |               | 18FFFF<br>180000           | 64 KByte Block | 59 |           |  |
|   | 1AFFFF<br>1A0000           | 64 KByte Block 26 |               | 1AFFFF<br>1A0000           | 64 KByte Block | 58 |           |  |
|   | 19FFFF<br>190000           | 64 KByte Block 25 |               | 19FFFF<br>190000           | 64 KByte Block | 57 |           |  |
|   | 18FFFF<br>180000           | 64 KByte Block 24 |               | 18FFFF<br>180000           | 64 KByte Block | 56 |           |  |
|   | 17FFFF<br>170000           | 64 KByte Block 23 |               | 17FFFF<br>170000           | 64 KByte Block | 55 |           |  |
|   | 16FFFF<br>160000           | 64 KByte Block 22 |               | 16FFFF<br>160000           | 64 KByte Block | 54 |           |  |
|   | 15FFFF<br>150000           | 64 KByte Block 21 |               | 15FFFF<br>150000           | 64 KByte Block | 53 |           |  |
|   | 14FFFF<br>140000           | 64 KByte Block 20 |               | 14FFFF<br>140000           | 64 KByte Block | 52 |           |  |
|   | 13FFFF<br>130000           | 64 KByte Block 19 |               | 13FFFF                     | 64 KByte Block | 51 |           |  |
|   | 12FFFF<br>120000           | 64 KByte Block 18 |               | 130000<br>12FFFF           | 64 KByte Block | 50 |           |  |
|   | 11FFFF<br>110000           | 64 KByte Block 17 |               | 120000<br>11FFFF<br>110000 | 64 KByte Block | 49 |           |  |
|   | 10FFFF<br>100000           | 64 KByte Block 16 |               | 10FFFF<br>100000           | 64 KByte Block | 48 |           |  |
|   | OFFFFF<br>OFGGGG           | 64 KByte Block 15 |               | 0FFFFF<br>0F0000           | 64 KByte Block | 47 |           |  |
|   | OEFFFF<br>OEOOOO           | 64 KByte Block 14 |               | OEFFFF                     | 64 KByte Block | 46 |           |  |
|   | ODFFFF<br>ODOOOO           | 64 KByte Block 13 |               | OEOOOO ODFFFF              | 64 KByte Block | 45 |           |  |
|   | OCFFFF<br>OCOGGO           | 64 KByte Block 12 |               | ODOOOO OCFFFF              | 64 KByte Block | 44 |           |  |
|   | OBFFFF                     | 64 KByte Block 11 |               | OCOOOO<br>OBFFFF           | 64 KByte Block | 43 |           |  |
|   | OBOOOO<br>OAFFFF<br>OAOOOO | 64 KByte Block 10 |               | OBOODO<br>OAFFFF<br>OAOOOO | 64 KByte Block | 42 |           |  |
|   | 09FFFF<br>090000           | 64 KByte Block 9  |               | 09FFFF<br>090000           | 64 KByte Block | 41 |           |  |
|   | 08FFFF<br>080000           | 64 KByte Block 8  |               | 08FFFF<br>080000           | 64 KByte Block | 40 |           |  |
|   | 07FFFF<br>070000           | 64 KByte Block 7  |               | 07FFFF<br>070000           | 64 KByte Block | 39 |           |  |
|   | 06FFFF<br>060000           | 64 KByte Block 6  |               | 06FFFF<br>060000           | 64 KByte Block | 38 |           |  |
|   | 05FFFF<br>050000           | 64 KByte Block 5  |               | 05FFFF<br>050000           | 64 KByte Block | 37 |           |  |
|   | 04FFFF<br>040000           | 64 KByte Block 4  |               | 04FFFF<br>040000           | 64 KByte Block | 36 |           |  |
|   | 03FFFF<br>030000           | 64 KByte Block 3  |               | 03FFFF<br>030000           | 64 KByte Block | 35 |           |  |
| V | 02FFFF<br>020000           | 64 KByte Block 2  |               | 02FFFF                     | 64 KByte Block | 34 |           |  |
|   | 01FFFF<br>010000           | 64 KByte Block 1  |               | 020000<br>01FFFF<br>010000 | 64 KByte Block | 33 |           |  |
|   | 00FFFF<br>000000           | 64 KByte Block 0  |               | OOFFFF                     | 64 KByte Block | 32 |           |  |
|   | 330000                     |                   | I<br>290490-4 | 000000                     | <u></u>        |    | 290490-5  |  |
| * |                            | 28F016SA No. 1    |               |                            | 28F016SA No.   | 2  | _30 .00 0 |  |
|   |                            |                   |               |                            |                |    |           |  |

Figure 3. DD28F032SA Memory Map (Byte-Wide Mode)



## 4.1 Extended Status Registers Memory Map for Either 28F016SA No. 1 or 28F016SA No. 2



Figure 4. Extended Status Register Memory Map (Byte-Wide Mode)



Figure 5. Extended Status Register Memory Map (Word-Wide Mode)



### 5.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS

## 5.1 Bus Operations for Word-Wide Mode (BYTE $\# = V_{IH}$ )

| Mode            | Notes | RP#             | CE <sub>X</sub> #(8)                                  | CE <sub>0</sub> #                                     | OE#             | WE#             | A <sub>1</sub>  | DQ <sub>0-15</sub> | RY/BY#          |
|-----------------|-------|-----------------|-------------------------------------------------------|-------------------------------------------------------|-----------------|-----------------|-----------------|--------------------|-----------------|
| Read            | 1,2,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | Х               | D <sub>OUT</sub>   | Х               |
| Output Disable  | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | High Z             | X               |
| Standby         | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IH</sub> | Х               | Х               | Х               | High Z             | Х               |
| Deep Power-Down | 1,3   | V <sub>IL</sub> | Х                                                     | Х                                                     | Х               | Х               | Х               | High Z             | V <sub>OH</sub> |
| Manufacturer ID | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 0089H              | V <sub>OH</sub> |
| Device ID       | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | 66A0H              | V <sub>OH</sub> |
| Write           | 1,5,6 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IL</sub> | Х               | D <sub>IN</sub>    | Х               |

5.2 Bus Operations for Byte-Wide Mode (BYTE  $\# = V_{II}$ )

| Mode .          | Notes  | RP#             | CE <sub>X</sub> #(8)                                                  | CE <sub>0</sub> #                  | OE#             | WE#             | Ao              | DQ <sub>0-7</sub> | RY/BY#          |
|-----------------|--------|-----------------|-----------------------------------------------------------------------|------------------------------------|-----------------|-----------------|-----------------|-------------------|-----------------|
| - Inouc         | 110103 | 111 "           |                                                                       |                                    |                 |                 | 1 ~0            | DG0-7             | 111701 "        |
| Read            | 1,2,7  | V <sub>IH</sub> | V <sub>IL</sub>                                                       | V <sub>IL</sub>                    | V <sub>IL</sub> | $V_{IH}$        | Х               | D <sub>OUT</sub>  | Х               |
| Output Disable  | 1,6,7  | V <sub>IH</sub> | V <sub>IL</sub>                                                       | V <sub>IL</sub>                    | V <sub>IH</sub> | V <sub>IH</sub> | Х               | High Z            | Х               |
| Standby         | 1,6,7  | V <sub>IH</sub> | V <sub>IL</sub> V <sub>IH</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub> | Х               | Х               | Х               | High Z            | . <b>X</b>      |
| Deep Power-Down | 1,3    | V <sub>IL</sub> | Х                                                                     | Х                                  | х               | Х               | X               | High Z            | V <sub>OH</sub> |
| Manufacturer ID | 4      | V <sub>IH</sub> | V <sub>IL</sub>                                                       | V <sub>IL</sub>                    | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 89H               | V <sub>OH</sub> |
| Device ID       | 4      | V <sub>IH</sub> | V <sub>IL</sub>                                                       | VIL                                | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | A0H               | V <sub>OH</sub> |
| Write           | 1,5,6  | V <sub>IH</sub> | V <sub>IL</sub>                                                       | V <sub>IL</sub>                    | V <sub>IH</sub> | VIL             | Х               | D <sub>IN</sub>   | Х               |

#### NOTES:

- 1. X can be VIH or VIL for address or control pins except for RY/BY#, which is either VOL or VOH.
- 2. RY/BY# output is open drain. When the WSM is ready, erase is suspended or the device is in deep power-down mode, RY/BY# will be at  $V_{OH}$  if it is tied to  $V_{CC}$  through a resistor. RY/BY# at  $V_{OH}$  is independent of OE# while a WSM operation is in progress.
- 3. RP# at GND  $\pm$  0.2V ensures the lowest deep power-down current.
- 4. A<sub>0</sub> and A<sub>1</sub> at V<sub>IL</sub> provide device manufacturer codes in x8 and x16 modes respectively. A<sub>0</sub> and A<sub>1</sub> at V<sub>IH</sub> provide device ID codes in x8 and x16 modes respectively. All other addresses are set to zero.
- 5. Commands for different Erase operations Data Write operations or Lock-Block operations can only be successfully completed when V<sub>PP</sub> = V<sub>PPH</sub>.
- 6. While the WSM is running, RY/BY# in level-mode (default) stays at V<sub>OL</sub> until all operations are complete. RY/BY# goes to V<sub>OH</sub> when the WSM is not busy or in erase suspend mode.
- 7. RY/BY# may be at V<sub>OL</sub> while the WSM is busy performing various operations. For example, a status register read during a Write operation.
- 8.  $CE_X\# = CE_1\# \text{ or } CE_2\#.$



### 5.3 28F008SA Compatible Mode Command Bus Definitions

| Command                         | Notes | Fire  | st Bus Cy | cle  | Sec   | ond Bus ( | Cycle |
|---------------------------------|-------|-------|-----------|------|-------|-----------|-------|
| Command                         | Notes | Oper  | Addr      | Data | Oper  | Addr      | Data  |
| Read Array                      |       | Write | Х         | FFH  | Read  | AA        | AD    |
| Intelligent Identifier          | 1     | Write | Х         | 90H  | Read  | IA        | ID    |
| Read Compatible Status Register | 2     | Write | Х         | 70H  | Read  | Х         | CSRD  |
| Clear Status Register           | 3     | Write | . X       | 50H  |       |           |       |
| Word/Byte Write                 |       | Write | Х         | 40H  | Write | WA        | WD    |
| Alternate Word/Byte Write       |       | Write | X         | 10H  | Write | WA        | WD    |
| Block Erase/Confirm             |       | Write | X         | 20H  | Write | ВА        | DOH   |
| Erase Suspend/Resume            | -     | Write | Х         | вон  | Write | Х         | D0H   |

#### **ADDRESS**

A = Array Address
BA = Block Address
IA = Identifier Address
WA = Write Address
X = Don't Care

#### **DATA**

AD = Array Data CSRD = CSR Data ID = Identifier Data WD = Write Data

#### NOTES:

- 1. Following the Intelligent Identifier command, two Read operations access the manufacturer and device signature codes.
- The CSR is automatically available after device enters Data Write, Erase, or Suspend operations.
   Clears CSR.3, CSR.4 and CSR.4. Also clears GSR.4 and all BSR.4 and BSR.2 bits.
- See Status Register definitions.



#### 5.4 28F016SA-Performance Enhancement Command Bus Definitions

| Command                               | Mode | Notes    | First | Bus C | ycle | Seco  | ond Bu         | s Cycle      | Thi   | rd Bus | Cycle   |
|---------------------------------------|------|----------|-------|-------|------|-------|----------------|--------------|-------|--------|---------|
| Command                               | Mode | Notes    | Oper  | Addr  | Data | Oper  | Addr           | Data         | Oper  | Addr   | Data    |
| Read Extended Status<br>Register      |      | 1        | Write | Х     | 71H  | Read  | RA             | GSRD<br>BSRD |       |        |         |
| Page Buffer Swap                      |      | 7        | Write | Х     | 72H  |       |                |              |       |        |         |
| Read Page Buffer                      |      |          | Write | Х     | 75H  | Read  | PA             | PD           |       |        |         |
| Single Load to Page Buffer            |      |          | Write | Х     | 74H  | Write | PA             | PD           |       |        |         |
| Sequential Load to Page               | x8   | 4,6,10   | Write | Х     | E0H  | Write | Х              | BCL          | Write | Х      | всн     |
| Buffer                                | x16  | 4,5,6,10 | Write | Х     | E0H  | Write | Х              | WCL          | Write | Х      | WCH     |
| Page Buffer Write to Flash            | х8   | 3,4,9,10 | Write | Х     | 0CH  | Write | A <sub>0</sub> | BC(L,H)      | Write | WA     | BC(H,L) |
| ,                                     | x16  | 4,5,10   | Write | Х     | 0CH  | Write | Х              | WCL          | Write | WA     | WCH     |
| Two-Byte Write                        | х8   | 3        | Write | Х     | FBH  | Write | A <sub>0</sub> | WD(L,H)      | Write | WA     | WD(H,L) |
| Lock Block/Confirm                    |      |          | Write | Х     | 77H  | Write | ВА             | D0H          |       |        |         |
| Upload Status Bits/Confirm            |      | 2        | Write | Х     | 97H  | Write | Х              | D0H          |       |        |         |
| Upload Device Information             |      | ,        | Write | Х     | 99H  | Write | Х              | D0H          |       |        |         |
| Erase All Unlocked Blocks/<br>Confirm |      |          | Write | Х     | A7H  | Write | Х              | D0H          |       |        |         |
| RY/BY# Enable to Level-<br>Mode       |      | 8        | Write | Х     | 96H  | Write | Х              | 01H          |       |        |         |
| RY/BY# Pulse-On-Write                 |      | 8        | Write | Х     | 96H  | Write | Х              | 02H          |       |        |         |
| RY/BY# Pulse-On-Erase                 |      | 8        | Write | Х     | 96H  | Write | Х              | 03H          |       |        |         |
| RY/BY# Disable                        |      | 8        | Write | Х     | 96H  | Write | Х              | 04H          |       |        |         |
| Sleep                                 |      |          | Write | Х     | F0H  |       |                |              |       |        |         |
| Abort                                 |      |          | Write | Х     | 80H  |       |                |              |       |        |         |

#### **ADDRESS**

BA = Block Address

PA = Page Buffer Address

RA = Extended Register Address

WA = Write Address

X = Don't Care

AD = Array Data

PD = Page Buffer Data

BSRD = BSR Data

GSRD = GSR Data

**DATA** 

WC (L,H) = Word Count (Low, High)

BC(L,H) = Byte Count(Low, High)

WD (L,H) = Write Data (Low, High)



#### NOTES:

- 1. RA can be the GSR address or any BSR address. See Figures 4 and 5 for Extended Status Register Memory Maps.
- 2. Upon device power-up, all BSR lock-bits come up locked. The Upload Status Bits command must be written to reflect the actual lock-bit status.
- 3. A<sub>0</sub> is automatically complemented to load second byte of data. BYTE# must be at V<sub>IL</sub>.
- $A_0$  value determines which WD/BC is supplied first:  $A_0 = 0$  looks at the WDL/BCL,  $A_0 = 1$  looks at the WDH/BCH.
- 4. BCH/WCH must be at 00H for this product because of the 256-byte (128-word) Page Buffer size and to avoid writing the Page Buffer contents to more than one 256-byte segment within an array block. They are simply shown for future Page Buffer expandability.
- 5. In x16 mode, only the lower byte DQ<sub>0.7</sub> is used for WCL and WCH. The upper byte DQ<sub>8.15</sub> is a don't care.
- 6. PA and PD (whose count is given in cycles 2 and 3) are supplied starting in the fourth cycle, which is not shown.
- 7. This command allows the user to swap between available Page Buffers (0 or 1).
- 8. These commands reconfigure RY/BY# output to one of two pulse-modes or enable and disable the RY/BY# function.
- 9. Write address, WA, is the Destination address in the flash array which must match the Source address in the Page Buffer. Refer to the 28F016SA User's Manual.
- 10. BCL = 00H corresponds to a byte count of 1. Similarly, WCL = 00H corresponds to a word count of 1.

#### 5.5 Compatible Status Register

| WSMS | ESS | ES | DWS | VPPS | R   | R | R |
|------|-----|----|-----|------|-----|---|---|
| 7    | . 6 | 5  | 4 . | 3    | 2 . | 1 | 0 |

#### NOTES:

#### CSR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

RY/BY# output or WSMS bit must be checked to determine completion of an operation (Erase Suspend, Erase or Data Write) before the appropriate Status bit (ESS, ES or DWS) is checked for success.

#### CSR.6 = ERASE-SUSPEND STATUS

1 = Erase Suspended

0 = Erase In Progress/Completed

#### CSR.5 = ERASE STATUS

1 = Error In Block Erasure

0 = Successful Block Erase

If DWS and ES are set to "1" during an erase attempt, an improper command sequence was entered. Clear the CSR and attempt the operation again.

#### CSR.4 = DATA-WRITE STATUS

1 = Error in Data Write

0 = Data Write Successful

#### $CSR.3 = V_{PP} STATUS$

1 = V<sub>PP</sub> Low Detect, Operation Abort

 $0 = V_{PP} OK$ 

The VPPS bit, unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM interrogates V<sub>PP</sub>'s level only after the Data-Write or Erase command sequences have been entered, and informs the system if V<sub>PP</sub> has not been switched on. VPPS is not guaranteed to report accurate feedback between V<sub>PPL</sub> and V<sub>PPH</sub>.

#### CSR.2-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the CSR.



#### 5.6 Global Status Register

| WSMS | oss | DOS | DSS | QS | PBAS | PBS | PBSS |
|------|-----|-----|-----|----|------|-----|------|
| 7    | 6   | 5   | 4   | 3  | 2    | 1   | 0    |

#### GSR.7 = WRITE STATE MACHINE STATUS

1 = Readv

0 = Busv

#### NOTES:

[1] RY/BY# output or WSMS bit must be checked to determine completion of an operation (Block Lock, Suspend, any RY/BY# reconfiguration, Upload Status Bits, Erase or Data Write) before the appropriate Status bit (OSS or DOS) is checked for success.

#### GSR.6 = OPERATION SUSPEND STATUS

1 = Operation Suspended

0 = Operation in Progress/Completed

#### GSR.5 = DEVICE OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

#### GSR.4 = DEVICE SLEEP STATUS

1 = Device in Sleep

0 = Device Not in Sleep

#### MATRIX = 5/4

0 0 = Operation Successful or Currently Running

0 1 = Device in Sleep mode or Pending Sleep

10 = Operation Unsuccessful

1 1 = Operation Unsuccessful or Aborted

If operation currently running, then GSR.7 = 0.

If device pending sleep, then GSR.7 = 0. Operation aborted: Unsuccessful due to

Abort command.

#### GSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

#### GSR.2 = PAGE BUFFER AVAILABLE STATUS

1 = One or Two Page Buffers Available

0 = No Page Buffer Available

#### The device contains two Page Buffers.

## GSR.1 = PAGE BUFFER STATUS

1 = Selected Page Buffer Ready

0 = Selected Page Buffer Busy

Selected Page Buffer is currently busy with WSM operation

#### GSR.0 = PAGE BUFFER SELECT STATUS

1 = Page Buffer 1 Selected

0 = Page Buffer 0 Selected

#### NOTE:

1. When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7, or CSR.7, provides indication when all queued operations are completed.



5.7 Block Status Register

| BS | BLS | BOS | BOAS | QS | VPPS | R | R |
|----|-----|-----|------|----|------|---|---|
| 7  | 6   | 5   | 4    | 3  | 2    | 1 | 0 |

#### NOTES:

BSR.7 = BLOCK STATUS

1 = Ready

0 = Busy

[1] RY/BY# output or BS bit must be checked to determine completion of an operation (Block Lock, Suspend, Erase or Data Write) before the appropriate Status bits (BOS, BLS) is checked for

BSR.6 = BLOCK LOCK STATUS

1 = Block Unlocked for Write/Erase

0 = Block Locked for Write/Erase

BSR.5 = BLOCK OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

BSR.4 = BLOCK OPERATION ABORT STATUS

1 = Operation Aborted

0 = Operation Not Aborted

The BOAS bit will not be set until

BSR.7 = 1.

success.

MATRIX 5/4

0 0 = Operation Successful or Currently Running

0 1 = Not a Valid Combination

1 0 = Operation Unsuccessful

1 1 = Operation Aborted

Operation halted via Abort command.

BSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

BSR.2 = Vpp STATUS

1 = V<sub>PP</sub> Low Detect, Operation Abort

 $0 = V_{PP} OK$ 

BSR.1-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the BSRs.

#### NOTE:

1. When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7, or CSR.7, provides indication when all queued operations are completed.



#### 6.0 ELECTRICAL SPECIFICATIONS

### 6.1 Absolute Maximum Ratings\*

Temperature Under Bias .......0°C to +80°C Storage Temperature .....-65°C to +125°C

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### $V_{CC} = 3.3V \pm 0.3V \text{ Systems}^{(5)}$

| Symbol          | Parameter                                                                         | Notes | Min  | Max                   | Units | Test Conditions     |
|-----------------|-----------------------------------------------------------------------------------|-------|------|-----------------------|-------|---------------------|
| T <sub>A</sub>  | Operating Temperature,<br>Commercial                                              | 1     | 0    | 70                    | °C    | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                               | 2     | -0.2 | 7.0                   | ٧     |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with<br>Respect to GND                             | 2,3   | -0.2 | 14.0                  | ٧     |                     |
| Ÿ               | Voltage on any Pin (except V <sub>CC</sub> ,V <sub>PP</sub> ) with Respect to GND | 2     | -0.5 | V <sub>CC</sub> + 0.5 | ٧     |                     |
| 1               | Current into any Non-Supply Pin                                                   |       |      | ±30                   | mA    |                     |
| lout            | Output Short Circuit Current                                                      | 4     |      | 100                   | mA    |                     |

#### $V_{CC} = 5.0V \pm 0.5V, V_{CC} = 5.0V \pm 0.25V \text{ Systems}^{(5,6)}$

| Symbol          | Parameter                                                                         | Notes | Min  | Max                   | Units    | Test Conditions     |
|-----------------|-----------------------------------------------------------------------------------|-------|------|-----------------------|----------|---------------------|
| T <sub>A</sub>  | Operating Temperature,<br>Commercial                                              | 1     | 0    | 70                    | °C       | Ambient Temperature |
| Vcc             | V <sub>CC</sub> with Respect to GND                                               | 2     | -0.2 | 7.0                   | ٧        |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                                | 2,3   | -0.2 | 14.0                  | <b>V</b> |                     |
| V               | Voltage on any Pin (except V <sub>CC</sub> ,V <sub>PP</sub> ) with Respect to GND | 2     | -2.0 | V <sub>CC</sub> + 0.5 | ٧        |                     |
| Į.              | Current into any Non-Supply Pin                                                   |       |      | ±30                   | mA       |                     |
| lout            | Output Short Circuit Current                                                      | 4     |      | 100                   | mA       |                     |

#### NOTES:

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC}+0.5V$  which, during transitions, may overshoot to  $V_{CC}+2.0V$  for periods <20 ns.
- 3. Maximum DC voltage on V<sub>PP</sub> may overshoot to + 14.0V for periods <20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.
- 6. 5% V<sub>CC</sub> specifications refer to the 28F032SA-070 in its High Speed Test configuration.



## 6.2 Capacitance

### For a 3.3V System:

| Symbol            | Parameter                                                          | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|--------------------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                    | 1     | 12  | 16  | pF    | T <sub>A</sub> = 25°C, f = 1.0 MHz       |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin                          | 1     | 16  | 24  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing<br>Specifications | 1     |     | 50  | pF    | For $V_{CC} = 3.3V \pm 0.3V$             |
| ,                 | Equivalent Load Timing Circuit                                     |       |     | 2.5 | ns    | $50\Omega$ transmission line delay       |

## For a 5.0V System:

| Symbol            | Parameter                                             | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin       | 1     | 12  | 16  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin             | 1     | 16  | 24  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by                            | 1     |     | 100 | pF    | For $V_{CC} = 5.0V \pm 0.5V$             |
|                   | Outputs for Timing<br>Specifications                  |       |     | 30  | pF    | For $V_{CC} = 5.0V \pm 0.25V$            |
| ,                 | Equivalent Testing Load Circuit for $V_{CC} \pm 10\%$ |       |     | 2.5 | ns    | $25\Omega$ transmission line delay       |
|                   | Equivalent Testing Load Circuit for $V_{CC} \pm 5\%$  |       |     | 2.5 | ns    | $83\Omega$ transmission line delay       |

#### NOTE:

<sup>1.</sup> Sampled, not 100% tested.



### 6.3 Timing Nomenclature

All 3.3V system timings are measured from where signals cross 1.5V.

For 5.0V systems use the standard JEDEC cross point definitions.

Each timing parameter consists of 5 characters. Some common examples are defined below:

t<sub>CE</sub> t<sub>ELQV</sub> time(t) from CE<sub>X</sub># (E) going low (L) to the outputs (Q) becoming valid (V)

 $t_{OE}$   $t_{GLQV}$  time(t) from OE # (G) going low (L) to the outputs (Q) becoming valid (V)

t<sub>ACC</sub> t<sub>AVQV</sub> time(t) from address (A) valid (V) to the outputs (Q) becoming valid (V)

t<sub>AS</sub> t<sub>AVWH</sub> time(t) from address (A) valid (V) to WE# (W) going high (H)
t<sub>DH</sub> t<sub>WHDX</sub> time(t) from WE# (W) going high (H) to when the data (D) can become undefined (X)

|     | Pin Characters                  |   | Pin States                        |
|-----|---------------------------------|---|-----------------------------------|
| Α   | Address Inputs                  | Н | High                              |
| D   | Data Inputs                     | L | Low                               |
| Q   | Data Outputs                    | V | Valid                             |
| E   | CE <sub>X</sub> # (Chip Enable) | Х | Driven, but not necessarily valid |
| F   | BYTE# (Byte Enable)             | Z | High Impedance                    |
| G   | OE# (Output Enable)             |   |                                   |
| W   | WE# (Write Enable)              |   |                                   |
| Р   | RP# (Deep Power-Down Pin)       |   |                                   |
| R - | RY/BY# (Ready Busy)             |   |                                   |
| ٧   | Any Voltage Level               |   |                                   |
| Υ   | 3/5# Pin                        |   |                                   |
| 5V  | V <sub>CC</sub> at 4.5V Minimum |   |                                   |
| ЗV  | V <sub>CC</sub> at 3.0V Minimum |   |                                   |





Figure 6. Transient Input/Output Reference Waveform ( $V_{CC} = 5.0V \pm 10\%$ ) for Standard Test Configuration(1)



Figure 7. Transient Input/Output Reference Waveform ( $V_{CC} = 3.3V$ ) and High Speed Reference Waveform<sup>(2)</sup> ( $V_{CC} = 5.0V \pm 5\%$ )

#### NOTES:

- 1. Testing characteristics for DD28F032SA-080/DD28F032SA-100.
- 2. Testing characteristics for DD28F032SA-070/DD28F032SA-150.





Figure 8. Transient Equivalent Testing Load Circuit ( $V_{CC} = 5.0V \pm 10\%$ )



Figure 9. Transient Equivalent Testing Load Circuit (V $_{CC} = 3.3 \text{V} \pm 0.3 \text{V}$ )



Figure 10. High Speed Transient Equivalent Testing Load Circuit (V $_{CC}=\,$  5.0V  $\pm\,$  5%)



## **6.4 DC Characteristics**

 $V_{CC}=3.3V\pm0.3V,\,T_A=0^{\circ}C$  to  $+70^{\circ}C$  3/5# = Pin Set High for 3.3V Operations

| Symbol             | Parameter                                   | Notes       | Min | Тур | Max  | Units | Test Conditions                                                                                                                                                                                                                                                                                             |
|--------------------|---------------------------------------------|-------------|-----|-----|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| l₁∟                | Input Leakage Current                       | 1           |     |     | ± 2  | μΑ    | $V_{CC} = V_{CC} Max,$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                          |
| lLO                | Output Leakage Current                      | 1           | ,   |     | ± 20 | μΑ    | $V_{CC} = V_{CC} Max,$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                          |
| Iccs               | V <sub>CC</sub> Standby Current             | 1,5,6       |     | 100 | 200  | μΑ    | $\label{eq:VCC} \begin{split} &V_{CC} = V_{CC}  \text{Max,} \\ &CE_0\#, CE_X\#, \\ &RP\#, = V_{CC} \pm 0.2V \\ &BYTE\#, WP\#, 3/5\# = V_{CC} \\ &\pm 0.2V  \text{or GND} \pm 0.2V \end{split}$                                                                                                              |
|                    |                                             |             |     | 2   | 8    | mA    | $V_{CC} = V_{CC}$ Max,<br>$CE_0$ #, $CE_X$ #, $RP$ # = $V_{IH}$<br>BYTE#, $WP$ #,<br>$3/5$ # = $V_{IH}$ or $V_{IL}$                                                                                                                                                                                         |
| ICCD               | V <sub>CC</sub> Deep Power-<br>Down Current | 1           |     | 2   | 10   | μΑ    | $\begin{aligned} \text{RP\#} &= \text{GND} \pm 0.2\text{V} \\ \text{BYTE\#} &= \text{V}_{\text{CC}} \pm 0.2\text{V} \\ \text{or GND} &\pm 0.2\text{V} \end{aligned}$                                                                                                                                        |
| I <sub>CCR</sub> 1 | V <sub>CC</sub> Read Current                | 1,4,5,<br>6 |     | 25  | ·30  | mA    | $\begin{split} &V_{CC} = V_{CC}\text{Max}\\ &\text{CMOS: CE}_0\#,\\ &\text{CE}_X\# = \text{GND} \pm 0.2V\\ &\text{BYTE}\# = \text{GND} \pm 0.2V\\ &\text{or }V_{CC} \pm 0.2V\text{Inputs} = \text{GND}\\ &\pm 0.2V\text{or }V_{CC} \pm 0.2V\\ &\text{f} = 6.67\text{MHz}, I_{OUT} = 0\text{mA} \end{split}$ |
|                    |                                             |             |     | 26  | 34   | mA    | $\begin{split} & \text{TTL: CE}_0\#, \text{CE}_X\# = \text{V}_{\text{IL}}, \\ & \text{BYTE}\# = \text{V}_{\text{IL}} \text{or V}_{\text{IL}} \\ & \text{INPUTS} = \text{V}_{\text{IL}} \text{ or V}_{\text{IH}}, \\ & \text{f} = 6.67  \text{MHz}, \text{I}_{\text{OUT}} = 0  \text{mA} \end{split}$        |
| Iccw               | V <sub>CC</sub> Write Current               | 1,7         |     | 8   | 12   | mA    | Word/Byte Write in Progress                                                                                                                                                                                                                                                                                 |



#### 6.4 DC Characteristics (Continued)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 3/5# Pin Set High for 3.3V Operations

| Symbol            | Parameter                                           | Notes       | Min                   | Тур  | Max              | Units | Test Conditions                                                     |
|-------------------|-----------------------------------------------------|-------------|-----------------------|------|------------------|-------|---------------------------------------------------------------------|
| ICCE              | V <sub>CC</sub> Block Erase Current                 | 1,7         |                       | 6    | 12               | mA    | Block Erase in Progress                                             |
| ICCES             | V <sub>CC</sub> Erase<br>Suspend Current            | 1,2,<br>6,7 |                       | 3    | 6                | mA    | $CE_0$ #, $CE_X$ # = $V_{IH}$<br>Block Erase Suspended              |
| IPPD              | V <sub>PP</sub> Deep Power-<br>Down Current         | 1           |                       | 0.4  | 10               | μΑ    | RP# = GND ± 0.2V                                                    |
| I <sub>PPRS</sub> | V <sub>PP</sub> Standby/                            | 1           |                       | ±2   | ±20              | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                   |
|                   | Read Current                                        |             |                       | 130  | 400              | μΑ    | $V_{PP} > V_{CC}$ .                                                 |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                       | 1           |                       | 10   | 15               | mA    | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Word/Byte Write in Progress |
| IPPE              | V <sub>PP</sub> Erase Current                       | 1           |                       | 4    | 10               | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress       |
| IPPES             | V <sub>PP</sub> Erase<br>Suspend Current            | 1           |                       | 130  | 400              | μΑ    | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Block Erase in Suspended    |
| V <sub>IL</sub>   | Input Low Voltage                                   |             | -0.3                  |      | 0.8              | ٧     |                                                                     |
| V <sub>IH</sub>   | Input High Voltage                                  |             | 2.0                   |      | $V_{CC} \pm 0.3$ | V     |                                                                     |
| V <sub>OL</sub>   | Output Low<br>Voltage                               |             |                       |      | 0.4              | ٧     | $V_{CC} = V_{CC} Min$<br>and $I_{OL} = 4 mA$                        |
| V <sub>OH</sub> 1 | Output High<br>Voltage                              |             | 2.4                   |      |                  | v     | $I_{OH} = -2.0 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$            |
| V <sub>OH</sub> 2 |                                                     |             | V <sub>CC</sub> - 0.2 |      |                  |       | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$            |
| V <sub>PPL</sub>  | V <sub>PP</sub> during<br>Normal Operations         | 3           | 0.0                   | -    | 6.5              | ٧     |                                                                     |
| V <sub>PPH</sub>  | V <sub>PP</sub> during<br>Write/Erase<br>Operations |             | 11.4                  | 12.0 | 12.6             | ٧     |                                                                     |
| V <sub>LKO</sub>  | V <sub>CC</sub> Write/Erase<br>Lockout Voltage      |             | 2.0                   |      |                  | ٧     |                                                                     |

- 1. All current are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 3.3V, V<sub>PP</sub> 12.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum
- of  $I_{CCES}$  and  $I_{CCR}$ .

  3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between VPPH and VPPL.
- 4. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA in static operation.
- 5. CMOS Inputs are either  $V_{CC} \pm 0.2V$  or GND  $\pm 0.2V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .
- 6.  $CE_X # = CE_1 # \text{ or } CE_2 #$ .
- 7. If operating with TTL levels, add 4 mA of VCC Standby Current to max ICCW, ICCE and ICCEs.



## 6.5 DC Characteristics

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$  3/5# Pin Set Low for 5.0V Operations

| Symbol             | Parameter                                   | Notes         | Min | Тур | Max  | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------|---------------------------------------------|---------------|-----|-----|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>IL</sub>    | Input Leakage<br>Current                    | 1             |     |     | ± 2  | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                |
| lLO                | Output Leakage<br>Current                   | 1             |     |     | ± 20 | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                |
| Iccs               | V <sub>CC</sub> Standby<br>Current          | 1,5,6         |     | 100 | 200  | μΑ    | $\begin{split} &V_{CC}=V_{CC}\text{Max}\\ &CE_0\#,CE_X\#,\\ &RP\#=V_{CC}\pm0.2V\\ &BYTE\#,WP\#,3/5\#=V_{CC}\\ &\pm0.2V\text{or}\text{GND}\pm0.2V \end{split}$                                                                                                                                                                                                                                                    |
|                    | ,                                           |               |     | 4   | 8    | mA    | $V_{CC} = V_{CC}$ Max<br>$CE_0$ #, $CE_X$ #, $RP$ # = $V_{IH}$<br>BYTE#, $WP$ #,<br>$3/5$ # = $V_{IH}$ or $V_{IL}$                                                                                                                                                                                                                                                                                               |
| ICCD               | V <sub>CC</sub> Deep Power-<br>Down Current | 1             |     | 2   | 10   | μΑ    | $\begin{array}{l} \text{RP\#} = \text{GND} \pm 0.2\text{V} \\ \text{BYTE\#} = \text{V}_{\text{CC}} \pm 0.2\text{V} \\ \text{or GND} \pm 0.2\text{V} \end{array}$                                                                                                                                                                                                                                                 |
| I <sub>CCR</sub> 1 | V <sub>CC</sub> Read Current                | 1,4,5,<br>6,7 |     | 50  | 60   | mA    | $V_{CC} = V_{CC}$ Max,<br>CMOS: $CE_0\#$ ,<br>$CE_X\# = GND \pm 0.2V$<br>BYTE# = GND $\pm 0.2V$                                                                                                                                                                                                                                                                                                                  |
|                    |                                             | ·             |     |     |      |       | or $V_{CC} \pm 0.2V$<br>Inputs = GND $\pm 0.2V$<br>or $V_{CC} \pm 0.2V$<br>f = 10 MHz, $I_{OUT} = 0$ mA                                                                                                                                                                                                                                                                                                          |
|                    |                                             |               |     | 52  | 64   | mA    | TTL: $CE_0\#$ , $CE_X\# = V_{IL}$ ,<br>BYTE# = $V_{IL}$ or $V_{IH}$<br>Inputs = $V_{IL}$ or $V_{IH}$ ,<br>f = 10 MHz, $I_{OUT} = 0$ mA                                                                                                                                                                                                                                                                           |
| ICCR2              | V <sub>CC</sub> Read Current                | 1,4,5,<br>6,7 |     | 30  | 35   | mA    | $\begin{array}{c} \text{V}_{CC} = \text{V}_{CC} \text{ Max,} \\ \text{CMOS: } \text{CE}_0 \#, \\ \text{CE}_X \# = \text{GND} \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V} \\ \text{or } \text{V}_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V} \\ \text{or } \text{V}_{CC} \pm 0.2 \text{V,} \\ \text{f} = 5 \text{ MHz, } \text{I}_{OUT} = 0 \text{ mA} \end{array}$ |
|                    |                                             |               |     | 32  | 39   | mA    | TTL: $CE_0\#$ , $CE_X\#=V_{ L}$ , BYTE# = $V_{ L}$ or $V_{ H}$ Inputs = $V_{ L}$ or $V_{ H}$ , $f=5$ MHz, $I_{OUT}=0$ mA                                                                                                                                                                                                                                                                                         |
| Iccw               | V <sub>CC</sub> Write Current               | 1,7           |     | 25  | 35   | mA    | Word/Byte in Progress                                                                                                                                                                                                                                                                                                                                                                                            |



## 6.5 DC Characteristics (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 3/5# Pin Set Low for 5.0V Operations

| Symbol            | Parameter                                           | Notes   | Min                   | Тур  | Max                   | Units    | Test Conditions                                                                 |
|-------------------|-----------------------------------------------------|---------|-----------------------|------|-----------------------|----------|---------------------------------------------------------------------------------|
| ICCE              | V <sub>CC</sub> Erase<br>Suspend Current            | 1,7     |                       | 18   | 25                    | mA       | Block Erase in Progress                                                         |
| ICCES             | V <sub>CC</sub> Block<br>Erase Current              | 1,2,6,7 |                       | 5    | 10                    | mA.      | CE <sub>0</sub> #, CE <sub>X</sub> # = V <sub>IH</sub><br>Block Erase Suspended |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-<br>Down Current         | 1       | ·                     | 0.4  | 10                    | μΑ       | $RP\# = GND \pm 0.2V$                                                           |
| IPPRS             | V <sub>PP</sub> Standby/Read Current                | 1       |                       | ± 2  | ± 20                  | μΑ       | $V_{PP} \leq V_{CC}$                                                            |
|                   |                                                     |         |                       | 130  | 400                   | μΑ       | $V_{PP} > V_{CC}$                                                               |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                       | 1.      |                       | 7    | 12                    | mA       | V <sub>PP</sub> = V <sub>PPH</sub> Word/<br>Byte Write in Progress              |
| IPPE              | V <sub>PP</sub> Block Erase Current                 | 1       |                       | 5    | 10                    | mA       | V <sub>PP</sub> = V <sub>PPH</sub> Block<br>Erase in Progress                   |
| IPPES             | V <sub>PP</sub> Erase<br>Suspend Current            | 1       |                       | 130  | 400                   | μΑ       | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                     |
| V <sub>IL</sub>   | Input Low Voltage                                   |         | -0.5                  |      | 0.8                   | ٧        |                                                                                 |
| V <sub>IH</sub>   | Input High Voltage                                  |         | 2.0                   |      | V <sub>CC</sub> + 0.5 | >        |                                                                                 |
| VOL               | Output Low Voltage                                  |         |                       |      | 0.45                  | ٧        | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                                         |
| V <sub>OH</sub> 1 | Output High Voltage                                 |         | 0.85 V <sub>CC</sub>  |      |                       | <b>V</b> | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                        |
| V <sub>OH</sub> 2 |                                                     | ~       | V <sub>CC</sub> - 0.4 |      | !                     |          | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$                        |
| V <sub>PPL</sub>  | V <sub>PP</sub> during<br>Normal Operations         | 3       | 0.0                   |      | 6.5                   | ٧        |                                                                                 |
| V <sub>PPH</sub>  | V <sub>PP</sub> during<br>Write/Erase<br>Operations |         | 11.4                  | 12.0 | 12.6                  | V        |                                                                                 |
| V <sub>LKO</sub>  | V <sub>CC</sub> Write/Erase<br>Lockout Voltage      |         | 2.0                   |      |                       | ٧        |                                                                                 |

#### **NOTES:**

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum
- of  $I_{CCES}$  and  $I_{CCR}$ .

  3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between V<sub>PPH</sub> and V<sub>PPL</sub>.
  4. Automatic Power Saving (APS) reduces I<sub>CCR</sub> to less than 2 mA in Static operation.
- 5. CMOS Inputs are either  $V_{CC}~\pm~0.2V$  or GND  $\pm~0.2V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .
- 6.  $CE_X # = CE_1 # \text{ or } CE_2 #$ .
- 7. If operating with TTL levels, add 4 mA of VCC standby current to max ICCW, ICCE and ICCES.



## 6.6 AC Characteristics—Read Only Operations(1) $V_{CC}=3.3V\pm0.3V,\,T_A=0^{\circ}C$ to $+70^{\circ}C$

|                   | Versions <sup>(5)</sup>                                                              | DD28F0 |     |     |       |  |
|-------------------|--------------------------------------------------------------------------------------|--------|-----|-----|-------|--|
| Symbol            | Parameter                                                                            | Notes  | Min | Max | Units |  |
| t <sub>AVAV</sub> | Read Cycle Time                                                                      |        | 150 |     | ns    |  |
| t <sub>AVQV</sub> | Address to Output Delay                                                              |        |     | 150 | ns    |  |
| t <sub>ELQV</sub> | CE <sub>X</sub> # to Output Delay                                                    | 2      |     | 150 | ns    |  |
| t <sub>PHQV</sub> | RP# High to Output Delay                                                             |        |     | 750 | ns    |  |
| t <sub>GLQV</sub> | OE# to Output Delay                                                                  | 2      |     | 50  | ns    |  |
| tELQX             | CE <sub>X</sub> # to Output in Low Z                                                 | 3      | 0   |     | ns    |  |
| t <sub>EHQZ</sub> | CE <sub>X</sub> # to Output in High Z                                                | 3      |     | 55  | ns    |  |
| tGLQX             | OE# to Output in Low Z                                                               | 3      | 0   |     | ns    |  |
| tGHQZ             | OE# to Output in High Z                                                              | 3      |     | 40  | ns    |  |
| tон               | Output Hold from Address, CE <sub>X</sub> # or OE#<br>Change, Whichever Occurs First | 3      | 0   |     | ns    |  |
| t <sub>FLQV</sub> | BYTE# to Output Delay                                                                | 3      |     | 150 | ns    |  |
| t <sub>FLQZ</sub> | BYTE# Low to Output in High Z                                                        | 3      | ,   | 40  | ns    |  |
| t <sub>ELFL</sub> | CE <sub>X</sub> # Low to BYTE# High or Low                                           | 3      |     | 5   | ns    |  |
| For Exter         | nded Status Register Reads                                                           |        | -   |     |       |  |
| taveL             | Address Setup to CE <sub>X</sub> # Going Low                                         | 3,4    | 0   |     | ns    |  |
| tavgl             | Address Setup to OE # Going Low                                                      | 3,4    | 0   |     | ns    |  |



## 6.6 AC Characteristics—Read Only Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Versions <sup>(5)</sup>            |                                                                                         | V <sub>CC</sub><br>± 5% | DD28F032SA-<br>070 <sup>(6)</sup> |     |                                   |     |                                   |      |       |
|------------------------------------|-----------------------------------------------------------------------------------------|-------------------------|-----------------------------------|-----|-----------------------------------|-----|-----------------------------------|------|-------|
|                                    |                                                                                         | V <sub>CC</sub> ± 10%   |                                   |     | DD28F032SA-<br>080 <sup>(7)</sup> |     | DD28F032SA-<br>100 <sup>(7)</sup> |      | Units |
| Symbol                             | Parameter                                                                               | Notes                   | Min                               | Max | Min                               | Max | Min                               | Max  |       |
| t <sub>AVAV</sub>                  | Read Cycle Time                                                                         |                         | 70                                |     | 80                                |     | 100                               |      | ns    |
| t <sub>AVQV</sub>                  | Address to Output Delay                                                                 |                         |                                   | 70  |                                   | 80  |                                   | 100  | ns    |
| t <sub>ELQV</sub>                  | CEX# to Output Delay                                                                    | 2                       |                                   | 70  |                                   | 80  |                                   | ·100 | ns    |
| t <sub>PHQV</sub>                  | RP# to Output Delay                                                                     |                         |                                   | 400 |                                   | 480 |                                   | 550  | ns    |
| tGLQV                              | OE# to Output Delay                                                                     | 2                       |                                   | 30  |                                   | 35  |                                   | 40   | ns    |
| t <sub>ELQX</sub>                  | CEX# to Output in Low Z                                                                 | 3                       | 0                                 |     | 0                                 |     | 0                                 |      | ns    |
| tEHQZ                              | CEX# to Output in High Z                                                                | 3                       |                                   | 25  |                                   | 30  |                                   | 35   | ns    |
| tGLQX                              | OE# to Output in Low Z                                                                  | 3                       | 0                                 |     | 0                                 |     | 0                                 |      | ns    |
| tGHQZ                              | OE# to Output in High Z                                                                 | 3                       |                                   | 25  |                                   | 30  |                                   | 35   | ns    |
| t <sub>OH</sub>                    | Output Hold from Address,<br>CE <sub>X</sub> # or OE# Change,<br>Whichever Occurs First | 3                       | 0                                 |     | 0                                 |     | 0                                 |      | ns    |
| t <sub>FLQV</sub>                  | BYTE# to Output Delay                                                                   | 3                       |                                   | 70  |                                   | 80  |                                   | 100  | ns    |
| tFLQZ                              | BYTE# Low to Output in High Z                                                           | 3                       |                                   | 25  |                                   | 30  |                                   | 30   | ns    |
| t <sub>ELFL</sub>                  | CE <sub>X</sub> # Low to BYTE#<br>High or Low                                           | - 3                     |                                   | 5   |                                   | 5   |                                   | 5    | ns    |
| For Extended Status Register Reads |                                                                                         |                         |                                   |     |                                   |     |                                   |      |       |
| tAVEL                              | Address Setup to CE <sub>X</sub> #<br>Going Low                                         | 3,4                     | 0                                 |     | 0                                 |     | 0                                 |      | ns    |
| tAVGL                              | Address Setup to OE#<br>Going Low                                                       | 3,4                     | 0                                 |     | 0                                 |     | 0                                 |      | ns    |

- 1. See AC Input/Output Reference Waveforms for timing measurements, Figures 6 and 7.
- 2. OE# may be delayed up to t<sub>ELQV</sub>-t<sub>GLQV</sub> after the falling edge of CE<sub>X</sub># without impact in t<sub>ELQV</sub>.
- 3. Sampled, not 100% tested.
- 4. This timing parameter is used to latch the correct BSR data onto the outputs.
- 5. Device speeds are defined as:
  - 70/80 ns at  $V_{CC}=5.0V$  equivalent to 150 ns at  $V_{CC}=3.3V$  100 ns at  $V_{CC}=5.0V$  equivalent to

  - 150 ns at  $V_{CC} = 3.3V$
- 6. See AC Input/Output Reverence Waveforms and AC Testing Load Circuits for High Speed Test Configuration.
- 7. See Standard AC Input/Output Reference Waveforms and AC Testing Load Circuit.





Figure 11. Read Timing Waveforms





For 28F016SA No. 1:  $CE_X\#$  is defined as the latter of  $CE_0\#$  or  $CE_1\#$  going low, or the first of  $CE_0\#$  or  $CE_1\#$  going high.

For 28F016SA No. 2:  $CE_X\#$  is defined as the latter of  $CE_0\#$  or  $CE_2\#$  going low, or the first of  $CE_0\#$  or  $CE_2\#$  going high.

Figure 12. BYTE# Timing Waveforms



## 6.7 Power-Up and Reset Timings



Figure 13. V<sub>CC</sub> Power-Up and RP# Reset Waveforms

| Symbol                                 | Parameter                                                                 | Notes | Min | Max | Units |
|----------------------------------------|---------------------------------------------------------------------------|-------|-----|-----|-------|
| t <sub>PLYL</sub><br>t <sub>PLYH</sub> | RP# Low to 3/5# Low (High)                                                | . 1   | 0   |     | μs    |
| t <sub>YLPH</sub><br>t <sub>YHPH</sub> | 3/5# Low (High) to RP# High                                               | 1     | 2   |     | μs    |
| t <sub>PL5V</sub><br>t <sub>PL3V</sub> | RP# Low to $V_{CC}$ at 4.5V Minimum (to $V_{CC}$ at 3.0V min or 3.6V max) | 2     | 0   |     | μs    |
| t <sub>AVQV</sub>                      | Address Valid to Data Valid for $V_{CC} = 5.0V \pm 10\%$                  | 3     |     | 80  | ns    |
| t <sub>PHQV</sub>                      | RP# High to Data Valid for $V_{CC} = 5.0V \pm 10\%$                       | 3     |     | 480 | ns    |

#### NOTES:

CE0#, CEX# and OE# are switched low after Power-Up.

1. Minimum of 2  $\mu s$  is required to meet the specified t<sub>PHQV</sub> times.

2. The power supply may start to switch concurrently with RP# going Low.

3. The address access tie and RP# high to data valid time are shown for 5.0V V<sub>CC</sub> operation. Refer to the AC Characteristics Read Only Operations 3.3V V<sub>CC</sub> operation and all other speed options.



# 6.8 AC Characteristics for WE #—Controlled Command Write Operations(1)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                     | Versions                                                                                | Notes | DD  | 28F0329 | SA-150 | Unit |
|---------------------|-----------------------------------------------------------------------------------------|-------|-----|---------|--------|------|
| Symbol              | Parameter                                                                               | Notes | Min | Тур     | Max    | Unit |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                        |       | 150 |         |        | ns   |
| t <sub>VPWH</sub>   | V <sub>PP</sub> Setup to WE# Going High                                                 | 3     | 100 |         |        | ns   |
| t <sub>PHEL</sub>   | RP# Setup to CE <sub>X</sub> # Going Low                                                |       | 480 |         |        | ns   |
| tELWL               | CEX# Setup to WE# Going Low                                                             |       | 10  |         |        | ns   |
| t <sub>AVWH</sub>   | Address Setup to WE# Going High                                                         | 2,6   | 75  |         |        | ns   |
| t <sub>DVWH</sub>   | Data Setup to WE# Going High                                                            | 2,6   | 75  |         |        | ns   |
| twLWH               | WE# Pulse Width                                                                         |       | 75  |         |        | ns   |
| twhox               | Data Hold from WE# High                                                                 | 2     | 10  |         |        | ns   |
| twhax               | Address Hold from WE# High                                                              | 2     | 10  |         |        | ns   |
| twhEH               | CEX# hold from WE# High                                                                 |       | 10  |         |        | ns   |
| twhwL               | WE# Pulse Width High                                                                    |       | 75  |         |        | ns   |
| tGHWL               | Read Recovery before Write                                                              |       | 0   |         |        | ns   |
| twhrl               | WE# High to RY/BY# Going Low                                                            |       |     |         | 100    | ns   |
| t <sub>RHPL</sub>   | RP# Hold from Valid Status Register<br>(CSR, GSR, BSR) Data and RY/BY# High             | 3     | 0   |         |        | ns   |
| t <sub>PHWL</sub>   | RP# High Recovery to WE# Going Low                                                      |       | 1   |         |        | μs   |
| twhgl               | Write Recovery before Read                                                              |       | 95  |         |        | ns   |
| tQVVL               | V <sub>PP</sub> Hold from Valid Status Register<br>(CSR, GSR, BSR) Data and RY/BY# High |       | 0   |         |        | μs   |
| t <sub>WHQV</sub> 1 | Duration of Word/Byte Write Operation                                                   | 4,5   | 5   | 9       | Note 7 | μs   |
| t <sub>WHQV</sub> 2 | Duration of Block Erase Operation                                                       | 4     | 0.3 |         | 10     | sec  |



# 6.8 AC Characteristics for WE #—Controlled Command Write Operations(1)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0$ °C to +70°C (Continued)

|                     | Versions                                                                                      | V <sub>CC</sub><br>± 5%  | DD  | 28F03<br>070 |        |     |              |        |     |              |        |      |
|---------------------|-----------------------------------------------------------------------------------------------|--------------------------|-----|--------------|--------|-----|--------------|--------|-----|--------------|--------|------|
|                     | Versions                                                                                      | V <sub>CC</sub><br>± 10% |     | ,            |        | DD  | 28F03<br>080 |        | DD  | 28F03<br>100 |        | Unit |
| Symbol              | Parameter                                                                                     | Notes                    | Min | Тур          | Max    | Min | Тур          | Max    | Min | Тур          | Max    |      |
| tavav               | Write Cycle Time                                                                              |                          | 70  |              |        | 80  |              |        | 100 |              |        | ns   |
| <sup>t</sup> VPWH   | V <sub>PP</sub> Setup to WE#<br>Going High                                                    | 3                        | 100 |              |        | 100 |              |        | 100 |              |        | ns   |
| <sup>†</sup> PHEL   | RP# Setup to CE <sub>X</sub> #<br>Going Low                                                   |                          | 480 |              |        | 480 |              |        | 480 |              |        | ns   |
| <sup>t</sup> ELWL   | CE <sub>X</sub> # Setup to WE#<br>Going Low                                                   |                          | 0   |              |        | 0   |              |        | 0   |              |        | ns   |
| t <sub>AVWH</sub>   | Address Setup to WE#<br>Going High                                                            | 2,6                      | 50  |              |        | 50  |              |        | 50  |              | ,      | ns   |
| <sup>t</sup> DVWH   | Data Setup to WE#<br>Going High                                                               | 2,6                      | 50  |              |        | 50  |              |        | 50  |              |        | ns   |
| twLWH               | WE# Pulse Width                                                                               |                          | 40  |              |        | 50  |              |        | 50  |              |        | ns   |
| twHDX               | Data Hold from WE#<br>High                                                                    | 2                        | 0   | 1            |        | 0   |              |        | 0   |              |        | ns   |
| <sup>t</sup> whax   | Address Hold from WE#                                                                         | 2                        | 10  |              |        | 10  |              |        | 10  |              |        | ns   |
| twheh               | CE <sub>X</sub> # Hold from WE#<br>High                                                       |                          | 10  |              |        | 10  |              |        | 10  |              |        | ns   |
| twHWL               | WE# Pulse Width High                                                                          |                          | 30  |              |        | 30  |              |        | 50  |              |        | ns   |
| t <sub>GHWL</sub>   | Read Recovery before<br>Write                                                                 |                          | 0   | ,            |        | 0   |              |        | 0   |              |        | ns   |
| <sup>t</sup> whrl   | WE# High to RY/BY#<br>Going Low                                                               |                          |     |              | 100    |     |              | 100    |     |              | 100    | ns   |
| t <sub>RHPL</sub>   | RP# Hold from Valid<br>Status Register (CSR,<br>GSR, BSR) Data and<br>RY/BY# High             | 3                        | 0   |              |        | 0   | 1            |        | 0   |              |        | ns   |
| t <sub>PHWL</sub>   | RP# High Recovery to WE# Going Low                                                            |                          | 1   |              | ,      | 1   |              |        | 1   |              |        | μs   |
| twHGL               | Write Recovery before Read                                                                    |                          | 60  |              |        | 65  |              |        | 65  |              |        | ns   |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid<br>Status Register (CSR,<br>GSR, BSR) Data and<br>RY/BY# High |                          | 0   |              |        | 0   |              |        | 0   |              |        | μs   |
| t <sub>WHQV</sub> 1 | Duration of Word/Byte<br>Write Operation                                                      | 4,5                      | 4.5 | 6            | Note 7 | 4.5 | 6            | Note 7 | 4.5 | 6            | Note 7 | μs   |
| t <sub>WHQV</sub> 2 | Duration of Block Erase<br>Operation                                                          | 4                        | 0.3 |              | 10     | 0.3 |              | 10     | 0.3 |              | 10     | sec  |



#### NOTES:

For 28F016SA No. 1:  $CE_X\#$  is defined as the latter of  $CE_0\#$  or  $CE_1\#$  going low or the first of  $CE_0\#$  or  $CE_1\#$  going high. For 28F016SA No. 2:  $CE_X\#$  is defined as the latter of  $CE_0\#$  or  $CE_2\#$  going low or the first of  $CE_0\#$  or  $CE_2\#$  going high.

- 1. Read timings during Write and Erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, but not 100% tested
- 4. Write/Erase durations are measured to valid Status Register (CSR) Data.
- 5. Word/Byte Write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of WE# for all Command Write operations.
- This information will be available in a technical paper. Please call Intel's Application Hotline or your local sales office for more information.



Figure 14. AC Waveforms for Command Write Operations



# 6.9 AC Characteristics for CEx #—Controlled Write Operations(1) $V_{CC}=3.3V\pm0.3V,\,T_A=0^{\circ}C$ to $+70^{\circ}C$

| Oursels al          | Versions                                                                                | Natas | DD  | 28F032 | SA-150 | 11:-14 |
|---------------------|-----------------------------------------------------------------------------------------|-------|-----|--------|--------|--------|
| Symbol              | Parameter                                                                               | Notes | Min | Тур    | Max    | Unit   |
| tavav               | Write Cycle Time                                                                        |       | 150 |        |        | ns     |
| tvpeH               | V <sub>PP</sub> Setup to CE <sub>X</sub> # Going High                                   | 3     | 100 |        | -      | ns     |
| tPHWL               | RP# Setup to WE# Going Low                                                              |       | 480 |        |        | ns     |
| twlEL               | WE# Setup to CEX# Going Low                                                             |       | 0   |        |        | ns     |
| t <sub>AVEH</sub>   | Address Setup to CE <sub>X</sub> # Going High                                           | 2,6   | 75  | ,      |        | ns     |
| <sup>t</sup> DVEH   | Data Setup to CE <sub>X</sub> # Going High                                              | 2,6   | 75  |        |        | ns     |
| tELEH               | CEX# Pulse Width                                                                        |       | 75  |        |        | ns     |
| tEHDX               | Data Hold from CE <sub>X</sub> # High                                                   | 2     | 10  |        |        | ns     |
| tEHAX               | Address Hold from CE <sub>X</sub> # High                                                | 2     | -10 |        |        | ns     |
| tEHWH               | WE hold from CE <sub>X</sub> # High                                                     |       | 10  |        |        | ns     |
| t <sub>EHEL</sub>   | CEX# Pulse Width High                                                                   |       | 75  |        |        | ns     |
| tGHEL               | Read Recovery before Write                                                              |       | 0   |        |        | ns     |
| tEHRL               | CEX# High to RY/BY# Going Low                                                           |       |     |        | 100    | ns     |
| t <sub>RHPL</sub>   | RP# Hold from Valid Status Register<br>(CSR, GSR, BSR) Data and RY/BY# High             | 3     | 0   |        |        | ns     |
| t <sub>PHEL</sub>   | RP# High Recovery to CEX# Going Low                                                     |       | 1   |        |        | μs     |
| tEHGL               | Write Recovery before Read                                                              |       | 120 |        |        | ns     |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid Status Register<br>(CSR, GSR, BSR) Data and RY/BY# High |       | 0   | ľ      |        | μs     |
| t <sub>EHQV</sub> 1 | Duration of Word/Byte Write Operation                                                   | 4,5   | 5   | 9      | Note 7 | μs     |
| t <sub>EHQV</sub> 2 | Duration of Block Erase Operation                                                       | 4     | 0.3 |        | 10     | sec    |



# **6.9 AC Characteristics for CEx #—Controlled Command Write Operations(1)** $V_{CC}=5.0V\pm0.5V$ , $T_A=0^{\circ}C$ to $+70^{\circ}$ C (Continued)

|                     | Vandana                                                                                      | V <sub>CC</sub><br>± 5% | DD  | 28F03<br>070 |        |     |              |        |     |              |        |      |
|---------------------|----------------------------------------------------------------------------------------------|-------------------------|-----|--------------|--------|-----|--------------|--------|-----|--------------|--------|------|
|                     | Versions                                                                                     | V <sub>CC</sub> ± 10%   |     |              |        | DD  | 28F03<br>080 |        | DD  | 28F03<br>100 | 2SA-   | Unit |
| Symbol              | Parameter                                                                                    | Notes                   | Min | Тур          | Max    | Min | Тур          | Max    | Min | Тур          | Max    |      |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                             |                         | 70  |              |        | 80  |              |        | 100 |              |        | ns   |
| tVPEH               | V <sub>PP</sub> Setup to CE <sub>X</sub> #<br>Going High                                     | 3                       | 100 |              |        | 100 |              |        | 100 |              |        | ns   |
| t <sub>PHWL</sub>   | RP# Setup to WE#<br>Going Low                                                                | 3                       | 480 |              |        | 480 |              |        | 480 |              |        | ns   |
| tWLEL               | WE# Setup to CE <sub>X</sub> # Going Low                                                     |                         | 0   |              |        | 0   |              |        | 0   |              |        | ns   |
| <sup>t</sup> AVEH   | Address Setup to CE <sub>X</sub> #<br>Going High                                             | 2,6                     | 50  |              |        | 50  |              |        | 50  |              |        | ns   |
| <sup>t</sup> DVEH   | Data Setup to CE <sub>X</sub> #<br>Going High                                                | 2,6                     | 50  |              |        | 50  |              |        | 50  |              |        | ns   |
| t <sub>ELÉH</sub>   | CE <sub>X</sub> # Pulse Width                                                                |                         | 40  |              |        | 50  |              |        | 50  |              |        | ns   |
| t <sub>EHDX</sub>   | Data Hold from CE <sub>X</sub> #<br>High                                                     | 2                       | 0   |              |        | 0   |              |        | 0   |              |        | ns   |
| t <sub>EHAX</sub>   | Address Hold from CE <sub>X</sub> # High                                                     | 2                       | 10  |              |        | 10  |              |        | 10  |              |        | ns   |
| tEHWH               | WE Hold from CE <sub>X</sub> #<br>High                                                       |                         | 10  |              |        | 10  |              |        | 10  |              |        | ns   |
| t <sub>EHEL</sub>   | CEX# Pulse Width High                                                                        |                         | 30  |              |        | 30  |              |        | 50  |              |        | ns   |
| tGHEL               | Read Recovery before<br>Write                                                                |                         | 0   |              | v      | 0   |              |        | 0   |              |        | ns   |
| t <sub>EHRL</sub>   | CEX# High to RY/BY# Going Low                                                                |                         |     |              | 100    |     |              | 100    |     |              | 100    | ns   |
| <sup>t</sup> RHPL   | RP# Hold from Valid<br>Status Register (CSR,<br>GSR, BSR) Data and<br>RY/BY# High            | 3                       | 0   |              |        | 0   |              |        | 0   |              |        | ns   |
| t <sub>PHEL</sub>   | RP# High Recovery to CE <sub>X</sub> # Going Low                                             |                         | 1   |              |        | 1   |              |        | 1   |              |        | μs   |
| <sup>t</sup> EHGL   | Write Recovery before<br>Read                                                                |                         | 60  |              |        | 65  |              |        | 80  |              |        | ns   |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid<br>Status Register (CSR,<br>GSR, BSR) Data at<br>RY/BY# High |                         | 0   |              |        | 0   |              |        | 0   |              |        | μs   |
| t <sub>EHQV</sub> 1 | Duration of Word/Byte<br>Write Operation                                                     | 4,5                     | 4.5 | 6            | Note 7 | 4.5 | 6            | Note 7 | 4.5 | 6            | Note 7 | μs   |
| t <sub>EHQV</sub> 2 | Duration of Block Erase<br>Operation                                                         | 4                       | 0.3 |              | 10     | 0.3 |              | 10     | 0.3 |              | 10     | sec  |



#### NOTES:

For 28F016SA No. 1: CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low or the first of CE<sub>0</sub># or CE<sub>1</sub># going high. For 28F016SA No. 2: CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>2</sub># going low or the first of CE<sub>0</sub># or CE<sub>2</sub># going high.

- 1. Read timings during Write and Erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, but not 100% tested.
- 4. Write/Erase durations are measured to valid Status Data.
- 5. Word/Byte Write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of CEx# for all Command Write Operations.
- 7. This information will be available in a technical paper. Please call Intel's Application Hotline or your local sales office for more information.



#### NOTES:

- 1. This address string depicts Data-Write/Erase cycles with corresponding verification via ESRD.
- 2. This address string depicts Data-Write/Erase cycles with corresponding verification via CSRD.
- 3. This cycle is invalid when using CSRD for verification during Data-Write/Erase operations.
- 4. For 28F016SA No. 1: CE<sub>X</sub># is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- For 28F016SA No. 2: CEx# is defined as the latter of CE0# or CE2# going low, or the first of CE0# or CE2# going high.
- 5. RP# low transition is only to show tRHPL; not valid for above Read and Write cycles.

Figure 15. Alternate AC Waveforms for Command Write Operations



# 6.10 AC Characteristics for Page Buffer Write Operations(1) $V_{CC}=3.3V~\pm0.3V,\,T_A=0^{\circ}C$ to $+70^{\circ}C$

|                   | Versions                       |       | DD  | 28F032SA | -150 | 11-14 |
|-------------------|--------------------------------|-------|-----|----------|------|-------|
| Symbol            | Parameter                      | Notes | Min | Тур      | Max  | Unit  |
| t <sub>AVAV</sub> | Write Cycle Time               |       | 150 |          |      | ns    |
| tELWL             | CEX# Setup to WE# Going Low    |       | 10  |          |      | ns    |
| t <sub>AVWL</sub> | Address Setup to WE# Going Low | 3     | 0   |          |      | ns    |
| t <sub>DVWH</sub> | Data Setup to WE# Going High   | 2     | 75  |          |      | ns    |
| twLWH             | WE# Pulse Width                |       | 75  |          |      | ns    |
| twHDX ·           | Data Hold from WE# High        | 2     | 10  |          |      | ns    |
| twhax             | Address Hold from WE# High     | 2     | 10  |          |      | ns    |
| twhEH             | CEX# Hold from WE# High        |       | 10  |          |      | ns    |
| twhwL             | WE# Pulse Width High           |       | 75  |          |      | ns    |
| t <sub>GHWL</sub> | Read Recovery before Write     |       | 0   |          |      | ns    |
| twigi             | Write Recovery before Read     |       | 95  |          |      | ns    |



# 6.10 AC Characteristics for Page Buffer Write Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                   | Versions                                    | ,     | DD  | DD28F032SA-<br>070 |     | DD28F032SA<br>-080 |     | DD  | 28F032<br>100 | SA- | Unit |      |
|-------------------|---------------------------------------------|-------|-----|--------------------|-----|--------------------|-----|-----|---------------|-----|------|------|
| Symbol            | Parameter                                   | Notes | Min | Тур                | Max | Min                | Тур | Max | Min           | Тур | Max  | Unit |
| tAVAV             | Write Cycle Time                            | ,     | 70  |                    |     | 80                 |     |     | 100           |     |      | ns   |
| tELWL             | CE <sub>X</sub> # Setup to WE#<br>Going Low | ·     | 0   |                    |     | 0                  |     |     | 0             |     |      | ns   |
| t <sub>AVWL</sub> | Address Setup to WE# Going Low              | 3     | 0   | -                  | ,   | 0                  |     |     | 0             |     |      | ns   |
| tDVWH             | Data Setup to WE#<br>Going High             | 2     | 50  |                    |     | 50                 |     |     | 50            |     |      | ns   |
| twLwH             | WE# Pulse Width                             |       | 40  |                    |     | 50                 |     |     | 50            |     |      | ns   |
| twHDX             | Data Hold from WE#<br>High                  | 2     | 0   |                    |     | 0                  |     |     | 0             |     |      | ns   |
| twhax             | Address Hold from WE# High                  | 2     | 10  |                    |     | 10                 |     |     | 10            |     |      | ns   |
| twhEH             | CE <sub>X</sub> # Hold from WE#<br>High     |       | 10  |                    |     | 10                 |     |     | 10            |     |      | ns   |
| twhwL             | WE# Pulse Width High                        |       | 30  |                    |     | 30                 |     |     | 50            |     |      | ns   |
| tGHWL             | Read Recovery before<br>Write               |       | 0   |                    |     | 0                  |     |     | 0             |     |      | ns   |
| twHGL             | Write Recovery before<br>Read               |       | 60  |                    |     | 65                 |     |     | 65            |     |      | ns   |

#### NOTES

For 28F016SA No. 1: CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low or the first of CE<sub>0</sub># or CE<sub>1</sub># going high. For 28F016SA No. 2: CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>2</sub># going low or the first of CE<sub>0</sub># or CE<sub>2</sub># going high.

- 1. These are WE#-controlled write timings, equivalent CEx#-controlled write timings apply.
- 2. Sampled, not 100% tested.
- 3. Address must be valid during the entire WE# low pulse or the entire CEx# low pulse (for CEx# controlled write timings)





Figure 16. Page Buffer Write Timing Waveforms (Loading Data to the Page Buffer)



# 6.11 Erase and Word/Byte Write Performance, Cycling Performance and Suspend Latency<sup>(1,3)</sup>

 $V_{CC} = 3.3V \pm 0.3V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol              | Parameter                              | Notes | Min     | Typ(1)    | Max    | Units  | <b>Test Conditions</b> |
|---------------------|----------------------------------------|-------|---------|-----------|--------|--------|------------------------|
|                     | Page Buffer Byte Write Time            | 2,4   |         | 3.26      | Note 6 | μs     |                        |
|                     | Page Buffer Word Write Time            | 2,4   |         | 6.53      | Note 6 | μs     |                        |
| t <sub>WHRH</sub> 1 | Word/Byte Write Time                   | 2     |         | 9         | Note 6 | μs     |                        |
| t <sub>WHRH</sub> 2 | Block Write Time                       | 2     |         | 0.6       | 2.1    | Sec    | Byte Write Mode        |
| t <sub>WHRH</sub> 3 | Block Write Time                       | 2     |         | 0.3       | 1.0    | Sec    | Word Write Mode        |
|                     | Block Erase Time                       | 2     |         | 0.8       | 10     | Sec    |                        |
|                     | Full Chip Erase Time                   | 2     |         | 25.6      |        | Sec    |                        |
|                     | Erase Suspend Latency<br>Time to Read  |       |         | 7.0       |        | μs     |                        |
|                     | Erase Suspend Latency<br>Time to Write |       |         | 10.0      |        | μs     | -                      |
|                     | Erase Cycles                           | 5     | 100,000 | 1,000,000 |        | Cycles |                        |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol              | Parameter                              | Notes | Min     | Typ(1)    | Max    | Units  | Test Conditions |
|---------------------|----------------------------------------|-------|---------|-----------|--------|--------|-----------------|
|                     | Page Buffer Byte Write Time            | 2,4   |         | 2.76      | Note 6 | μs     |                 |
|                     | Page Buffer Word Write Time            | 2,4   |         | 5.51      | Note 6 | μs     |                 |
| t <sub>WHRH</sub> 1 | Word/Byte Write Time                   | - 2   |         | 6         | Note 6 | μs     |                 |
| t <sub>WHRH</sub> 2 | Block Write Time                       | 2     |         | 0.4       | 2.1    | Sec    | Byte Write Mode |
| t <sub>WHRH</sub> 3 | Block Write Time                       | 2     |         | 0.2       | 1.0    | Sec    | Word Write Mode |
|                     | Block Erase Time                       | 2     |         | 0.6       | 10     | Sec    |                 |
|                     | Full Chip Erase Time                   | 2     |         | 19.2      |        | Sec    |                 |
|                     | Erase Suspend Latency<br>Time to Read  |       |         | 5.0       |        | μs     |                 |
|                     | Erase Suspend Latency<br>Time to Write |       |         | 8.0       |        | μs     |                 |
|                     | Erase Cycles                           | 5     | 100,000 | 1,000,000 |        | Cycles |                 |

#### NOTES

- 1. 25°C,  $V_{CC} = 3.3V$  or 5.0V nominal, 10K cycles.
- 2. Excludes system-level overhead.
- 3. These performance numbers are valid for all speed versions.
- 4. This assumes using the full Page Buffer to Write to Flash (256 bytes or 128 words).
- 5. 1,000,000 cycle performance assume the application uses block retirement techniques.
- 6. This information will be available in a technical paper. Please call Intel's Application hotline or your local sales office for more information.

# intel<sub>®</sub>

## 7.0 DERATING CURVES



Figure 17.  $I_{CC}$  vs. Frequency ( $V_{CC} = 5.5V$ ) for x8 or x16 Operation



Figure 19.  $I_{CC}$  vs. Frequency ( $V_{CC} = 3.6V$ ) for x8 or x16 Operation



Figure 18. I<sub>CC</sub> during Block Erase



Figure 20. Ipp during Block Erase





Figure 21. Access Time (t<sub>ACC</sub>) vs. Output Loading



Figure 22. Ipp during Word Write Operation



Figure 23. Ipp during Page Buffer Write Operation



## 8.0 MECHANICAL SPECIFICATIONS



Figure 24. Mechanical Specifications of the Dual Die 56-L TSOP Type I Package



|                | Family: Dual | Die Thin Small Out-L | ine Package |       |  |  |  |  |  |
|----------------|--------------|----------------------|-------------|-------|--|--|--|--|--|
| 0              | Millimeters  |                      |             |       |  |  |  |  |  |
| Symbol         | Minimum      | Nominal              | Maximum     | Notes |  |  |  |  |  |
| Α              |              | ,                    | 1.20        |       |  |  |  |  |  |
| A <sub>1</sub> | 0.50         |                      |             | 1.    |  |  |  |  |  |
| A <sub>2</sub> | 0.965        | 0.995                | 1.025       |       |  |  |  |  |  |
| b              | 0.100        | 0.150                | 0.200       |       |  |  |  |  |  |
| С              | 0.115        | 0.125                | 0.135       |       |  |  |  |  |  |
| D <sub>1</sub> | 18.20        | 18.40                | 18.60       |       |  |  |  |  |  |
| E              | 13.80        | 14.00                | 14.20       |       |  |  |  |  |  |
| е              |              | 0.50                 |             |       |  |  |  |  |  |
| D              | 19.80        | 20.00                | 20.20       |       |  |  |  |  |  |
| L              | 0.500        | 0.600                | 0.700       |       |  |  |  |  |  |
| N              |              | 56                   |             | .*    |  |  |  |  |  |
| Ø              | 0°           | 3°                   | 5°          |       |  |  |  |  |  |
| Υ ,            |              |                      | 0.100       |       |  |  |  |  |  |
| Z              | 0.150        | 0.250                | 0.350       |       |  |  |  |  |  |



## **DEVICE NOMENCLATURE/ORDERING INFORMATION**



|        |                |                                         | Valid Combinations                    |                                         |
|--------|----------------|-----------------------------------------|---------------------------------------|-----------------------------------------|
| Option | Order Code     | V <sub>CC</sub> = 3.3V<br>± 0.3V, 50 pF | V <sub>CC</sub> = 5.0V<br>± 5%, 30 pF | V <sub>CC</sub> = 5.0V<br>± 10%, 100 pF |
| 1      | DD28F032SA 070 | DD28F032SA-150                          | DD28F032SA-070                        | DD28F032SA-080                          |
| 2      | DD28F032SA 100 | DD28F032SA-150                          | `                                     | DD28F032SA-100                          |

## **ADDITIONAL INFORMATION**

|        | Item                                                                                    | Order Number |
|--------|-----------------------------------------------------------------------------------------|--------------|
|        | 28F016SA 16-Mbit FlashFile™ Memory User's Manual                                        | 297372       |
| ,      | 28F016SA 16-Mbit FlashFile™ Memory Data Sheet                                           | 290489       |
|        | 28F016SV FlashFile™ Memory Data Sheet                                                   | 290528       |
| 1      | 28F008SA Data Sheet                                                                     | 290435       |
| AP 393 | "28F016SV Compatibility with 28F016SA"                                                  | 292144       |
| AP 378 | "System Optimization Using the Enhanced Features of the 28F016SA"                       | 292127       |
| AP 377 | "28F016SA Software Drivers"                                                             | 292126       |
| AP 375 | "Upgrade Considerations from the 28F008SA to the 28F016SA"                              | 292124       |
| AP357  | "Power Supply Solutions for Flash Memory"                                               | 292092       |
| AP374  | "Flash Memory Write Protection Techniques"                                              | 292123       |
| FLASH  | Builder Design Resource Tool                                                            | 297508       |
| AP 607 | Multi-Ste Layout Planning w/Intel's FlashFile™ Components Including ROM Capab-          | 292159       |
|        | ility Small and Low-Cost Power Supply Solution for Intel's Flash Memory Products        | 297534       |
| ER 33  | "ETOX™ Flash Memory Technology—Insight to Intel's Fourth Generation Process Innovation" | 294016       |

Please check with Intel Literature for availability.



## **DATA SHEET REVISION HISTORY**

| 271171 011221 1127101011 111010111 |                                                        |
|------------------------------------|--------------------------------------------------------|
| Number                             | Description                                            |
| 001                                | Original Version                                       |
| 002                                | CE <sub>0</sub> #, CE <sub>1</sub> # control die No. 1 |
|                                    | CE <sub>0</sub> #, CE <sub>2</sub> # control die No. 2 |



# 28F016SV 16-MBIT (1 MBIT x 16, 2 MBIT x 8) FlashFile™ MEMORY

- SmartVoltage Technology
  - User-Selectable 3.3V or 5V V<sub>CC</sub>
  - User-Selectable 5V or 12V Vpp
- 65 ns Access Time
- 1 Million Erase Cycles per Block
- 30.8 MB/sec Burst Write Transfer Rate
- 0.48 MB/sec Sustainable Write Transfer Rate
- Configurable x8 or x16 Operation
- 56-Lead TSOP and SSOP Type I Packages

- Backwards-Compatible with 28F016SA, 28F008SA Command Set
- **■** Revolutionary Architecture
  - Multiple Command Execution
  - Write during Erase
  - Command Super-Set of the Intel 28F008SA
  - Page Buffer Write
- **2** μA Typical Deep Power-Down
- 32 Independently Lockable Blocks
- State-of-the-Art 0.6 µm ETOX™ IV Flash Technology

Intel's 28F016SV 16-Mbit FlashFile<sup>TM</sup> memory is a revolutionary architecture which is the ideal choice for designing embedded direct-execute code and mass storage data/file flash memory systems. With innovative capabilities, low-power operation, user-selectable V<sub>PP</sub> voltage and high read/write performance, the 28F016SV enables the design of truly mobile, high-performance personal computing and communications products.

The 28F016SV is the highest density, highest performance nonvolatile read/write solution for solid-state storage applications. Its symmetrically blocked architecture (100% compatible with the 28F008SA 8-Mbit and 28F016SA 16-Mbit FlashFile memories), extended cycling, flexible V<sub>CC</sub> and V<sub>PP</sub> voltages (SmartVoltage technology), fast write and read performance and selective block locking provide a highly flexible memory component suitable for Resident Flash Arrays, high-density memory cards and PCMCIA-ATA flash drives. The 28F016SV's dual read voltage enables the design of memory cards which can interchangeably be read/writen in 3.3V and 5.0V systems. Its x8/x16 architecture allows optimization of the memory-to-processor interface. The flexible block locking option enables bundling of executable application software in a Resident Flash Array or memory card. The 28F016SV is manufactured on Intel's 0.6 μm ETOX<sup>TM</sup> IV process technology.



290528-22

# 28F016SV 16-MBIT (1 MBIT x 16, 2 MBIT x 8) FlashFile™ MEMORY

| CONTENTS PA                                                        | AGE   | CONTENTS                                                            | PAGE               |
|--------------------------------------------------------------------|-------|---------------------------------------------------------------------|--------------------|
| 1.0 INTRODUCTION                                                   | 3-305 | 5.2 Capacitance                                                     | 3-324              |
| 1.1 Enhanced Features                                              | 3-305 | 5.3 DC Characteristics $(V_{CC} = 3.3V \pm 0.3V)$                   | 3-327              |
| 1.2 Product Overview                                               |       | 5.4 DC Characteristics                                              |                    |
| 2.0 DEVICE PINOUT                                                  |       | $(V_{CC} = 5.0V \pm 0.5V, 5.0V \pm 0.25V) \dots$                    | 3-330              |
| 2.1 Lead Descriptions                                              | 3-309 | 5.5 Timing Nomenclature                                             |                    |
| 3.0 MEMORY MAPS                                                    |       | 5.6 AC Characteristics—F Operations                                 | Read Only<br>3-334 |
| Map                                                                | 3-314 | 5.7 Power-Up and Reset                                              | Timings 3-339      |
| 4.0 BUS OPERATIONS, COMMANDS<br>AND STATUS REGISTER<br>DEFINITIONS | 015   | 5.8 AC Characteristics for<br>Controlled Command W<br>Operations    | /rite              |
| 4.1 Bus Operations for Word-Wide Mode (BYTE# = V <sub>IH</sub> )   |       | 5.9 AC Characteristics for<br>Controlled Command W<br>Operations    | /rite              |
| 4.2 Bus Operations for Byte-Wide Mode (BYTE# = V <sub>IL</sub> )   |       | 5.10 AC Characteristics for<br>Controlled Page Buffer<br>Operations | Write              |
| Command Bus Definitions                                            |       | 5.11 AC Characteristics for Controlled Page Buffer Operations       | Write 3-350        |
| 4.5 Compatible Status Register 3                                   |       | 5.12 Erase and Word/Byt<br>Performance                              | e Write<br>3-352   |
| 4.6 Global Status Register                                         |       | 6.0 MECHANICAL SPECIFIC                                             | CATIONS 3-354      |
| 4.7 Block Status Register                                          | 3-321 |                                                                     |                    |
| 4.8 Device Configuration Code                                      | 3-322 | DEVICE NOMENCLATURE<br>ORDERING INFORMATION                         |                    |
| 5.0 ELECTRICAL SPECIFICATIONS 3                                    |       | ADDITIONAL INFORMATIO                                               | <b>DN</b> 3-357    |
| 5.1 Absolute Maximum Ratings 3                                     | 3-323 | DATASHEET REVISION HIS                                              |                    |
|                                                                    |       | DATASHEET HEVISION HIS                                              | 310ni 3-356        |



#### 1.0 INTRODUCTION

The documentation of the Intel 28F016SV memory device includes this datasheet, a detailed user's manual, and a number of application notes and design tools, all of which are referenced at the end of this datasheet.

The datasheet is intended to give an overview of the chip feature-set and of the operating AC/DC specifications. The 16-Mbit Flash Product Family User's Manual provides complete descriptions of the user modes, system interface examples and detailed descriptions of all principles of operation. It also contains the full list of software algorithm flowcharts, and a brief section on compatibility with the Intel 28F008SA.

## 1.1 Enhanced Features

The 28F016SV is backwards compatible with the 28F016SA and offers the following enhancements:

- SmartVoltage Technology
  - Selectable 5.0V or 12.0V VPP
- V<sub>PP</sub> Level Bit in Block Status Register
- Internal 3/5V Detection Circuitry
- Additional RY/BY# Configuration
  - Pulse-On-Write/Erase
- Additional Upload Device Information Command Feedback
  - Device Proliferation Code
  - Device Configuration Code

### 1.2 Product Overview

The 28F016SV is a high-performance, 16-Mbit (16,777,216-bit) block erasable, nonvolatile random access memory, organized as either 1 Mword x 16 or 2 Mbyte x 8. The 28F016SV includes thirty-two 64-KB (65,536 byte) blocks or thirty-two 32-KW (32,768 word) blocks. A chip memory map is shown in Figure 4.

The implementation of a new architecture, with many enhanced features, will improve the device operating characteristics and result in greater product reliability and ease-of-use.

The 28F016SV incorporates SmartVoltage technology, providing  $V_{CC}$  operation at both 3.3V and 5.0V and program and erase capability at  $V_{PP}=12.0V$  or 5.0V. Operating at  $V_{CC}=3.3V$ , the 28F016SV consumes approximately one half the power consumption at 5.0V  $V_{CC}$ , while 5.0V  $V_{CC}$  provides highest read performance capability.  $V_{PP}=5.0V$  operation eliminates the need for a separate 12.0V converter, while  $V_{PP}=12.0V$  maximizes write/erase performance. In addition to the flexible program and erase voltages, the dedicated  $V_{PP}$  gives complete code protection with  $V_{PP} \leq V_{PPI}$  K.

Internal 3.3V or 5.0V  $V_{CC}$  detection automatically configures the device internally for optimized 3.3V or 5.0V Read/Write operation.

A Command User Interface (CUI) serves as the system interface between the microprocessor or microcontroller and the internal memory operation.

Internal Algorithm Automation allows Byte/Word Writes and Block Erase operations to be executed using a Two-Write command sequence to the CUI in the same way as the 28F008SA 8-Mbit FlashFile memory.

A super-set of commands has been added to the basic 28F008SA command-set to achieve higher write performance and provide additional capabilities. These new commands and features include:

- Page Buffer Writes to Flash
- · Command Queuing Capability
- Automatic Data Writes during Erase
- Software Locking of Memory Blocks
- Two-Byte Successive Writes in 8-bit Systems
- · Erase All Unlocked Blocks

Writing of memory data is performed in either byte or word increments typically within 6  $\mu$ s (12.0V V<sub>PP</sub>)—a 33% improvement over the 28F008SA. A Block Erase operation erases one of the 32 blocks in typically 0.6 sec (12.0V V<sub>PP</sub>), independent of the other blocks, which is about a 65% improvement over the 28F008SA.

Each block can be written and erased a minimum of 100,000 cycles. Systems can achieve one million Block Erase Cycles by providing wear-leveling algorithms and graceful block retirement. These techniques have already been employed in many flash file systems and hard disk drive designs.

### 28F016SV FlashFile™ Memory



The 28F016SV incorporates two Page Buffers of 256 bytes (128 words) each to allow page data writes. This feature can improve system write performance by up to 4.8 times over previous flash memory devices, which have no Page Buffers.

All operations are started by a sequence of Write commands to the device. Three Status Registers (described in detail later in this datasheet) and a RY/BY# output pin provide information on the progress of the requested operation.

While the 28F008SA requires an operation to complete before the next operation can be requested, the 28F016SV allows queuing of the next operation while the memory executes the current operation. This eliminates system overhead when writing several bytes in a row to the array or erasing several blocks at the same time. The 28F016SV can also perform Write operations to one block of memory while performing Erase of another block.

The 28F016SV provides selectable block locking to protect code or data such as Device Drivers, PCMCIA card information, ROM-Executable O/S or Application Code. Each block has an associated nonvolatile lock-bit which determines the lock status of the block. In addition, the 28F016SV has a master Write Protect pin (WP#) which prevents any modifications to memory blocks whose lock-bits are set.

The 28F016SV contains three types of Status Registers to accomplish various functions:

- A Compatible Status Register (CSR) which is 100% compatible with the 28F008SA FlashFile memory Status Register. The CSR, when used alone, provides a straightforward upgrade capability to the 28F016SV from a 28F008SA-based design.
- A Global Status Register (GSR) which informs the system of command Queue status, Page Buffer status, and overall Write State Machine (WSM) status.
- 32 Block Status Registers (BSRs) which provide block-specific status information such as the block lock-bit status.

The GSR and BSR memory maps for Byte-Wide and Word-Wide modes are shown in Figures 5 and 6.

The 28F016SV incorporates an open drain RY/BY# output pin. This feature allows the user to OR-tie many RY/BY# pins together in a multiple memory configuration such as a Resident Flash Array.

Other configurations of the RY/BY# pin are enabled via special CUI commands and are described in detail in the 16-Mbit Flash Product Family User's Manual.

The 28F016SV's enhanced Upload Device Information command provides access to additional information that the 28F016SA previously did not offer. This command uploads the Device Revision Number, Device Proliferation Code and Device Configuration Code to the page buffer. The Device Proliferation Code for the 28F016SV is 01H, and the Device Configuration Code identifies the current RY/BY# configuration. Section 4.4 documents the exact page buffer address locations for all uploaded information. A subsequent Page Buffer Swap and Page Buffer Read command sequence is necessary to read the correct device information.

The 28F016SV also incorporates a dual chip-enable function with two input pins,  $\text{CE}_0\#$  and  $\text{CE}_1\#$ . These pins have exactly the same functionality as the regular chip-enable pin,  $\text{CE}_{+}\#$ , on the 28F008SA. For minimum chip designs,  $\text{CE}_1\#$  may be tied to ground and system logic may use  $\text{CE}_0\#$  as the chip enable input. The 28F016SV uses the logical combination of these two signals to enable or disable the entire chip. Both  $\text{CE}_0\#$  and  $\text{CE}_1\#$  must be active low to enable the device. If either one becomes inactive, the chip will be disabled. This feature, along with the open drain RY/BY# pin, allows the system designer to reduce the number of control pins used in a large array of 16-Mbit devices.

The BYTE# pin allows either x8 or x16 read/writes to the 28F016SV. BYTE# at logic low selects 8-bit mode with address  $A_0$  selecting between the low byte and high byte. On the other hand, BYTE# at logic high enables 16-bit operation with address  $A_1$  becoming the lowest order address, and address  $A_0$  is not used (don't care). A device block diagram is shown in Figure 1.

The 28F016SV is specified for a maximum access time of 65 ns ( $t_{ACC}$ ) at 5.0V operation (4.75V to 5.25V) over the commercial temperature range (0°C to +70°C). A corresponding maximum access time of 75 ns at 3.3V (3.0V to 3.6V and 0°C to +70°C) is achieved for reduced power consumption applications.

The 28F016SV incorporates an Automatic Power Saving (APS) feature, which substantially reduces the active current when the device is in static mode of operation (addresses not switching). In APS mode, the typical  $I_{CC}$  current is 1 mA at 5.0V (3.0 mA at 3.3V).

A deep power-down mode of operation is invoked when the RP# (called PWD# on the 28F008SA) pin transitions low. This mode brings the device power consumption to less than 2.0  $\mu$ A, typically, and provides additional write protection by acting as a device reset pin during power transitions. A reset time of 300 ns (5.0V V<sub>CC</sub> operation) is required from RP# switching high until outputs are again valid. In the Deep Power-Down state, the WSM is reset (any current operation will abort) and the CSR, GSR and BSR registers are cleared.

A CMOS standby mode of operation is enabled when either CE $_0\#$  or CE $_1\#$  transitions high and RP# stays high with all input control pins at CMOS levels. In this mode, the device typically draws an lCC standby current of 70  $\mu$ A at 5V VCC.

The 28F016SV will be available in 56-Lead, 1.2 mm thick, 14 mm x 20 mm TSOP and 56-Lead, 1.8 mm thick, 16 mm x 23.7 SSOP Type I packages. The form factor and pinout of these two packages allow for very high board layout densities.

#### 2.0 DEVICE PINOUT

The 28F016SV 56-Lead TSOP and 56-Lead SSOP Type I pinout configurations are shown in Figures 2 and 3.

Ş





Figure 1. 28F016SV Block Diagram
Architectural Evolution Includes SmartVoltage Technology,
Page Buffers, Queue Registers and Extended Registers



## 2.1 Lead Descriptions

| Symbol                               | Туре             | Name and Function                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub>                       | INPUT            | BYTE-SELECT ADDRESS: Selects between high and low byte when device is in x8 mode. This address is latched in x8 Data Writes. Not used in x16 mode (i.e. the A <sub>0</sub> input buffer is turned off when BYTE# is high).                                                                                                                                                              |
| A <sub>1</sub> -A <sub>15</sub>      | INPUT            | <b>WORD-SELECT ADDRESSES:</b> Select a word within one 64-Kbyte block. $A_{6-15}$ selects 1 of 1024 rows, and $A_{1-5}$ selects 16 of 512 columns. These addresses are latched during Data Writes.                                                                                                                                                                                      |
| A <sub>16</sub> -A <sub>20</sub>     | INPUT            | <b>BLOCK-SELECT ADDRESSES:</b> Select 1 of 32 Erase blocks. These addresses are latched during Data Writes, Erase and Lock-Block operations.                                                                                                                                                                                                                                            |
| DQ <sub>Q</sub> -DQ <sub>7</sub>     | INPUT/<br>OUTPUT | LOW-BYTE DATA BUS: Inputs data and commands during CUI write cycles. Outputs array, buffer, identifier or status data in the appropriate read mode. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                                                   |
| DQ <sub>8</sub> -DQ <sub>15</sub>    | INPUT/<br>OUTPUT | <b>HIGH-BYTE DATA BUS:</b> Inputs data during x16 Data-Write operations. Outputs array, buffer or identifier data in the appropriate read mode; not used for Status Register reads. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                   |
| CE <sub>0</sub> #, CE <sub>1</sub> # | INPUT            | CHIP ENABLE INPUTS: Activate the device's control logic, input buffers, decoders and sense amplifiers. With either CE <sub>0</sub> # or CE <sub>1</sub> # high, the device is de-selected and power consumption reduces to standby levels upon completion of any current Data-Write or Erase operations. Both CE <sub>0</sub> # and CE <sub>1</sub> # must be low to select the device. |
|                                      |                  | All timing specifications are the same for both signals. Device Selection occurs with the latter falling edge of $CE_0\#$ or $CE_1\#$ . The first rising edge of $CE_0\#$ or $CE_1\#$ disables the device.                                                                                                                                                                              |
| RP#                                  | INPUT            | RESET/POWER-DOWN: RP# low places the device in a Deep Power-Down state. All circuits that consume static power, even those circuits enabled in standby mode, are turned off. When returning from Deep Power-Down, a recovery time of tpHQV is required to allow these circuits to power-up.                                                                                             |
|                                      |                  | When RP# goes low, any current or pending WSM operation(s) are terminated, and the device is reset. All Status Registers return to ready (with all status flags cleared).                                                                                                                                                                                                               |
|                                      |                  | Exit from Deep Power-Down places the device in read array mode.                                                                                                                                                                                                                                                                                                                         |
| OE#                                  | INPUT            | <b>OUTPUT ENABLE:</b> Gates device data through the output buffers when low. The outputs float to tri-state off when OE# is high.                                                                                                                                                                                                                                                       |
|                                      |                  | NOTE:  CE <sub>x</sub> # overrides OE#, and OE# overrides WE#.                                                                                                                                                                                                                                                                                                                          |
| WE#                                  | INPUT            | WRITE ENABLE: Controls access to the CUI, Page Buffers, Data Queue Registers and Address Queue Latches. WE# is active low, and latches both address and data (command or array) on its rising edge. Page Buffer addresses are latched on the falling edge of WE#.                                                                                                                       |



# 2.1 Lead Descriptions (Continued)

| Symbol          | Туре                 | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RY/BY#          | OPEN DRAIN<br>OUTPUT | READY/BUSY: Indicates status of the internal WSM. When low, it indicates that the WSM is busy performing an operation. RY/BY# floating indicates that the WSM is ready for new operations (or WSM has completed all pending operations), or Erase is Suspended, or the device is in deep power-down mode. This output is always active (i.e., not floated to tri-state off when OE# or CE <sub>0</sub> #, CE <sub>1</sub> # are high), except if a RY/BY# Pin Disable command is issued. |
| WP#             | INPUT                | WRITE PROTECT: Erase blocks can be locked by writing a nonvolatile lock-bit for each block. When WP# is low, those locked blocks as reflected by the Block-Lock Status bits (BSR.6), are protected from inadvertent Data Writes or Erases. When WP# is high, all blocks can be written or erased regardless of the state of the lock-bits. The WP# input buffer is disabled when RP# transitions low (deep power-down mode).                                                             |
| BYTE#           | INPUT                | <b>BYTE ENABLE:</b> BYTE# low places the device in x8 mode. All data is then input or output on $DQ_{0-7}$ , and $DQ_{8-15}$ float. Address $A_0$ selects between the high and low byte. BYTE# high places the device in x16 mode, and turns off the $A_0$ input buffer. Address $A_1$ , then becomes the lowest order address.                                                                                                                                                          |
| V <sub>PP</sub> | SUPPLY               | WRITE/ERASE POWER SUPPLY (12.0V $\pm$ 0.6V, 5.0V $\pm$ 0.5V): For erasing memory array blocks or writing words/bytes/pages into the flash array. Vpp = 5.0V $\pm$ 0.5V eliminates the need for a 12V converter, while connection to 12.0V $\pm$ 0.6V maximizes Write/Erase Performance. Write and Erase attempts are inhibited with Vpp at or below 1.5V.                                                                                                                                |
|                 |                      | Write and Erase attempts with $V_{PP}$ between 1.5V and 4.5V, between 5.5V and 11.4V, and above 12.6V produce spurious results and should not be attempted.                                                                                                                                                                                                                                                                                                                              |
| V <sub>CC</sub> | SUPPLY               | <b>DEVICE POWER SUPPLY (3.3V</b> $\pm$ <b>0.3V, 5.0V</b> $\pm$ <b>0.5V, 5.0</b> $\pm$ <b>0.25V):</b> Internal detection configures the device for 3.3V or 5.0V operation. To switch 3.3V to 5.0V (or vice versa), first ramp V <sub>CC</sub> down to GND, and then power to the new V <sub>CC</sub> voltage.                                                                                                                                                                             |
|                 |                      | Do not leave any power pins floating.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| GND             | SUPPLY               | GROUND FOR ALL INTERNAL CIRCUITRY: Do not leave any ground pins floating.                                                                                                                                                                                                                                                                                                                                                                                                                |
| NC              |                      | NO CONNECT: No internal connection to die, lead may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                          |





Figure 2. 28F016SV 56-Lead TSOP Pinout Configuration Shows Compatibility with 28F016SA/28F032SA





Figure 3. 56-Lead SSOP Pinout Configuration



## 3.0 MEMORY MAPS

|                |                     |     | ۸                  |                   |       | 4        |
|----------------|---------------------|-----|--------------------|-------------------|-------|----------|
| 20-0]<br>FFFFF | C4 Khista Diask     | -   | A[20-1]<br>  FFFFF | OO IG and Display | - 41  |          |
| F0000<br>FFFF  | 64-Kbyte Block      | 31  | F8000<br>F7FFF     | 32-Kword Block    |       |          |
| E0000          | 64-Kbyte Block      | 30  | F0000<br>EFFFF     | 32-Kword Block    |       |          |
| COCCO          | 64-Kbyte Block      | 29  | E8000              | 32-Kword Block    |       |          |
| 20000          | 64-Kbyte Block      | 28  | E7FFF<br>E0000     | 32-Kword Block    | 28    |          |
| BOOOD          | 64-Kbyte Block      | 27  | DFFFF<br>D8000     | 32-Kword Block    | 27    |          |
| A0000          | 64-Kbyte Block      | 26  | D7FFF<br>D0000     | 32-Kword Block    | 26    |          |
| 90000          | 64-Kbyte Block      | 25  | CFFFF<br>C8000     | 32-Kword Block    | 25    |          |
| 8FFFF<br>80000 | 64-Kbyte Block      | 24  | C7FFF<br>C00000    | 32-Kword Block    | 24    |          |
| 7FFFF<br>70000 | 64-Kbyte Block      | 23  | BFFFF<br>B8000     | 32-Kword Block    | 23    |          |
| 60000          | 64-Kbyte Block      | 22  | B7FFF<br>B0000     | 32-Kword Block    | 22    |          |
| 50000          | 64-Kbyte Block      | 21  | A8FFF<br>A8000     | 32-Kword Block    | 21    |          |
| 40000          | 64-Kbyte Block      | 20  | A7FFF<br>A0000     | 32-Kword Block    | 20    |          |
| 30000          | 64-Kbyte Block      | 19  | 9FFFF<br>98000     | 32-Kword Block    | 19    |          |
| 20000          | 64-Kbyte Block      | 18  | 97FFF<br>90000     | 32-Kword Block    | 18    |          |
| 10000          | 64-Kbyte Block      | 17  | 8FFFF<br>88000     | 32-Kword Block    | 17    |          |
| 00000          | 64-Kbyte Block      | 16  | 87FFF<br>80000     | 32-Kword Block    | 16    |          |
| FFFF<br>-0000  | 64-Kbyte Block      | 15  | 7FFFF<br>78000     | 32-Kword Block    | 15    |          |
| FFFF<br>E0000  | 64-Kbyte Block      | 14  | 77FFF<br>70000     | 32-Kword Block    | 14    |          |
| OFFFF<br>COOCO | 64-Kbyte Block      | 13  | 6FFFF<br>68000     | 32-Kword Block    | 13    |          |
| C0000          | 64-Kbyte Block      | 12  | 67FFF<br>60000     | 32-Kword Block    | 12    |          |
| 3FFFF<br>30000 | 64-Kbyte Block      | 11  | 5FFFF<br>58000     | 32-Kword Block    | 11    |          |
| A0000          | 64-Kbyte Block      | 10  | 57FFF<br>50000     | 32-Kword Block    | 10    |          |
| 90000          | 64-Kbyte Block      | 9   | 4FFFF<br>48000     | 32-Kword Block    | 9     |          |
| BFFFF<br>80000 | 64-Kbyte Block      | 8   | 47FFF<br>40000     | 32-Kword Block    | . 8   |          |
| 70000<br>70000 | 64-Kbyte Block      | 7   | 3FFFF<br>38000     | 32-Kword Block    | 7     |          |
| 60000          | 64-Kbyte Block      | 6   | 37FFF<br>30000     | 32-Kword Block    | 6     |          |
| FFFF           | 64-Kbyte Block      | 5   | 2FFFF              | 32-Kword Block    | . 5   |          |
| 50000<br>1FFFF | 64-Kbyte Block      | 4   | 28000<br>27FFF     | 32-Kword Block    | 4     |          |
| 40000<br>FFFF  | 64-Kbyte Block      | 3   | 20000<br>1FFFF     | 32-Kword Block    | 3     |          |
| 30000<br>2FFFF | 64-Kbyte Block      | 2   | 18000<br>17FFF     | 32-Kword Block    |       |          |
| 20000          | 64-Kbyte Block      | 1   | 10000<br>0FFFF     | 32-Kword Block    |       |          |
| 10000          | 64-Kbyte Block      | 0   | 08000<br>07FFF     | 32-Kword Block    |       |          |
| <br>           | syte-Wide (x8) Mo   |     |                    | Vord-Wide (x16)   |       |          |
| Ь              | yte-vvide (AU) IVIC | ,ue | V                  | VOIG-VVIGE (X IO) | wiode | 290528-4 |

Figure 4. 28F016SV Memory Maps (Byte-Wide and Word-Wide Modes)



## 3.1 Extended Status Registers Memory Map



Figure 5. Extended Status Register Memory Map (Byte-Wide Mode)



Figure 6. Extended Status Register Memory Map (Word-Wide Mode)



## 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS

## 4.1 Bus Operations for Word-Wide Mode (BYTE $\# = V_{IH}$ )

|                 |       |                 |                                                       |                                                       |                 | 11 1/           |                 |                    |                 |
|-----------------|-------|-----------------|-------------------------------------------------------|-------------------------------------------------------|-----------------|-----------------|-----------------|--------------------|-----------------|
| Mode            | Notes | RP#             | CE <sub>1</sub> #                                     | CE <sub>0</sub> #                                     | OE#             | WE#             | A <sub>1</sub>  | DQ <sub>0-15</sub> | RY/BY#          |
| Read            | 1,2,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | VIL             | VIH             | Х               | D <sub>OUT</sub>   | Х               |
| Output Disable  | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | High Z             | Х               |
| Standby         | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IH</sub> | Х               | Х               | х               | High Z             | X               |
| Deep Power-Down | 1,3   | V <sub>IL</sub> | Х                                                     | Х                                                     | Х               | Х               | Х               | High Z             | V <sub>OH</sub> |
| Manufacturer ID | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 0089H              | V <sub>OH</sub> |
| Device ID       | 4,8   | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | VIL             | V <sub>IH</sub> | V <sub>IH</sub> | 66A0H              | V <sub>OH</sub> |
| Write           | 1,5,6 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IL</sub> | X               | D <sub>IN</sub>    | Х               |

## 4.2 Bus Operations for Byte-Wide Mode (BYTE $\# = V_{IL}$ )

|                 |       | - 1 km/         |                                                       |                                                       |                 |                 |                 |                   |                 |
|-----------------|-------|-----------------|-------------------------------------------------------|-------------------------------------------------------|-----------------|-----------------|-----------------|-------------------|-----------------|
| Mode            | Notes | RP#             | CE <sub>1</sub> #                                     | CE <sub>0</sub> #                                     | OE#             | WE#             | A <sub>0</sub>  | DQ <sub>0_7</sub> | RY/BY#          |
| Read            | 1,2,7 | V <sub>IH</sub> | VIL                                                   | V <sub>IL</sub>                                       | VIL             | V <sub>IH</sub> | Х               | D <sub>OUT</sub>  | Х               |
| Output Disable  | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | VIL                                                   | VIH             | V <sub>IH</sub> | X               | High Z            | Х               |
| Standby         | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IH</sub> | X               | Х               | ×               | High Z            | Х               |
| Deep Power-Down | 1,3   | ٧ <sub>IL</sub> | Х                                                     | Х                                                     | X               | Х               | Х               | High Z            | V <sub>OH</sub> |
| Manufacturer ID | 4     | V <sub>IH</sub> | VIL                                                   | VIL                                                   | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 89H               | V <sub>OH</sub> |
| Device ID       | 4,8   | V <sub>IH</sub> | V <sub>IL</sub>                                       | VIL                                                   | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | A0H               | V <sub>OH</sub> |
| Write           | 1,5,6 | V <sub>IH</sub> | VIL                                                   | VIL                                                   | V <sub>IH</sub> | V <sub>IL</sub> | Х               | D <sub>IN</sub>   | Х               |

#### NOTES:

- 1. X can be VIH or VIL for address or control pins except for RY/BY#, which is either VOL or VOH.
- RY/BY# output is open drain. When the WSM is ready, Erase is suspended or the device is in deep power-down mode.
   RY/BY# will be at V<sub>OH</sub> if it is tied to V<sub>CC</sub> through a resistor. RY/BY# at V<sub>OH</sub> is independent of OE# while a WSM operation is in progress.
- 3. RP# at GND ± 0.2V ensures the lowest deep power-down current.
- 4. A<sub>0</sub> and A<sub>1</sub> at V<sub>IL</sub> provide device manufacturer codes in x8 and x16 modes respectively. A<sub>0</sub> and A<sub>1</sub> at V<sub>IH</sub> provide device ID codes in x8 and x16 modes respectively. All other addresses are set to zero.
- Commands for Erase, Data Write, or Lock-Block operations can only be completed successfully when V<sub>PP</sub> = V<sub>PPH2</sub>.
- While the WSM is running, RY/BY# in level-mode (default) stays at V<sub>OL</sub> until all operations are complete. RY/BY# goes
  to V<sub>OH</sub> when the WSM is not busy or in erase suspend mode.
- 7. RY/BY# may be at V<sub>OL</sub> while the WSM is busy performing various operations. For example, a Status Register read during a Write operation.
- The 28F016SV shares an identical device identifier (66A0H in word-wide mode, A0H in byte-wide mode) with the 28F016SA. See application note AP-393 for software and hardware techniques to differentiate between the 28F016SV and 28F016SA.



## 4.3 28F008SA—Compatible Mode Command Bus Definitions

| Command                         | Notes  | Fir   | st Bus Cy | cle  | Second Bus Cycle |      |      |
|---------------------------------|--------|-------|-----------|------|------------------|------|------|
| <u> </u>                        | 110100 | Oper  | Addr      | Data | Oper             | Addr | Data |
| Read Array                      |        | Write | Х         | FFH  | Read             | AA   | AD   |
| Intelligent Identifier          | 1      | Write | Х         | 90H  | Read             | , IA | ID   |
| Read Compatible Status Register | 2      | Write | Х         | 70H  | Read             | Х    | CSRD |
| Clear Status Register           | 3      | Write | Х         | 50H  |                  |      |      |
| Word/Byte Write                 |        | Write | Х         | 40H  | Write            | WA   | WD   |
| Alternate Word/Byte Write       |        | Write | · X       | 10H  | Write            | WA   | WD   |
| Block Erase/Confirm             |        | Write | Х         | 20H  | Write            | BÁ   | D0H  |
| Erase Suspend/Resume            |        | Write | X         | вон  | Write            | Х    | D0H  |

|  | u |  |  |
|--|---|--|--|
|  |   |  |  |

DATA

AA = Array Address

AD = Array Data

BA = Block Address IA = Identifier Address CSRD = CSR Data ID = Identifier Data

WA = Write Address

WD = Write Data

X = Don't Care

#### NOTES:

1. Following the Intelligent Identifier command, two Read operations access the manufacturer and device signature codes.

2. The CSR is automatically available after device enters Data Write, Erase, or Suspend operations.

Clears CSR.3, CSR.4 and CSR.5. Also clears GSR.5 and all BSR.5, BSR.4 and BSR.2 bits. See Status Register definitions.



## 4.4 28F016SV—Performance Enhancement Command Bus Definitions

| Command                              | Mode | Notes    | First | Bus C | ycle | Sec   | ond Bu          | s Cycle      | Thi   | rd Bus | Cycle   |
|--------------------------------------|------|----------|-------|-------|------|-------|-----------------|--------------|-------|--------|---------|
| Command                              | Mode | Notes    | Oper  | Addr  | Data | Oper  | Addr            | Data         | Oper  | Addr   | Data    |
| Read Extended<br>Status Register     |      | 1        | Write | Х     | 71H  | Read  | RA              | GSRD<br>BSRD |       |        |         |
| Page Buffer Swap                     |      | 7        | Write | Х     | 72H  |       |                 |              |       |        |         |
| Read Page Buffer                     |      |          | Write | Х     | 75H  | Read  | PA              | PD           |       |        |         |
| Single Load to<br>Page Buffer        |      |          | Write | ×     | 74H  | Write | PA <sub>.</sub> | PD           |       |        |         |
| Sequential Load to                   | x8:  | 4,6,10   | Write | Х     | E0H  | Write | Х               | BCL          | Write | Х      | всн     |
| Page Buffer                          | x16  | 4,5,6,10 | Write | Х     | E0H  | Write | Х               | WCL          | Write | X      | WCH     |
| Page Buffer Write                    | х8   | 3,4,9,10 | Write | Х     | 0CH  | Write | A <sub>0</sub>  | BC(L,H)      | Write | WA     | BC(H,L) |
| to Flash                             | x16  | 4,5,10   | Write | Х     | 0CH  | Write | Х               | WCL          | Write | WA     | WCH     |
| Two-Byte Write                       | х8   | 3        | Write | Х     | FBH  | Write | A <sub>0</sub>  | WD(L,H)      | Write | WA     | WD(H,L) |
| Lock Block/Confirm                   |      |          | Write | X.    | 77H  | Write | ВА              | D0H          |       |        |         |
| Upload Status<br>Bits/Confirm        |      | 2        | Write | Х     | 97H  | Write | Х               | D0H          |       |        |         |
| Upload Device<br>Information/Confirm |      | 11       | Write | ×     | 99H  | Write | X               | D0H          |       |        |         |
| Erase All Unlocked<br>Blocks/Confirm |      |          | Write | X     | A7H  | Write | ×               | D0H          |       |        |         |
| RY/BY# Enable to<br>Level-Mode       |      | 8        | Write | Х     | 96H  | Write | ×               | 01H          |       |        |         |
| RY/BY#<br>Pulse-On-Write             |      | 8        | Write | Х     | 96H  | Write | X               | 02H          |       |        |         |
| RY/BY#<br>Pulse-On-Erase             |      | 8        | Write | ×     | 96H  | Write | ×               | 03H          |       |        |         |
| RY/BY# Disable                       |      | 8        | Write | Х     | 96H  | Write | Х               | 04H          |       |        |         |
| RY/BY# Pulse-On-<br>Write/Erase      |      | 8        | Write | ×     | 96H  | Write | ×               | 05H          |       |        |         |
| Sleep                                |      |          | Write | Х     | F0H  |       |                 |              |       |        |         |
| Abort                                |      |          | Write | Х     | 80H  |       |                 |              |       |        |         |

### **ADDRESS**

BA = Block Address

PA = Page Buffer Address

RA = Extended Register Address

WA = Write Address

X = Don't Care

### DATA

AD = Array Data

PD = Page Buffer Data

BSRD = BSR Data

GSRD = GSR Data

WC (L,H) = Word Count (Low, High)

BC(L,H) = Byte Count(Low, High)

WD (L,H) = Write Data (Low, High)

### 28F016SV FlashFile™ Memory



#### NOTES:

- 1. RA can be the GSR address or any BSR address. See Figures 5 and 6 for Extended Status Register memory maps.
- Upon device power-up, all BSR lock-bits come up locked. The Upload Status Bits command must be written to reflect the actual lock-bit status.
- A<sub>0</sub> is automatically complemented to load second byte of data. BYTE# must be at V<sub>IL</sub>. A<sub>0</sub> value determines which WD/BC is supplied first: A<sub>0</sub> = 0 looks at the WDL/BCL, A<sub>0</sub> = 1 looks at the WDH/BCH.
   BCH/WCH must be at 00H for this product because of the 256-byte (128-word) Page Buffer size, and to avoid writing
- 4. BCH/WCH must be at 00H for this product because of the 256-byte (128-word) Page Buffer size, and to avoid writing the Page Buffer contents to more than one 256-byte segment within an array block. They are simply shown for future Page Buffer expandability.
- 5. In x16 mode, only the lower byte  $DQ_{0-7}$  is used for WCL and WCH. The upper byte  $DQ_{8-15}$  is a don't care.
- 6. PA and PD (whose count is given in cycles 2 and 3) are supplied starting in the fourth cycle, which is not shown.
- 7. This command allows the user to swap between available Page Buffers (0 or 1).
- 8. These commands reconfigure RY/BY# output to one of three pulse-modes or enable and disable the RY/BY# function.
- 9. Write address, WA, is the Destination address in the flash array which must match the Source address in the Page Buffer. Refer to the 16-Mbit Flash Product Family User's Manual.
- 10. BCL = 00H corresponds to a byte count of 1. Similarly, WCL = 00H corresponds to a word count of 1.
- 11. After writing the Upload Device Information command and the Confirm command, the following information is output at Page Buffer addresses specified below:

| Address                              | Information                     |
|--------------------------------------|---------------------------------|
| 06H, 07H (Byte Mode)                 | Device Revision Number          |
| 03H (Word Mode)                      | Device Revision Number          |
| 1EH (Byte Mode)                      | Device Configuration Code       |
| 0FH (DQ <sub>0-7</sub> )(Word Mode)  | Device Configuration Code       |
| 1FH (Byte Mode)                      | Device Proliferation Code (01H) |
| 0FH (DQ <sub>8-15</sub> )(Word Mode) | Device Proliferation Code (01H) |
|                                      |                                 |

A page buffer swap followed by a page buffer read sequence is necessary to access this information. The contents of all other Page Buffer locations, after the Upload Device Information command is written, are reserved for future implementation by Intel Corporation. See Section 4.8 for a description of the Device Configuration Code. This code also corresponds to data written to the 28F016SV after writing the RY/BY# Reconfiguration command.



## 4.5 Compatible Status Register

| WSMS | ESS | ES | DWS | VPPS | R | R | R |
|------|-----|----|-----|------|---|---|---|
| 7    | 6   | 5  | 4   | 3    | 2 | 1 | 0 |

#### NOTES:

1 = Readv

0 = Busv

CSR.7 = WRITE STATE MACHINE STATUS RY/BY # output or WSMS bit must be checked to determine completion of an operation (Erase, Erase Suspend, or Data Write) before the appropriate Status bit (ESS, ES or DWS) is checked for success.

CSR.6 = ERASE-SUSPEND STATUS

1 = Erase Suspended

0 = Erase In Progress/Completed

CSR.5 = ERASE STATUS

1 = Error In Block Erasure

0 = Successful Block Erase

CSR.4 = DATA-WRITE STATUS

1 = Error in Data Write

0 = Data Write Successful

CSR.3 = V<sub>PP</sub> STATUS

1 = V<sub>PP</sub> Error Detect, Operation Abort

 $0 = V_{PP} OK$ 

If DWS and ES are set to "1" during an erase attempt, an improper command sequence was entered. Clear the CSR and attempt the operation again.

The VPPS bit, unlike an A/D converter, does not provide continuous indication of VPP level. The WSM interrogates V<sub>PP</sub>'s level only after the Data Write or Erase command sequences have been entered, and informs the system if VPP has not been switched on. VPPS is not guaranteed to report accurate feedback between VPPLK(max) and VPPH1(min), between VPPH1(max) and VPPH2(min) and above V<sub>PPH2</sub>(max).

#### CSR.2-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the CSR.



4.6 Global Status Register

| WSMS | oss | DOS | DSS | QS | PBAS | PBS | PBSS |
|------|-----|-----|-----|----|------|-----|------|
| 7    | 6   | 5   | 4   | 3  | 2    | . 1 | 0    |

| GSR.7 = WRITE STATE MACHINE STATUS  1 = Ready 0 = Busy                                                     | NOTES:  [1] RY/BY# output or WSMS bit must be checked to determine completion of an operation (Block Lock, Suspend, any RY/BY# reconfiguration, Upload Status Bits, Erase or Data Write) before the appropriate Status bit (OSS or DOS) is checked for success. |
|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GSR.6 = OPERATION SUSPEND STATUS  1 = Operation Suspended  0 = Operation in Progress/ Completed            |                                                                                                                                                                                                                                                                 |
| GSR.5 = DEVICE OPERATION STATUS  1 = Operation Unsuccessful  0 = Operation Successful or Currently Running |                                                                                                                                                                                                                                                                 |
| GSR.4 = DEVICE SLEEP STATUS  1 = Device in Sleep  0 = Device Not in Sleep                                  |                                                                                                                                                                                                                                                                 |
| MATRIX <u>5/4</u> 0 0 = Operation Successful or Currently Running                                          | If operation currently running, then $GSR.7 = 0$ .                                                                                                                                                                                                              |
| 0 1 = Device in Sleep mode or<br>Pending Sleep<br>1 0 = Operation Unsuccessful                             | If device pending sleep, then GSR.7 = 0.                                                                                                                                                                                                                        |
| 1 1 = Operation Unsuccessful or<br>Aborted                                                                 | Operation aborted: Unsuccessful due to Abort command.                                                                                                                                                                                                           |
| GSR.3 = QUEUE STATUS 1 = Queue Full 0 = Queue Available                                                    |                                                                                                                                                                                                                                                                 |
| GSR.2 = PAGE BUFFER AVAILABLE STATUS  1 = One or Two Page Buffers  Available  0 = No Page Buffer Available | The device contains two Page Buffers.                                                                                                                                                                                                                           |
| GSR.1 = PAGE BUFFER STATUS  1 = Selected Page Buffer Ready  0 = Selected Page Buffer Busy                  | Selected Page Buffer is currently busy with WSM operation                                                                                                                                                                                                       |
| GSR.0 = PAGE BUFFER SELECT STATUS  1 = Page Buffer 1 Selected  0 = Page Buffer 0 Selected                  |                                                                                                                                                                                                                                                                 |

#### NOTE

When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



### 4.7 Block Status Register

| BS | BLS | BOS | BOAS | QS | VPPS | VPPL | R |
|----|-----|-----|------|----|------|------|---|
| 7  | 6 , | 5   | 4    | 3  | 2    | 1    | 0 |

# BSR.7 = BLOCK STATUS

1 = Ready

0 = Busv

#### NOTES:

[1] RY/BY# output or BS bit must be checked to determine completion of an operation (Block Lock, Suspend, Erase or Data Write) before the appropriate Status bits (BOS or BLS) is checked for success.

#### BSR.6 = BLOCK LOCK STATUS

1 = Block Unlocked for Write/Erase

0 = Block Locked for Write/Erase

#### BSR.5 = BLOCK OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

#### BSR.4 = BLOCK OPERATION ABORT STATUS

1 = Operation Aborted

0 = Operation Not Aborted

The BOAS bit will not be set until BSR.7 = 1.

#### MATRIX 5/4

0 0 = Operation Successful or Currently Running

0 1 = Not a Valid Combination

1 0 = Operation Unsuccessful

11 = Operation Aborted

Operation halted via Abort command.

#### BSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

#### BSR.2 = Vpp STATUS

1 = V<sub>PP</sub> Error Detect, Operation Abort

 $0 = V_{PP} OK$ 

# $BSR.1 = V_{PP} LEVEL$

 $1 = V_{PP}$  Detected at 5.0V  $\pm$  10%

 $0 = V_{PP}$  Detected at 12.0V  $\pm$  5%

BSR.1 is not guaranteed to report accurate feedback between the V<sub>PPH1</sub> and V<sub>PPH2</sub> voltage ranges. Writes and erases with V<sub>PP</sub> between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub> (min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min), and above V<sub>PPH2</sub>(max) produce spurious results and should not be attempted.

BSR.1 was a RESERVED bit on the 28F016SA.

#### BSR.0 = RESERVED FOR FUTURE ENHANCEMENTS

This bit is reserved for future use; mask it out when polling the BSRs.

#### NOTE:

 When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



4.8 Device Configuration Code

| R | R | R | R | R | RB2 | RB1 | RB0 |
|---|---|---|---|---|-----|-----|-----|
| 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |

#### NOTES:

be used.

Undocumented combinations of RB2-RB0 are reserved by Intel Corporation for future implementations and should not

DCC.2-DCC.0 = RY/BY# CONFIGURATION

(RB2-RB0)

001 = Level Mode (Default)

010 = Pulse-On-Write

011 = Pulse-On-Erase

100 = RY/BY# Disabled 101 = Pulse-On-Write/

Erase

DCC.7-DCC.3 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when reading the Device Configuration Code. Set these bits to "0" when writing the desired RY/BY# configuration to the device.



#### 5.0 ELECTRICAL SPECIFICATIONS

# 5.1 Absolute Maximum Ratings\*

Temperature Under Bias ...........0°C to +80°C Storage Temperature .......-65°C to +125°C

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

 $V_{CC} = 3.3V \pm 0.3V \text{ Systems}(5)$ 

| Symbol          | Parameter                                                            | Notes | Min  | Max                      | Units | Test Conditions     |
|-----------------|----------------------------------------------------------------------|-------|------|--------------------------|-------|---------------------|
| T <sub>A</sub>  | Operating Temperature, Commercial                                    | 1     | 0    | 70                       | С     | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> withRespect to GND                                   | 2     | -0.2 | 7.0                      | V     |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                   | 2,3   | -0.2 | 14.0                     | V     |                     |
| V               | Voltage on any Pin (except $V_{CC}$ , $V_{PP}$ ) with Respect to GND | 2     | -0.5 | V <sub>CC</sub><br>+ 0.5 | ٧     |                     |
| 1               | Current into any Non-Supply Pin                                      |       |      | ±30                      | mA    |                     |
| lout            | Output Short Circuit Current                                         | 4     |      | 100                      | mA    |                     |

#### $V_{CC} = 5.0V \pm 0.5V$ , 5.0V $\pm 0.25V$ Systems(5,6)

| Symbol          | Parameter                                                            | Notes | Min  | Max  | Units | Test Conditions     |
|-----------------|----------------------------------------------------------------------|-------|------|------|-------|---------------------|
| TA              | Operating Temperature, Commercial                                    | 1     | 0    | 70   | °C    | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                  | 2     | -0.2 | 7.0  | ٧     |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                   | 2,3   | -0.2 | 14.0 | ٧     |                     |
| ٧               | Voltage on any Pin (except $V_{CC}$ , $V_{PP}$ ) with Respect to GND | 2     | -2.0 | 7.0  | ٧     |                     |
| l ·             | Current into any Non-Supply Pin                                      |       |      | ± 30 | mA    |                     |
| lout            | Output Short Circuit Current                                         | 4     |      | 100  | mA    | !                   |

- 1. Operating temperature is for commercial product defined by this specification.
- Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is V<sub>CC</sub> + 0.5V which, during transitions, may overshoot to V<sub>CC</sub> + 2.0V for periods <20 ns.</li>
- 3. Maximum DC voltage on V<sub>PP</sub> may overshoot to +14.0V for periods <20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.
- 6. 5% V<sub>CC</sub> specifications refer to the 28F016SV-065 and 28F016SV-070 in its high speed test configuration.



# 5.2 Capacitance

For a 3.3V ± 0.3V System:

| Symbol            | Parameter                                                       | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-----------------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                 | , 1   | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an Output Pin                          | 1     | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing Specifications | 1,2   |     | 50  | pF    |                                          |

# For 5.0V $\pm$ 0.5V, 5.0V $\pm$ 0.25V System:

| Symbol            | Parameter                                       | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin | 1     | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin       | 1     | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by                      | 1,2   |     | 100 | pF    | For $V_{CC} = 5.0V \pm 0.5V$             |
|                   | Outputs for Timing Specifications               |       |     | 30  | pF    | For $V_{CC} = 5.0V \pm 0.25V$            |

Sampled, not 100% tested. Guaranteed by design.
 Intel is currently developing more accurate models for the Transient Equivalent Testing Load Circuits. For more information or to obtain iBIS models, please contact your local Intel/Distribution Sales Office.





AC test inputs are driven at  $V_{OH}$  (2.4 VTTL) for a Logic "1" and  $V_{OL}$  (0.45 VTTL) for a Logic "0." Input timing begins at  $V_{IH}$  (2.0 VTTL) and  $V_{IL}$  (0.8 VTTL). Output timing ends at  $V_{IH}$  and  $V_{IL}$ . Input rise and fall times (10% to 90%) <10 ns.

Figure 7. Transient Input/Output Reference Waveform for  $V_{CC} = 5.0V \pm 10\%$  (Standard Testing Configuration)(1)



Figure 8. Transient Input/Output Reference Waveform for  $V_{CC}=3.3V\pm0.3V$  and  $V_{CC}=5.0V\pm5\%$  (High Speed Testing Configuration)(2)

- 1. Testing characteristics for 28F016SV-070 (Standard Testing Configuration) and 28F016SV-080.
- Testing characteristics for 28F016SV-065/28F016SV-075 and 28F016SV-70 (High Speed Testing Configuration)/ 28F016SV-120.





Figure 9. Transient Equivalent Testing Load Circuit (28F016SV-070/-080 at  $V_{CC} = 5.0V \pm 10\%$ )



Figure 10. Transient Equivalent Testing Load Circuit (28F016SV-075/-120 at  $V_{CC}=3.3V\pm0.3V$ )



Figure 11. High Speed Transient Equivalent Testing Load Circuit (28F016SV-065/-070 at  $V_{CC}=5.0V\pm5\%$ )



# 5.3 DC Characteristics

 $V_{CC}$  = 3.3V  $\pm$  0.3V,  $T_A$  = 0°C to +70°C

| Symbol            | Parameter                                   | Notes       | Min | Тур | Max | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|---------------------------------------------|-------------|-----|-----|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>LI</sub>   | Input Load Current                          | 1           |     |     | 1   | μΑ    | $V_{CC} = V_{CC} Max,$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ILO               | Output Leakage<br>Current                   | 1           |     |     | 10  | μΑ    | $V_{CC} = V_{CC} Max,$<br>$V_{OUT} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Iccs              | V <sub>CC</sub> Standby<br>Current          | 1,5         |     | 70  | 130 | μΑ    | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC}  \text{Max,} \\ \text{CE}_0 \#, \text{CE}_1 \#, \text{RP} \# = \text{V}_{CC} \pm \\ \text{0.2V} \\ \text{BYTE} \#, \text{WP} \# = \text{V}_{CC} \pm \\ \text{or GND} \pm \\ \text{0.2V} \end{array}$                                                                                                                                                                                                                                                                                                                        |
|                   |                                             | ·           |     | 1   | 4   | mA    | $V_{CC} = V_{CC} Max,$ $CE_0 \#, CE_1 \#, RP \# = V_{IH}$ $BYTE \#, WP \# = V_{IH} \text{ or } V_{IL}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ICCD              | V <sub>CC</sub> Deep Power-<br>Down Current | 1           |     | 2   | 5   | μΑ    | $RP\# = GND \pm 0.2V$ $BYTE\# = V_{CC} \pm 0.2V \text{ or}$ $GND \pm 0.2V$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ICCR <sup>1</sup> | V <sub>CC</sub> Read Current                | 1,4,5       |     | 40  | 50  | mΑ    | $\begin{array}{c} \text{V}_{CC} = \text{V}_{CC}  \text{Max} \\ \text{CMOS: CE}_0 \#, \text{CE}_1 \# = \text{GND} \\ \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V or} \\ \text{V}_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V or V}_{CC} \\ \pm 0.2 \text{V} \\ \text{TTL: CE}_0 \#, \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ \text{BYTE} \# = \text{V}_{\text{IL}}  \text{or V}_{\text{IH}}, \\ \text{INPUTS} = \text{V}_{\text{IL}}  \text{or V}_{\text{IH}}, \\ \text{f} = 8  \text{MHz, I}_{OUT} = 0  \text{mA} \end{array}$ |
| ICCR <sup>2</sup> | V <sub>CC</sub> Read Current                | 1,4,<br>5,6 |     | 20  | 30  | · mA  | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ \text{CMOS: CE}_0\#, \text{CE}_1\# = \text{GND} \\ \pm 0.2\text{V} \\ \text{BYTE}\# = \text{GND} \pm 0.2\text{V or} \\ \text{V}_{CC} \pm 0.2\text{V} \\ \text{Inputs} = \text{GND} \pm 0.2\text{V or V}_{CC} \\ \pm 0.2\text{V} \\ \text{TTL: CE}_0\#, \text{CE}_1\# = \text{V}_{IL}, \\ \text{BYTE}\# = \text{V}_{IL} \text{ or V}_{IH} \\ \text{INPUTS} = \text{V}_{IL} \text{ or V}_{IH}, \\ \text{f} = 4 \text{ MHz, I}_{OUT} = 0 \text{ mA} \end{array}$                                                |



# 5.3 DC Characteristics (Continued)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol            | Parameter                                   | Notes | Min  | Тур | Max                      | Units | Test Conditions                                                                     |
|-------------------|---------------------------------------------|-------|------|-----|--------------------------|-------|-------------------------------------------------------------------------------------|
| lccw              | V <sub>CC</sub> Write Current               | 1,6   |      | 8   | 12                       | mA    | Word/Byte Write in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                         |
|                   |                                             |       |      | 8   | 17                       | mA    | Word/Byte Write in Progress V <sub>PP</sub> = 5.0V ± 10%                            |
| ICCE              | V <sub>CC</sub> Block Erase<br>Current      | 1,6   |      | 6   | 12                       | mA    | Block Erase in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                             |
|                   | <i>i</i>                                    |       | ,    | 9   | 17                       | mA    | Block Erase in Progress<br>V <sub>PP</sub> = 5.0V ± 10%                             |
| ICCES             | V <sub>CC</sub> Erase<br>Suspend Current    | 1,2   |      | 1   | 4                        | mA    | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended     |
| IPPS              | V <sub>PP</sub> Standby/Read                | 1     |      | ± 1 | ± 10                     | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                   |
| I <sub>PPR</sub>  | Current                                     |       |      | 30  | 50                       | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                                   |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-<br>Down Current | 1     |      | 0.2 | 5                        | μΑ    | RP# = GND ± 0.2V                                                                    |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current               | 1,6   |      | 10  | 15                       | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Word/Byte Write in Progress                         |
|                   | Ţ                                           |       |      | 15  | 25                       | mA    | V <sub>PP</sub> = 5.0V ± 10%<br>Word/Byte Write in Progress                         |
| IPPE              | V <sub>PP</sub> Erase Current               | 1,6   |      | 4   | 10                       | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress                             |
|                   |                                             |       |      | 14  | 20                       | mA    | V <sub>PP</sub> = 5.0V ± 10%<br>Block Erase in Progress                             |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase<br>Suspend Current    | 1     |      | 30  | 50                       | μΑ    | V <sub>PP</sub> = V <sub>PPH1 or</sub> V <sub>PPH2</sub> ,<br>Block Erase Suspended |
| V <sub>IL</sub>   | Input Low Voltage                           | 6     | -0.3 |     | 0.8                      | ٧     | :                                                                                   |
| V <sub>IH</sub>   | Input High Voltage                          | 6     | 2.0  |     | V <sub>CC</sub><br>+ 0.3 | ٧     |                                                                                     |
| V <sub>OL</sub>   | Output Low<br>Voltage                       | 6     |      |     | 0.4                      | ٧     | $V_{CC} = V_{CC}$ Min and $I_{OL} = 4$ mA                                           |



#### 5.3 DC Characteristics (Continued)

 $V_{CC} = 3.3V \pm 0.3V, T_A = 0^{\circ}C \text{ to } +70^{\circ}C$ 

| Symbol                       | Parameter                                           | Notes | Min                     | Тур  | Max  | Units | Test Conditions                                          |
|------------------------------|-----------------------------------------------------|-------|-------------------------|------|------|-------|----------------------------------------------------------|
| V <sub>OH</sub> <sup>1</sup> | Output High<br>Voltage                              | 6     | 2.4                     |      |      | >     | $I_{OH} = -2.0 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$ |
| V <sub>OH</sub> <sup>2</sup> |                                                     | 6     | V <sub>CC</sub><br>-0.2 |      |      | >     | $I_{OH} = -100 \mu A$ $V_{CC} = V_{CC} Min$              |
| V <sub>PPLK</sub>            | V <sub>PP</sub> Erase/Write<br>Lock Voltage         | 3,6   | 0.0                     |      | 1.5  | >     |                                                          |
| V <sub>PPH1</sub>            | V <sub>PP</sub> during<br>Write/Erase<br>Operations | 3     | 4.5                     | 5.0  | 5.5  | ٧     |                                                          |
| V <sub>PPH2</sub>            | V <sub>PP</sub> during<br>Write/Erase<br>Operations | 3     | 11.4                    | 12.0 | 12.6 | ٧     |                                                          |
| V <sub>LKO</sub>             | V <sub>CC</sub> Erase/Write<br>Lock Voltage         |       | 2.0                     |      |      | ٧     |                                                          |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 3.3V, V<sub>PP</sub> = 12.0V or 5.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum
- of I<sub>CCES</sub> and I<sub>CCR</sub>.

  3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when V<sub>PP</sub> ≤ V<sub>PPLK</sub> and not guaranteed in the ranges between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min) and above V<sub>PPH2</sub>(max).
- 4. Automatic Power Savings (APS) reduces ICCR to 3.0 mA typical in static operation.
- CMOS Inputs are either V<sub>CC</sub> ± 0.2V or GND ± 0.2V. TTL Inputs are either V<sub>IL</sub> or V<sub>IH</sub>.
- 6. Sampled, but not 100% tested. Guaranteed by design.



# 5.4 DC Characteristics

 $V_{CC} = 5.0V \pm 0.5V$ ,  $5.0V \pm 0.25V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol            | Parameter                                   | Notes       | Min | Тур | Max  | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|---------------------------------------------|-------------|-----|-----|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ILI               | Input Load Current                          | 1           |     |     | ± 1  | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ILO               | Output Leakage<br>Current                   | 1           |     |     | ± 10 | μΑ    | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>OUT</sub> = V <sub>CC</sub> or GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Iccs              | V <sub>CC</sub> Standby<br>Current          | 1,5         |     | 70  | 130  | μΑ    | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ \text{CE}_0\#, \text{CE}_1\#, \text{RP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{BYTE}\#, \text{WP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{or GND} \pm 0.2\text{V} \end{array}$                                                                                                                                                                                                                                                                                                                                                                                 |
|                   |                                             |             |     | 2   | 4    | mA    | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE <sub>0</sub> #, CE <sub>1</sub> #, RP# = V <sub>IH</sub><br>BYTE#, WP# = V <sub>IH</sub> or V <sub>IL</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ICCD              | V <sub>CC</sub> Deep Power-<br>Down Current | 1           |     | 2   | 5    | μΑ    | $RP\# = GND \pm 0.2V$ $BYTE\# = V_{CC} \pm 0.2V \text{ or}$ $GND \pm 0.2V$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Iccn <sup>1</sup> | V <sub>CC</sub> Read Current                | 1,4,5       |     | 75  | 95   | mA    | $\begin{split} &V_{CC} = V_{CC} \text{ Max,} \\ &C\text{MOS: } \text{CE}_0 \#, \text{CE}_1 \# = \text{GND} \\ &\pm 0.2 \text{V} \\ &\text{BYTE} \# = \text{GND} \pm 0.2 \text{V} \\ &\text{or } \text{V}_{CC} \pm 0.2 \text{V} \\ &\text{Inputs} = \text{GND} \pm 0.2 \text{V or} \\ &\text{V}_{CC} \pm 0.2 \text{V} \\ &\text{TTL: } \text{CE}_0 \#, \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ &\text{BYTE} \# = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}} \\ &\text{Inputs} = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ &\text{f} = 10 \text{ MHz, } \text{I}_{\text{OUT}} = 0 \text{ mA} \end{split}$ |
| ICCR <sup>2</sup> | V <sub>CC</sub> Read Current                | 1,4,<br>5,6 |     | 45  | 55   | mA    | $\begin{array}{l} V_{CC} = V_{CC}Max, \\ CMOS:CE_0\#, CE_1\# = GND \\ \pm 0.2V \\ BYTE\# = GND \pm 0.2V \\ orV_{CC} \pm 0.2V \\ Inputs = GND \pm 0.2Vor \\ V_{CC} \pm 0.2V \\ TTL:CE_0\#, CE_1\# = V_{IL}, \\ BYTE\# = V_{IL}orV_{IH}, \\ Inputs = V_{IL}orV_{IH}, \\ f = 5MHz, I_{OUT} = 0mA \end{array}$                                                                                                                                                                                                                                                                                                                           |



# 5.4 DC Characteristics (Continued)

 $V_{CC}\,=\,5.0V\,\pm\,0.5V,\,5.0V\,\pm\,0.25V,\,T_{A}\,=\,0^{\circ}C$  to  $\,+\,70^{\circ}C$ 

| Symbol            | Parameter                                   | Notes | Min  | Тур | Max                      | Units | Test Conditions                                                                     |
|-------------------|---------------------------------------------|-------|------|-----|--------------------------|-------|-------------------------------------------------------------------------------------|
| Iccw              | V <sub>CC</sub> Write Current               | 1,6   |      | 25  | 35                       | mA    | Word/Byte in Progress $V_{PP} = 12.0V \pm 5\%$                                      |
|                   |                                             |       |      | 25  | 40                       | mA    | Word/Byte in Progress $V_{PP} = 5.0V \pm 10\%$                                      |
| ICCE              | V <sub>CC</sub> Block Erase<br>Current      | 1,6   |      | 18  | 25                       | mA    | Block Erase in Progress $V_{PP} = 12.0V \pm 5\%$                                    |
|                   |                                             |       | i    | 20  | 30                       | mA-   | Block Erase in Progress $V_{PP} = 5.0V \pm 10\%$                                    |
| ICCES             | V <sub>CC</sub> Erase<br>Suspend Current    | 1,2   |      | 2   | 4                        | mA    | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended     |
| IPPS              | V <sub>PP</sub> Standby/Read                | 1     |      | ± 1 | ± 10                     | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                   |
| IPPR              | Current                                     |       |      | 30  | 50                       | μΑ    | $V_{PP} > V_{CC}$                                                                   |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-<br>Down Current | 1     |      | 0.2 | 5                        | μА    | RP# = GND ± 0.2V                                                                    |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current               | 1,6   |      | 7   | 12                       | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Word/Byte Write in Progress                         |
|                   | ,                                           |       |      | 17  | 22                       | mA    | V <sub>PP</sub> = 5.0V ± 10%<br>Word/Byte Write in Progress                         |
| I <sub>PPE</sub>  | V <sub>PP</sub> Block Erase<br>Current      | 1,6   |      | 5   | 10                       | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress                             |
|                   |                                             |       |      | 16  | 20                       | mA    | V <sub>PP</sub> = 5.0V ± 10%<br>Block Erase in Progress                             |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase<br>Suspend Current    | 1     |      | 30  | 50                       | μА    | V <sub>PP</sub> = V <sub>PPH1</sub> or V <sub>PPH2</sub> ,<br>Block Erase Suspended |
| V <sub>IL</sub>   | Input Low Voltage                           | 6     | -0.5 |     | 0.8                      | ٧     |                                                                                     |
| V <sub>IH</sub>   | Input High Voltage                          | 6     | 2.0  |     | V <sub>CC</sub><br>+ 0.5 | ٧     |                                                                                     |



#### 5.4 DC Characteristics (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ , 5.0V  $\pm 0.25V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol                       | Parameter                                           | Notes | Min                     | Тур  | Max  | Units | Test Conditions                                          |
|------------------------------|-----------------------------------------------------|-------|-------------------------|------|------|-------|----------------------------------------------------------|
| V <sub>OL</sub>              | Output Low<br>Voltage                               | 6     |                         |      | 0.45 | ٧     | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                  |
| V <sub>OH</sub> 1            | Output High<br>Voltage                              | 6     | 0.85<br>V <sub>CC</sub> |      |      | V     | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$ |
| V <sub>OH</sub> <sup>2</sup> |                                                     | 6     | V <sub>CC</sub><br>-0.4 |      |      |       | $I_{OH} = -100 \mu A$ $V_{CC} = V_{CC} Min$              |
| V <sub>PPLK</sub>            | V <sub>PP</sub> Write/Erase<br>Lock Voltage         | 3,6   | 0.0                     |      | 1.5  | V     |                                                          |
| V <sub>PPH1</sub>            | V <sub>PP</sub> during<br>Write/Erase<br>Operations |       | 4.5                     | 5.0  | 5.5  | V     |                                                          |
| V <sub>PPH2</sub>            | V <sub>PP</sub> during<br>Write/Erase<br>Operations |       | 11.4                    | 12.0 | 12.6 | ٧     |                                                          |
| V <sub>LKO</sub>             | V <sub>CC</sub> Write/Erase<br>Lock Voltage         |       | 2.0                     |      |      | V     |                                                          |

#### NOTES:

1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V or 5.0V, T = 25°C. These currents are valid for all product versions (package and speeds).

2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum

of I<sub>CCES</sub> and I<sub>CCR</sub>.

3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when V<sub>PP</sub> ≤ V<sub>PPLK</sub> and not guaranteed in the ranges between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min) and above V<sub>PPH2</sub>(max).

Automatic Power Saving (APS) reduces I<sub>CCR</sub> to 1 mA typical in Static operation.
 CMOS Inputs are either V<sub>CC</sub> ± 0.2V or GND ± 0.2V. TTL Inputs are either V<sub>IL</sub> or V<sub>IH</sub>.

6. Sampled, not 100% tested. Guaranteed by design.



#### 5.5 Timing Nomenclature

All 3.3V system timings are measured from where signals cross 1.5V.

For 5.0V systems use the standard JEDEC cross point definitions (standard testing) or from where signals cross 1.5V (high speed testing).

Each timing parameter consists of 5 characters. Some common examples are defined below:

t<sub>CE</sub> t<sub>ELQV</sub> time(t) from CE# (E) going low (L) to the outputs (Q) becoming valid (V)

toE t<sub>GLQV</sub> time(t) from OE # (G) going low (L) to the outputs (Q) becoming valid (V)

tACC tAVQV time(t) from address (A) valid (V) to the outputs (Q) becoming valid (V)

t<sub>AS</sub> t<sub>AVWH</sub> time(t) from address (A) valid (V) to WE# (W) going high (H)

tDH tWHDX time(t) from WE# (W) going high (H) to when the data (D) can become undefined (X)

|    | Pin Characters                  |   | Pin States                        |
|----|---------------------------------|---|-----------------------------------|
| Α  | Address Inputs                  | Н | High                              |
| D  | Data Inputs                     | L | Low                               |
| Q  | Data Outputs                    | ٧ | Valid                             |
| Ε  | CE# (Chip Enable)               | Х | Driven, but Not Necessarily Valid |
| F  | BYTE# (Byte Enable)             | Z | High Impedance                    |
| G  | OE# (Output Enable)             |   |                                   |
| W  | WE# (Write Enable)              |   |                                   |
| Р  | RP# (Deep Power-Down Pin)       |   |                                   |
| R  | RY/BY# (Ready Busy)             |   |                                   |
| ٧  | Any Voltage Level               |   | ·                                 |
| 5V | V <sub>CC</sub> at 4.5V Minimum |   |                                   |
| 3V | V <sub>CC</sub> at 3.0V Minimum |   |                                   |



# 5.6 AC Characteristics—Read Only Operations(1)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0$ °C to +70°C

|                   | Versions <sup>(5)</sup>                                                   |       | 28F010 | 6SV-075 | 28F016 | SV-120 | Units |
|-------------------|---------------------------------------------------------------------------|-------|--------|---------|--------|--------|-------|
| Sym               | Parameter                                                                 | Notes | Min    | Max     | Min    | Max    |       |
| t <sub>AVAV</sub> | Read Cycle Time                                                           |       | 75     |         | 120    |        | ns    |
| t <sub>AVQV</sub> | Address to Output Delay                                                   |       |        | 75      | 2      | 120    | ns    |
| t <sub>ELQV</sub> | CE# to Output Delay                                                       | 2,8   |        | 75      |        | 120    | ns    |
| t <sub>PHQV</sub> | RP# High to Output Delay                                                  |       |        | 480     |        | 620    | ns    |
| tGLQV             | OE# to Output Delay                                                       | 2     |        | 40      |        | 45     | ns    |
| t <sub>ELQX</sub> | CE# to Output in Low Z                                                    | 3,8   | 0      |         | 0      |        | ns    |
| t <sub>EHQZ</sub> | CE# to Output in High Z                                                   | 3,8   |        | 30      |        | 50     | ns    |
| tGLQX             | OE# to Output in Low Z                                                    | 3     | 0      |         | 0      |        | ns    |
| tGHQZ             | OE# to Output in High Z                                                   | 3     |        | 30      |        | 30     | nș    |
| tон               | Output Hold from Address,<br>CE# or OE# Change,<br>Whichever Occurs First | 3,8   | 0      |         | 0      |        | ns    |
| t <sub>FLQV</sub> | BYTE# to Output Delay                                                     | 3     |        | 75      |        | 120    | ns    |
| t <sub>FLQZ</sub> | BYTE# Low to Output in High Z                                             | 3     |        | 30      |        | 30     | ns    |
| t <sub>ELFL</sub> | CE# Low to BYTE#<br>High or Low                                           | 3,8   |        | 5       |        | 5      | ns    |

# **Extended Status Register Reads**

| tAVEL | Address Setup to CE#<br>Going Low | 3,4,8,9 | 0 | 0 . | ns |
|-------|-----------------------------------|---------|---|-----|----|
| tAVGL | Address Setup to OE#<br>Going Low | 3,4,9   | 0 | 0   | ns |



# 5.6 AC Characteristics—Read Only Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ , 5.0V  $\pm 0.25V$ ,  $T_A = 0$ °C to +70°C

|                                        | Versions(5)                                                                  | V <sub>CC</sub> ± 5%  | 28F016S | V-065 <sup>(6)</sup> | 28F016S | V-070 <sup>(6)</sup>                     |         |                      |       |
|----------------------------------------|------------------------------------------------------------------------------|-----------------------|---------|----------------------|---------|------------------------------------------|---------|----------------------|-------|
|                                        | versions(*)                                                                  | V <sub>CC</sub> ± 10% |         |                      | 28F016S | V-070 <sup>(7)</sup>                     | 28F016S | V-080 <sup>(7)</sup> | Units |
| Sym                                    | Parameter                                                                    | Notes                 | Min     | Max                  | Min     | Max                                      | Min     | Max                  |       |
| t <sub>AVAV</sub>                      | Read Cycle Time                                                              | ,                     | 65      |                      | 70      |                                          | 80      |                      | ns    |
| tavqv                                  | Address to<br>Output Delay                                                   |                       |         | 65                   | -       | 70                                       |         | 80                   | ns    |
| t <sub>ELQV</sub>                      | CE# to Output Delay                                                          | 2,8                   |         | 65                   |         | 70                                       |         | 80                   | ns    |
| t <sub>PHQV</sub>                      | RP# to Output Delay                                                          |                       |         | 300                  |         | 400 <sup>(6)</sup><br>300 <sup>(7)</sup> |         | 480                  | ns    |
| tGLQV                                  | OE# to Output Delay                                                          | 2                     |         | 30                   |         | 30(6)<br>35(7)                           |         | 35                   | ns    |
| t <sub>ELQX</sub>                      | CE# to Output in Low Z                                                       | 3,8                   | 0       |                      | 0       |                                          | 0       |                      | ns    |
| t <sub>EHQZ</sub>                      | CE# to Output in High Z                                                      | 3,8                   |         | 25                   |         | 25                                       |         | 30                   | ns    |
| tGLQX                                  | OE# to Output in Low Z                                                       | 3                     | 0       |                      | . 0     |                                          | O       |                      | ns    |
| tGHQZ                                  | OE# to Output in High Z                                                      | 3                     |         | 25                   |         | 25                                       |         | 30                   | ns    |
| t <sub>OH</sub>                        | Output Hold from<br>Address, CE# or OE#<br>Change, Whichever<br>Occurs First | 3,8                   | 0       |                      | 0       |                                          | 0       | ·                    | ns    |
| t <sub>FLQV</sub>                      | BYTE# to Output Delay                                                        | 3                     |         | 65                   |         | 70                                       |         | 80                   | ns    |
| t <sub>FLQZ</sub>                      | BYTE# Low to Output in High Z                                                | 3                     |         | 25                   |         | 25                                       |         | 30                   | ns    |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> | CE# Low to BYTE#<br>High or Low                                              | 3,8                   |         | 5                    |         | 5                                        |         | 5                    | ns    |

#### **Extended Status Register Reads**

|                   | ava viaido mogioto, mod           |         |   |   |   |    |
|-------------------|-----------------------------------|---------|---|---|---|----|
| 1 / 1             | Address Setup to CE#<br>Going Low | 3,4,8,9 | 0 | 0 | 0 | ns |
| t <sub>AVGL</sub> | Address Setup to OE#<br>Going Low | 3,4,9   | 0 | 0 | 0 | ns |

#### 28F016SV FlashFile™ Memory



- 1. See AC Input/Output Reference Waveforms for timing measurements, Figures 7 and 8.
- 2. OE# may be delayed up to t<sub>ELQV</sub>-t<sub>GLQV</sub> after the falling edge of CE#, without impacting t<sub>ELQV</sub>.
- 3. Sampled, not 100% tested. Guaranteed by design
- 4. This timing parameter is used to latch the correct BSR data onto the outputs.
- 5. Device speeds are defined as: 65/70 ns at  $V_{CC}=5.0V$  equivalent to 75 ns at  $V_{CC}=3.3V$  70/80 ns at  $V_{CC}=5.0V$  equivalent to
- 120 ns at V<sub>CC</sub> = 3.3V
- 6. See the high speed AC Input/Output Reference Waveforms and AC Testing Load Circuit.
- 7. See the standard AC Input/Output Reference Waveforms and AC Testing Load Circuit.
- 8. CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- 9. The address setup requirement for Extended Status Register reads must only be met referenced to the falling edge of the last control signal to become active (CE<sub>0</sub>#, CE<sub>1</sub># or OE#). For example, if CE<sub>0</sub># and CE<sub>1</sub># are activated prior to OE# for an Extended Status Register read, specification tAVGL must be met. On the other hand, if either CE<sub>0</sub># or CE<sub>1</sub># (or both) are activated after OE#, specification tAVEL must be referenced.





Figure 12. Read Timing Waveforms





Figure 13. BYTE# Timing Waveforms



# 5.7 Power-Up and Reset Timings



Figure 14. V<sub>CC</sub> Power-Up and RP# Reset Waveforms

| Symbol            | Parameter                                                | Notes | Min | Max | Units |
|-------------------|----------------------------------------------------------|-------|-----|-----|-------|
| t <sub>PL5V</sub> | RP# Low to V <sub>CC</sub> at 4.5V (Minimum)             | 2     | 0   |     | μs    |
| t <sub>PL3V</sub> | RP# Low to V <sub>CC</sub> at 3.0V (Minimum)             | 2     | 0   |     | μs    |
| t <sub>AVQV</sub> | Address Valid to Data Valid for $V_{CC} = 5.0V \pm 10\%$ | 3     |     | 70  | ns    |
| t <sub>PHQV</sub> | RP# High to Data Valid for V <sub>CC</sub> = 5.0V ± 10%  | 3     |     | 300 | ns    |
| t <sub>5VPH</sub> | V <sub>CC</sub> at 4.5V (Minimum) to RP# High            | 1     | 2   |     | μs    |
| tзvрн             | V <sub>CC</sub> at 3.0V (Minimum) to RP# High            | 1     | 2   |     | μs    |

#### **NOTES:**

CE<sub>0</sub>#, CE<sub>1</sub># and OE# are switched low after Power-Up.

- 1. The t<sub>5VPH</sub> and/or t<sub>3VPH</sub> times must be strictly followed to guarantee all other read and write specifications for the 28E018SV
- 2. The power supply may start to switch concurrently with RP# going low.
- 3. The address access time and RP# high to data valid time are shown for 5.0V V<sub>CC</sub> operation of the 28F016SV-070 (Standard Test Configuration). Refer to the AC Characteristics-Read Only Operations for 3.3V V<sub>CC</sub> and 5.0V V<sub>CC</sub> (High Speed Test Configuration) values.



# 5.8 AC Characteristics for WE #—Controlled Command Write Operations(1)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                    | Versions                                                                                   |       | 28F   | 016SV- | 075 | 28F | 016SV- | 120 | Units |
|--------------------|--------------------------------------------------------------------------------------------|-------|-------|--------|-----|-----|--------|-----|-------|
| Symbol             | Parameter                                                                                  | Notes | Min   | Тур    | Max | Min | Тур    | Max | Onits |
| tavav              | Write Cycle Time                                                                           |       | 75    |        | -   | 120 |        |     | ns    |
| tvpwh              | V <sub>PP</sub> Setup to WE# Going High                                                    | 3     | 100   |        |     | 100 |        |     | ns    |
| t <sub>PHEL</sub>  | RP# Setup to CE# Going Low                                                                 | 3,7   | 480   |        |     | 480 | i      |     | ns    |
| tELWL              | CE# Setup to WE# Going Low                                                                 | 3,7   | 0     |        |     | 10  |        |     | ns    |
| tavwh              | Address Setup to WE# Going High                                                            | 2,6   | 60    |        |     | 75  |        |     | ns    |
| <sup>t</sup> DVWH  | Data Setup to WE# Going High                                                               | 2,6   | 60    |        |     | 75  |        |     | ns    |
| twLWH              | WE# Pulse Width                                                                            |       | 60    |        |     | 75  |        |     | ns    |
| twhox              | Data Hold from WE# High                                                                    | 2     | 5     |        |     | -10 |        |     | ns    |
| twhax              | Address Hold from WE# High                                                                 | 2     | 5     |        |     | 10  |        |     | ns    |
| twheh              | CE# Hold from WE# High                                                                     | 3,7   | 5     |        |     | 10  |        |     | ns    |
| twhwL              | WE# Pulse Width High                                                                       |       | 15    |        |     | 45  |        |     | ns    |
| tGHWL              | Read Recovery before Write                                                                 | 3     | 0     | ,      |     | 0   |        |     | ns    |
| twhrl              | WE# High to RY/BY# Going Low                                                               | 3     |       |        | 100 |     |        | 100 | ns    |
| <sup>t</sup> RHPL  | RP# Hold from Valid Status<br>Register (CSR, GSR, BSR) Data<br>and RY/BY# High             | 3     | 0     |        |     | 0   |        |     | ns    |
| t <sub>PHWL</sub>  | RP# High Recovery to WE# Going Low                                                         | 3     | 0.480 |        |     | 1   |        |     | μs    |
| twhgl              | Write Recovery before Read                                                                 | 3     | 55    |        |     | 95  |        |     | ns    |
| <sup>t</sup> QVVL  | V <sub>PP</sub> Hold from Valid Status Register<br>(CSR, GSR, BSR) Data and<br>RY/BY# High | 3     | 0     |        |     | 0   |        |     | μs    |
| twHQV1             | Duration of Word/Byte<br>Write Operation                                                   | 3,4,5 | 5     | 9      | TBD | 5   | 9      | TBD | μs    |
| twHQV <sup>2</sup> | Duration of Block Erase Operation                                                          | 3,4   | 0.3   | 0.8    | 10  | 0.3 | 0.8    | 10  | sec   |



# 5.8 AC Characteristics for WE #—Controlled Command Write Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $5.0V \pm 0.25V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| ,                 | /ersions <sup>(8)</sup>                                                                 | V <sub>CC</sub> ± 5%  | 28F0 | 16SV-0 | )65( <sup>9</sup> ) | 28F01                                     | 6SV-07 | 70(9) |      |         |        |       |
|-------------------|-----------------------------------------------------------------------------------------|-----------------------|------|--------|---------------------|-------------------------------------------|--------|-------|------|---------|--------|-------|
| ,                 | Craioria (-)                                                                            | V <sub>CC</sub> ± 10% |      |        |                     | 28F016                                    | SV-07  | 0(10) | 28F0 | 16SV-08 | 30(10) | Units |
| Sym               | Parameter                                                                               | Notes                 | Min  | Тур    | Max                 | Min                                       | Тур    | Max   | Min  | Тур     | Max    |       |
| t <sub>AVAV</sub> | Write Cycle<br>Time                                                                     |                       | 65   |        |                     | 70                                        |        |       | 80   |         |        | ns    |
| t <sub>VPWH</sub> | V <sub>PP</sub> Setup to<br>WE# Going<br>High                                           | 3                     | 100  |        |                     | 100                                       |        |       | 100  |         |        | ns    |
| <sup>t</sup> PHEL | RP# Setup to CE# Going Low                                                              | 3,7                   | 300  |        |                     | 480 <sup>(9)</sup><br>300 <sup>(10)</sup> |        |       | 480  |         |        | ns    |
| tELWL             | CE# Setup to<br>WE# Going Low                                                           | 3,7                   | 0    |        |                     | 0                                         |        |       | 0    |         |        | ns    |
| tavwh             | Address Setup<br>to WE# Going<br>High                                                   | 2,6                   | 40   |        |                     | 50(9)<br>40(10)                           | ·      |       | 50   |         |        | ns    |
| t <sub>DVWH</sub> | Data Setup<br>to WE# Going<br>High                                                      | 2,6                   | 40   | -      |                     | 50(9)<br>40(10)                           |        |       | 50   |         |        | ns    |
| twLwH             | WE# Pulse<br>Width                                                                      |                       | 40   |        |                     | 40(9)<br>45(10)                           |        |       | 50   |         |        | ns    |
| t <sub>WHDX</sub> | Data Hold from<br>WE# High                                                              | 2                     | 0    |        |                     | 0                                         |        |       | 0    |         |        | ns    |
| twhax             | Address Hold from WE# High                                                              | 2                     | 5    |        |                     | 10                                        |        |       | 10   |         |        | ns    |
| twheh             | CE# Hold from<br>WE# High                                                               | 3,7                   | 5    |        |                     | 10 <sup>(9)</sup><br>5 <sup>(10)</sup>    |        |       | 10   |         |        | ns    |
| twHWL             | WE# Pulse<br>Width High                                                                 |                       | 15   |        | ŕ                   | 30 <sup>(9)</sup><br>15 <sup>(10)</sup>   |        |       | 30   |         |        | ns    |
| tGHWL             | Read Recovery before Write                                                              | 3                     | 0    |        |                     | 0                                         |        |       | 0    |         |        | ns    |
| twhrl             | WE# High to<br>RY/BY# Going<br>Low                                                      | 3                     |      |        | 100                 |                                           |        | 100   |      |         | 100    | ns    |
| t <sub>RHPL</sub> | RP# Hold from<br>Valid Status<br>Register (CSR,<br>GSR, BSR)<br>Data and<br>RY/BY# High | 3                     | 0    |        |                     | 0                                         |        |       | 0    |         |        | ns    |



## 5.8 AC Characteristics for WE #—Controlled Command Write Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $5.0V \pm 0.25V$ ,  $T_A = 0$ °C to +70°C

| v                   | /ersions(8)                                                                                         | V <sub>CC</sub> ± 5%  | 28F01 | 6SV-0 | )65( <sup>9</sup> )          | 28F016                                    | SV-07 | 0(9)                         |     |     |       |     |
|---------------------|-----------------------------------------------------------------------------------------------------|-----------------------|-------|-------|------------------------------|-------------------------------------------|-------|------------------------------|-----|-----|-------|-----|
| •                   |                                                                                                     | V <sub>CC</sub> ± 10% | 0%    |       | 28F016SV-070 <sup>(10)</sup> |                                           |       | 28F016SV-080 <sup>(10)</sup> |     |     | Units |     |
| Sym                 | Parameter                                                                                           | Notes                 | Min   | Тур   | Max                          | Min                                       | Тур   | Max                          | Min | Тур | Max   |     |
| tpHWL               | RP# High<br>Recovery to<br>WE# Going Low                                                            | 3                     | 0.300 |       |                              | 1 <sup>(9)</sup><br>0.300 <sup>(10)</sup> |       |                              | 1   |     |       | μs  |
| twHGL               | Write Recovery before Read                                                                          | 3                     | 55    |       |                              | 60                                        |       |                              | 65  |     |       | ns  |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from<br>Valid Status<br>Register (CSR,<br>GSR, BSR)<br>Data and<br>RY/BY# High | 3                     | 0     |       |                              | 0                                         |       |                              | 0   |     |       | μs  |
| t <sub>WHQV</sub> 1 | Duration of<br>Word/Byte Write<br>Operation                                                         | 3,4,5                 | 4.5   | 6     | TBD                          | 4.5                                       | 6     | TBD                          | 4.5 | 6   | TBD   | μs  |
| twHQv2              | Duration of<br>Block Erase<br>Operation                                                             | 3,4                   | 0.3   | 0.6   | 10                           | 0.3                                       | 0.6   | 10                           | 0.3 | 0.6 | 10    | sec |

- 1. Read timings during write and erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, not 100% tested. Guaranteed by design.
- 4. Write/Erase durations are measured to valid Status Register (CSR) Data.  $V_{PP}=12.0V\pm0.6V$ .
- 5. Word/Byte Write operations are typically performed within 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of WE# for all Command Write operations.
- 7. CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- 8. Device speeds are defined as:
  - 65/70 ns at  $V_{CC} = 5.0V$  equivalent to

  - 75 ns at  $V_{CC} = 3.3V$ 70/80 ns at  $V_{CC} = 5.0V$  equivalent to
  - 120 ns at  $V_{CC} = 3.3V$
- 9. See the high speed AC Input/Output Reference Waveforms and AC Testing Load Circuit.
- 10. See the standard AC Input/Output Reference Waveforms and AC Testing Load Circuit.





- 1. This address string depicts Data Write/Erase cycles with corresponding verification via ESRD.
- 2. This address string depicts Data Write/Erase cycles with corresponding verification via CSRD.
- 3. This cycle is invalid when using CSRD for verification during Data Write/Erase operations.
- 4. CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- 5. RP# low transition is only to show t<sub>RHPL</sub>; not valid for above Read and Write cycles.
- 6. VPP voltage during Write/Erase operations valid at both 12.0V and 5.0V.
- 7. VPP voltage equal to or below VPPLK provides complete flash memory array protection.

Figure 15. AC Waveforms for Command Write Operations



# 5.9 AC Characteristics for CE #—Controlled Command Write Operations(1)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C + 70^{\circ}C$ 

|                     | Versions                                                                                   |       | 28F   | 016SV- | 075 | 28F | Units |     |        |
|---------------------|--------------------------------------------------------------------------------------------|-------|-------|--------|-----|-----|-------|-----|--------|
| Sym                 | Parameter                                                                                  | Notes | Min   | Тур    | Max | Min | Тур   | Max | Oilles |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                           |       | 75    |        |     | 120 |       |     | ns     |
| t <sub>VPEH</sub>   | V <sub>PP</sub> Setup to CE# Going High                                                    | 3,7   | 100   |        |     | 100 |       |     | ns     |
| t <sub>PHWL</sub>   | RP# Setup to WE# Going Low                                                                 | 3     | 480   |        |     | 480 |       |     | ns     |
| twlEL               | WE# Setup to CE# Going Low                                                                 | 3,7   | . 0   |        |     | Ó   |       |     | ns     |
| t <sub>AVEH</sub>   | Address Setup to CE# Going High                                                            | 2,6,7 | 60    |        |     | 75  |       |     | ns     |
| t <sub>DVEH</sub>   | Data Setup to CE# Going High                                                               | 2,6,7 | 60    |        |     | 75  |       |     | ns     |
| tELEH               | CE# Pulse Width                                                                            | 7     | 60    |        |     | 75  |       |     | ns     |
| t <sub>EHDX</sub>   | Data Hold from CE# High                                                                    | 2,7   | 10    |        |     | 10  |       |     | ns     |
| t <sub>EHAX</sub>   | Address Hold from CE# High                                                                 | 2,7   | 10    |        |     | 10  |       |     | ns     |
| tEHWH               | WE hold from CE# High                                                                      | 3     | 5     |        |     | 10  |       |     | ns     |
| t <sub>EHEL</sub>   | CE# Pulse Width High                                                                       | 7     | 15    |        |     | 45  |       |     | ns     |
| tGHEL               | Read Recovery before Write                                                                 | 3     | 0     |        |     | 0   |       |     | ns     |
| t <sub>EHRL</sub>   | CE# High to RY/BY# Going Low                                                               | 3,7   |       |        | 100 |     |       | 100 | ns     |
| <sup>t</sup> RHPL   | RP# Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High                   | 3     | 0     |        |     | 0   |       |     | ns     |
| t <sub>PHEL</sub>   | RP# High Recovery to CE# Going Low                                                         | 3,7   | 0.480 |        |     | 1   |       |     | μs     |
| t <sub>EHGL</sub>   | Write Recovery before Read                                                                 | 3     | 55    |        |     | 95  |       |     | ns     |
| t <sub>QVVL</sub>   | V <sub>PP</sub> Hold from Valid Status Register<br>(CSR, GSR, BSR) Data and<br>RY/BY# High | 3     | 0     | . ,    |     | 0   |       |     | μs     |
| t <sub>EHQV</sub> 1 | Duration of Word/Byte<br>Write Operation                                                   | 3,4,5 | 5     | 9      | TBD | 5   | 9     | TBD | μs     |
| t <sub>EHQV</sub> 2 | Duration of Block Erase Operation                                                          | 3,4   | 0.3   | 0.8    | 10  | 0.3 | 0.8   | 10  | sec    |



# 5.9 AC Characteristics for CE # —Controlled Command Write Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $5.0V \pm 0.25V$ ,  $T_A = 0^{\circ}$  to  $+70^{\circ}C$ 

| ,                 | Versions <sup>(8)</sup>                                                                 | V <sub>CC</sub> ± 5%  | 28F0 | 16SV-0 | )65 <sup>(9)</sup> | 28F01                                     | 6SV-07 | 70(9) |      |        |        |       |
|-------------------|-----------------------------------------------------------------------------------------|-----------------------|------|--------|--------------------|-------------------------------------------|--------|-------|------|--------|--------|-------|
|                   | versions(=)                                                                             | V <sub>CC</sub> ± 10% |      |        |                    | 28F016                                    | SV-07  | 0(10) | 28F0 | 16SV-0 | 80(10) | Units |
| Sym               | Parameter                                                                               | Notes                 | Min  | Тур    | Max                | Min                                       | Тур    | Max   | Min  | Тур    | Max    |       |
| tavav             | Write Cycle<br>Time                                                                     |                       | 65   |        |                    | 70                                        |        |       | 80   |        |        | ns    |
| t <sub>VPEH</sub> | V <sub>PP</sub> Setup to<br>CE# Going High                                              | 3,7                   | 100  |        |                    | 100                                       |        |       | 100  |        | -      | ns    |
| t <sub>PHWL</sub> | RP# Setup to<br>WE# Going Low                                                           | 3                     | 300  |        |                    | 480 <sup>(9)</sup><br>300 <sup>(10)</sup> |        |       | 480  |        |        | ns    |
| twLEL             | WE# Setup to CE# Going Low                                                              | 3,7                   | 0    |        |                    | 0                                         |        |       | 0    |        |        | ns    |
| tAVEH             | Address Setup<br>to CE# Going<br>High                                                   | 2,6,7                 | 40   |        |                    | 50(9)<br>45(10)                           |        |       | 50   |        |        | ns    |
| tDVEH             | Data Setup to<br>CE# Going High                                                         | 2,6,7                 | 40   |        |                    | 50(9)<br>45(10)                           |        |       | 50   | -      |        | ns    |
| tELEH             | CE# Pulse<br>Width                                                                      | 7                     | 40   |        |                    | 40(9)<br>45(10)                           |        |       | 50   |        |        | ns    |
| tEHDX             | Data Hold from<br>CE# High                                                              | 2,7                   | 0    |        |                    | 0                                         | ,      |       | 0    |        |        | ns    |
| tEHAX             | Address Hold from CE# High                                                              | 2,7                   | 10   |        |                    | 10                                        |        |       | 10   |        |        | ns    |
| t <sub>EHWH</sub> | WE Hold from<br>CE# High                                                                | 3,7                   | 5    |        |                    | 10 <sup>(9)</sup><br>5 <sup>(10)</sup>    |        |       | 10   |        |        | ns    |
| tEHEL             | CE# Pulse<br>Width High                                                                 | 7                     | 15   |        |                    | 30 <sup>(9)</sup><br>15 <sup>(10)</sup>   |        |       | 30   |        |        | ns    |
| tGHEL             | Read Recovery before Write                                                              | 3                     | 0    |        |                    | 0                                         |        |       | 0,   |        |        | ns    |
| t <sub>EHRL</sub> | CE# High to<br>RY/BY# Going<br>Low                                                      | 3,7                   |      |        | 100                |                                           |        | 100   |      |        | 100    | ns    |
| <sup>t</sup> RHPL | RP# Hold from<br>Valid Status<br>Register (CSR,<br>GSR, BSR)<br>Data and<br>RY/BY# High | 3                     | 0    |        |                    | 0                                         |        |       | 0    |        |        | ns    |



# 5.9 AC Characteristics for CE #—Controlled Command Write Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $5.0V \pm 0.25V$ ,  $T_A = 0^{\circ}$  to  $+70^{\circ}$ C

|                     | /ersions <sup>(8)</sup>                                                                            | V <sub>CC</sub> ± 5%  | 28F01 | 6SV-0 | 65(9) | 28F016                                    | SV-07  | 0(9)  |      |        |        |       |
|---------------------|----------------------------------------------------------------------------------------------------|-----------------------|-------|-------|-------|-------------------------------------------|--------|-------|------|--------|--------|-------|
|                     | , croiona.                                                                                         | V <sub>CC</sub> ± 10% |       |       |       | 28F0169                                   | SV-070 | )(10) | 28F0 | 16SV-0 | 80(10) | Units |
| Sym                 | Parameter                                                                                          | Notes                 | Min   | Тур   | Max   | Min                                       | Тур    | Max   | Min  | Тур    | Max    |       |
| <sup>t</sup> PHEL   | RP# High<br>Recovery to<br>CE# Going Low                                                           | 3,7                   | 0.300 |       |       | 1 <sup>(9)</sup><br>0.300 <sup>(10)</sup> |        |       | 1    |        |        | μs    |
| t <sub>EHGL</sub>   | Write Recovery before Read                                                                         | 3                     | 55    |       |       | 60                                        |        |       | 65   |        |        | ns    |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from<br>Valid Status<br>Register (CSR,<br>GSR, BSR)<br>Data at RY/BY#<br>High | 3                     | 0     |       |       | 0                                         |        |       | 0    |        |        | μs    |
| t <sub>EHQV</sub> 1 | Duration of<br>Word/Byte Write<br>Operation                                                        | 3,4,5                 | 4.5   | 6     | TBD   | 4.5                                       | 6      | TBD   | 4.5  | 6      | TBD    | μs    |
| t <sub>EHQV</sub> 2 | Duration of<br>Block Erase<br>Operation                                                            | 3,4                   | 0.3   | 0.6   | 10    | 0.3                                       | 0.6    | 10    | 0.3  | 0.6    | 10     | sec   |

- 1. Read timings during write and erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, not 100% tested. Guaranteed by design.
- 4. Write/Erase durations are measured to valid Status Data. Vpp = 12.0V ± 0.6V.
- 5. Word/Byte Write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of CE# for all Command Write Operations.
- 7. CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- 8. Device speeds are defined as:
  - 65/70 ns at  $V_{CC} = 5.0V$  equivalent to 75 ns at  $V_{CC} = 3.3V$  70/80 ns at  $V_{CC} = 5.0V$  equivalent to

  - 120 ns at  $V_{CC} = 3.3V$
- 9. See the high speed AC Input/Output Reference Waveforms and AC Testing Load Circuit.
- 10. See the standard AC Input/Output Reference Waveforms and AC Testing Load Circuit.





Figure 16. Alternate AC Waveforms for Command Write Operations



# 5.10 AC Characteristics for WE #—Controlled Page Buffer Write Operations(1)

 $V_{CC}=$  3.3V  $\pm$  0.3V,  $T_{A}=$  0°C to +70°C

| Versions          |                                |       | 28F016SV-075 28F016SV-120 |     |     |     |     | 20  | Units |
|-------------------|--------------------------------|-------|---------------------------|-----|-----|-----|-----|-----|-------|
| Sym               | Parameter                      | Notes | Min                       | Тур | Max | Min | Тур | Max |       |
| t <sub>AVWL</sub> | Address Setup to WE# Going Low | 2     | 0                         |     |     | 0   |     |     | ns    |

 $V_{CC}$  = 5.0V  $\pm$  0.5V, 5.0V  $\pm$  0.25V,  $T_A$  = 0°C to +70°C

| V     | ersions <sup>(8)</sup>               | V <sub>CC</sub> ± 5%<br>V <sub>CC</sub> ± 10% |     | 28F016SV-065 <sup>(9)</sup> 28F016SV-070 <sup>(9)</sup> 28F016SV-070 <sup>(10)</sup> |     | 28F0 16SV-080 <sup>(10)</sup> |     |     | Units |     |     |    |
|-------|--------------------------------------|-----------------------------------------------|-----|--------------------------------------------------------------------------------------|-----|-------------------------------|-----|-----|-------|-----|-----|----|
| Sym   | Parameter                            | Notes                                         | Min | Тур                                                                                  | Max | Min                           | Тур | Max | Min   | Тур | Max |    |
| tavwl | Address Setup<br>to WE# Going<br>Low | 1                                             | 0   |                                                                                      |     | 0                             |     |     | 0     |     |     | ns |

- 1. All other specifications for WE#Controlled Write Operations can be found in Section 5.8.
- 2. Address must be valid during the entire WE# low pulse.
- 3. Device speeds are defined as:

  - 65/70 ns at  $V_{CC}=5.0V$  equivalent to 75 ns at  $V_{CC}=3.3V$  70/80 ns at  $V_{CC}=5.0V$  equivalent to
  - 120 ns at V<sub>CC</sub> = 3.3V
- 4. See the high speed AC Input/Output Reference Waveforms and AC Testing Load Circuit.
- 5. See the standard AC Input/Output Reference Waveforms and AC Testing Load Circuit.





Figure 17. WE #—Controlled Page Buffer Write Timing Waveforms (Loading Data to the Page Buffer)



# 5.11 AC Characteristics for CE # — Controlled Page Buffer Write Operations(1)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|       | Versions                          |       |     | 28F016SV-075 |     |     | 28F016SV-120 |     |       |  |
|-------|-----------------------------------|-------|-----|--------------|-----|-----|--------------|-----|-------|--|
| Sym   | Parameter                         | Notes | Min | Тур          | Max | Min | Тур          | Max | Units |  |
| tAVEL | Address Setup to CE#<br>Going Low | 2,3   | 0   |              |     | 0   |              |     | ns    |  |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $5.0V \pm 0.25V$ ,  $T_A = 0$ °C to +70°C

| V                 | ersions <sup>(8)</sup>               | V <sub>CC</sub> ± 5% |     | 16SV-0 | V-065 <sup>(9)</sup> 28F016SV-070 <sup>(9)</sup> 28F016SV-080 <sup>(10)</sup> 28F016SV-080 <sup>(10)</sup> |     |     |     |     | 30(10) | Units |    |
|-------------------|--------------------------------------|----------------------|-----|--------|------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|--------|-------|----|
| Sym               | Parameter                            | Notes                | Min | Тур    | Max                                                                                                        | Min | Тур | Max | Min | Тур    | Max   |    |
| t <sub>AVEL</sub> | Address Setup<br>to CE# Going<br>Low | 2,3                  | 0   |        |                                                                                                            | 0   |     |     | 0   |        |       | ns |

#### NOTES:

- 1. All other specifications for CE#-Controlled Write Operations can be found in Section 5.9.
- 2. Address must be valid during the entire CE# low pulse.
- 3. CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- 4. Device speeds are defined as:

65/70 ns at  $V_{CC}=5.0V$  equivalent to 75 ns at  $V_{CC}=3.3V$  70/80 ns at  $V_{CC}=5.0V$  equivalent to

120 ns at V<sub>CC</sub> = 3.3V

- 5. See the high speed AC Input/Output Reference Waveforms and AC Testing Load Circuit.
- 6. See the standard AC Input/Output Reference Waveforms and AC Testing Load Circuit.





Figure 18. CE#—Controlled Page Buffer Write Timing Waveforms (Loading Data to the Page Buffer)



# 5.12 Erase and Word/Byte Write Performance(3,5)

 $V_{CC}=$  3.3V  $\pm$  0.3V,  $V_{PP}=$  5.0V  $\pm$  0.5V,  $T_{A}=$  0°C to  $+70^{\circ}C$ 

| Sym                  | Parameter                                          | Notes | Min | Typ(1) | Max | Units | Test Conditions |
|----------------------|----------------------------------------------------|-------|-----|--------|-----|-------|-----------------|
|                      | Page Buffer Byte<br>Write Time                     | 2     | TBD | 6.0    | TBD | μs    |                 |
|                      | Page Buffer Word<br>Write Time                     | 2     | TBD | 12.1   | TBD | μs    | ·               |
| t <sub>WHRH</sub> 1A | Byte Write Time                                    | 2     | TBD | 16.5   | TBD | μs    |                 |
| twhRH <sup>1B</sup>  | Word Write Time                                    | 2     | TBD | 24.0   | TBD | μs    |                 |
| t <sub>WHRH</sub> 2  | Block Write Time                                   | 2     | TBD | 1.1    | TBD | sec   | Byte Write Mode |
| twhRH3               | Block Write Time                                   | 2     | TBD | 0.8    | TBD | sec   | Word Write Mode |
|                      | Block Erase Time                                   | 2     | TBD | 1.4    | TBD | sec   |                 |
|                      | Full Chip Erase Time                               | 2     | TBD | 44.8   | TBD | sec   | ·               |
|                      | Time from Erase<br>Suspend Command to<br>WSM Ready | 4     | TBD | 10     | TBD | μs    |                 |

 $V_{CC}$  = 3.3V  $\pm$  0.3V,  $V_{PP}$  = 12.0V  $\pm$  0.6V,  $T_{A}$  = 0°C to +70°C

| Sym                 | Parameter                                          | Notes | Min | Typ(1) | Max | Units | Test Conditions |
|---------------------|----------------------------------------------------|-------|-----|--------|-----|-------|-----------------|
| ٠.                  | Page Buffer Byte<br>Write Time                     | 2     | TBD | 2.2    | TBD | μs    |                 |
|                     | Page Buffer Word<br>Write Time                     | 2     | TBD | 4.4    | TBD | μs    |                 |
| twhrh1              | Word/Byte Write Time                               | 2     | 5   | 9      | TBD | μs    |                 |
| t <sub>WHRH</sub> 2 | Block Write Time                                   | 2     | TBD | 0.6    | 2.1 | sec   | Byte Write Mode |
| t <sub>WHRH</sub> 3 | Block Write Time                                   | 2     | TBD | 0.3    | 1.0 | sec   | Word Write Mode |
|                     | Block Erase Time                                   | 2     | 0.3 | 0.8    | 10  | sec   |                 |
|                     | Full Chip Erase Time                               | 2     | TBD | 25.6   | TBD | sec   |                 |
|                     | Time from Erase<br>Suspend Command to<br>WSM Ready | 4     | TBD | 10     | TBD | μs    |                 |



# 5.12 Erase and Word/Byte Write Performance(3,5) (Continued)

 $V_{CC}$  = 5.0V  $\pm$  0.5V, 5.0V  $\pm$  0.25V,  $V_{PP}$  = 5.0V  $\pm$  0.5V,  $T_A$  = 0°C to +70°C

| Sym                  | Parameter                                          | Notes | Min | Typ <sup>(1)</sup> | Max | Units | Test Conditions |
|----------------------|----------------------------------------------------|-------|-----|--------------------|-----|-------|-----------------|
|                      | Page Buffer Byte<br>Write Time                     | 2     | TBD | 6.0                | TBD | μs    |                 |
|                      | Page Buffer Word<br>Write Time                     | 2     | TBD | 12.1               | TBD | μs    |                 |
| t <sub>WHRH</sub> 1A | Byte Write Time                                    | 2     | TBD | 11                 | TBD | μs    |                 |
| t <sub>WHRH</sub> 1B | Word Write Time                                    | 2     | TBD | 16                 | TBD | μs    |                 |
| t <sub>WHRH</sub> 2  | Block Write Time                                   | 2     | TBD | 0.8                | TBD | sec   | Byte Write Mode |
| t <sub>WHRH</sub> 3  | Block Write Time                                   | 2     | TBD | 0.6                | TBD | sec   | Word Write Mode |
|                      | Block Erase Time                                   | 2     | TBD | 1.0                | TBD | sec   |                 |
|                      | Full Chip Erase Time                               | 2     | TBD | 32.0               | TBD | sec   |                 |
|                      | Time from Erase<br>Suspend Command to<br>WSM Ready | 4     | TBD | 10                 | TBD | μs    | ×               |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $5.0V \pm 0.25V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Sym    | Parameter                                    | Notes | Min | Typ <sup>(1)</sup> | Max | Units | Test Conditions |
|--------|----------------------------------------------|-------|-----|--------------------|-----|-------|-----------------|
|        | Page Buffer Byte<br>Write Time               | 2     | TBD | 2.1                | TBD | μs    |                 |
|        | Page Buffer Word<br>Write Time               | 2     | TBD | 4.1                | TBD | μs    |                 |
| twhRH1 | Word/Byte Write Time                         | 2     | 4.5 | 6                  | TBD | μs    |                 |
| twhRH2 | Block Write Time                             | 2     | TBD | 0.4                | 2.1 | sec   | Byte Write Mode |
| twhRH3 | Block Write Time                             | 2     | TBD | 0.2                | 1.0 | sec   | Word Write Mode |
|        | Block Erase Time                             | 2     | 0.3 | 0.6                | 10  | sec   |                 |
|        | Full Chip Erase Time                         | 2     | TBD | 19.2               | TBD | sec   |                 |
|        | Time from Erase Suspend Command to WSM Ready | 4     | TBD | 10                 | TBD | μs    |                 |

- 1. 25°C, and nominal voltages.
- 2. Excludes system-level overhead.
- 3. These performance numbers are valid for all speed versions.
- Specification applies to interrupt latency for Single Block Erase. Suspend latency for Erase All Unlocked Block operation extends the latency time to 140 μs (typical).
- 5. Sampled, but not 100% tested. Guaranteed by design.



# 6.0 MECHANICAL SPECIFICATIONS



Figure 19. Mechanical Specifications of the 28F016SV 56-Lead TSOP Type I Package

|                | Family: Th | nin Small Out-Line P                  | ackage  |       |
|----------------|------------|---------------------------------------|---------|-------|
| Symbol         | ,          | Millimeters                           |         | Notes |
| Oymbo.         | Minimum    | Nominal                               | Maximum | Notes |
| Α              |            | · · · · · · · · · · · · · · · · · · · | 1.20    |       |
| A <sub>1</sub> | 0.50       |                                       |         |       |
| A <sub>2</sub> | 0.965      | 0.995                                 | 1.025   |       |
| b              | 0.100      | 0.150                                 | 0.200   | ,     |
| С              | 0.115      | 0.125                                 | 0.135   |       |
| D <sub>1</sub> | 18.20      | 18.40                                 | 18.60   |       |
| E              | 13.80      | 14.00                                 | 14.20   |       |
| е              |            | 0.50                                  |         |       |
| D              | 19.80      | 20.00                                 | 20.20   |       |
| L              | 0.500      | 0.600                                 | 0.700   |       |
| N              |            | 56                                    |         |       |
| Ø              | 0°         | 3°                                    | 5°      |       |
| Y              |            |                                       | 0.100   |       |
| Z              | 0.150      | 0.250                                 | 0.350   |       |





Figure 20. Mechanical Specifications of the 28F016SV 56-Lead SSOP Type I Package

|                | Family: Shrink Small Out-Line Package |             |         |       |  |  |  |  |  |  |  |
|----------------|---------------------------------------|-------------|---------|-------|--|--|--|--|--|--|--|
| Symbol         |                                       | Millimeters |         |       |  |  |  |  |  |  |  |
| Cymbol         | Minimum                               | Nominal     | Maximum | Notes |  |  |  |  |  |  |  |
| Α              |                                       | 1.80        | 1.90    |       |  |  |  |  |  |  |  |
| A1             | 0.47                                  | 0.52        | 0.57    |       |  |  |  |  |  |  |  |
| A2             | 1.18                                  | 1.28        | 1.38    |       |  |  |  |  |  |  |  |
| В              | 0.25                                  | 0.30        | 0.20    |       |  |  |  |  |  |  |  |
| С              | 0.13                                  | 0.15        | 0.20    |       |  |  |  |  |  |  |  |
| D              | 23.40                                 | 23.70       | 24.00   |       |  |  |  |  |  |  |  |
| E              | 13.10                                 | 13.30       | 13.50   |       |  |  |  |  |  |  |  |
| e <sub>1</sub> |                                       | 0.80        |         |       |  |  |  |  |  |  |  |
| He             | 15.70                                 | 16.00       | 16.30   |       |  |  |  |  |  |  |  |
| N              |                                       | 56          |         |       |  |  |  |  |  |  |  |
| L <sub>1</sub> | 0.45                                  | 0.50        | 0.55    |       |  |  |  |  |  |  |  |
| Υ              |                                       |             | 0.10    |       |  |  |  |  |  |  |  |
| а              | 2°                                    | 3°          | 4°      |       |  |  |  |  |  |  |  |
| · b            | 3°                                    | 4°          | 5°      |       |  |  |  |  |  |  |  |
| R1             | 0.15                                  | 0.20        | 0.25    |       |  |  |  |  |  |  |  |
| R2             | 0.15                                  | 0.20        | 0.25    |       |  |  |  |  |  |  |  |



#### **DEVICE NOMENCLATURE AND ORDERING INFORMATION**

E28F016SV-065

DA = COMMERCIAL TEMPERATURE 56-LEAD SSOP E = COMMERCIAL TEMPERATURE 56-LEAD TSOP ACCESS SPEED (ns)

65 ns (5V, 30 pF), 70 ns (5V), 75 ns (3.3V) 70 ns (5V, 30 pF), 80 ns (5V), 120 ns (3.3V)

290528-21

|        |                | Valid Combinations                                                              |                                                                               |                                                                              |  |  |  |  |  |
|--------|----------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--|--|--|--|
| Option | Order Code     | V <sub>CC</sub> = 3.3V ± 0.3V,<br>50 pF load,<br>1.5V I/O Levels <sup>(1)</sup> | V <sub>CC</sub> = 5.0V ± 10%,<br>100 pF load<br>TTL I/O Levels <sup>(1)</sup> | V <sub>CC</sub> = 5.0V ± 5%,<br>30 pF load<br>1.5V I/O Levels <sup>(1)</sup> |  |  |  |  |  |
| 1      | E28F016SV 070  | E28F016SV-120                                                                   | E28F016SV-080                                                                 | E28F016SV-070                                                                |  |  |  |  |  |
| 2      | E28F016SV 065  | E28F016SV-075                                                                   | E28F016SV-070                                                                 | E28F016SV-065                                                                |  |  |  |  |  |
| 3      | DA28F016SV 070 | DA28F016SV-120                                                                  | DA28F016SV-080                                                                | DA28F016SV-070                                                               |  |  |  |  |  |
| 4      | DA28F016SV 065 | DA28F016SV-075                                                                  | DA28F016SV-070                                                                | DA28F016SV-065                                                               |  |  |  |  |  |

#### NOTE:

<sup>1.</sup> See Section 5.2 for Transient Input/Output Reference Waveforms and Testing Load Circuits.



# **ADDITIONAL INFORMATION**

| Order Number                                | Document/Tool                                                                                 |
|---------------------------------------------|-----------------------------------------------------------------------------------------------|
| 297372                                      | 16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016SXS/28F016XD           |
| 292092                                      | AP-357 "Power Supply Solutions for Flash Memory"                                              |
| 292123                                      | AP-374 "Flash Memory Write Protection Techniques"                                             |
| 292124                                      | AP-375 "Upgrade Considerations from the 28F008SA to the 28F016SA"                             |
| 292126                                      | AP-377 "16-Mbit Flash Product Family Software Drivers, 28F016SA/28F016SV/28F016SXS/28F016XD"  |
| 292127                                      | AP-378 "System Optimization Using the Enhanced Features of the 28F016SA"                      |
| 292144                                      | AP-393 "28F016SV Compatibility with 28F016SA"                                                 |
| 294016                                      | ER-33 "ETOX™ Flash Memory Technology—Insight to Intel's Fourth Generation Process Innovation" |
| 290490                                      | DD28F032SA Datasheet                                                                          |
| 290435                                      | 28F008SA Datasheet                                                                            |
| 297508                                      | FlashBuilder Utility                                                                          |
| Contact Intel/Distribution<br>Sales Offices | 28F016SV iBIS Models                                                                          |
| Contact Intel/Distribution<br>Sales Offices | 28F016SV VHDL/Verilog Models                                                                  |
| Contact Intel/Distribution<br>Sales Offices | 28F016SV Timing Designer Library Files                                                        |
| Contact Intel/Distribution<br>Sales Offices | 28F016SV Orcad and ViewLogic Schematic Symbol                                                 |



# **DATASHEET REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 001    | Original Version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 002    | Added 28F016SV-065/-070 at 5.0V V <sub>CC</sub> and 28F016SV-075 at 3.3V V <sub>CC</sub> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|        | Improved burst write transfer rate to 30.8 MB/sec.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|        | Added 56-Lead SSOP Type 1 packaging information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|        | Changed V <sub>PPLK</sub> from 2.0V to 1.5V.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|        | Increased $I_{CCR}$ at 5.0V $V_{CC}$ and 3.3V $V_{CC}$ : $I_{CCR1}$ from 30 mA (typ)/35 mA (max) to 40 mA (typ)/50 mA (max) - $V_{CC}$ = 3.3V $I_{CCR2}$ from 15 mA (typ)/20 mA (max) to 20 mA (typ)/30 mA (max) - $V_{CC}$ = 3.3V $I_{CCR1}$ from 50 mA (typ)/60 mA (max) to 75 mA (typ)/95 mA (max) - $V_{CC}$ = 5.0V $I_{CCR2}$ from 30 mA (typ)/35 mA (max) to 45 mA (typ)/55 mA (max) - $V_{CC}$ = 5.0V Moved AC Characteristics for Extended Register Reads into separate table. Increased $V_{PP}$ MAX from 13V to 14V.  Added Erase Suspend Command Latency times to Section 5.12 Modified Device Nomenclature Section to include SSOP package option and Ordering Information |  |



# 28F016SA 16 MBIT (1 MBIT x 16, 2 MBIT x 8) FlashFile™ MEMORY

- User-Selectable 3.3V or 5V V<sub>CC</sub>
- User-Configurable x8 or x16 Operation
- 70 ns Maximum Access Time
- 28.6 MB/sec Burst Write Transfer Rate
- 1 Million Typical Erase Cycles per Block
- 56-Lead, 1.2mm x 14mm x 20mm TSOP Package
- 56-Lead, 1.8mm x 16mm x 23.7mm SSOP Package

- Revolutionary Architecture
  - Pipelined Command Execution
  - Write During Erase
  - Command Superset of Intel 28F008SA
- 1 mA Typical I<sub>CC</sub> in Static Mode
- 1 µA Typical Deep Power-Down
- 32 Independently Lockable Blocks
- State-of-the-Art 0.6 µm ETOX™ IV Flash Technology

Intel's 28F016SA 16-Mbit FlashFile<sup>TM</sup> memory is a revolutionary architecture which is the ideal choice for designing embedded direct-execute code and mass storage data/file flash memory systems. With innovative capabilities, low-power, extended temperature operation and high read/write performance, the 28F016SA enables the design of truly mobile, high-performance communications and computing products.

The 28F016SA is the highest density, highest performance non-volatile read/write solution for solid-state storage applications. Its symmetrically blocked architecture (100% compatible with the 28F008SA 8-Mbit FlashFile memory), extended cycling, extended temperature operation, flexible  $V_{CC}$ , fast write and read performance and selective block locking provide highly flexible memory components suitable for resident flash arrays, high-density memory cards and PCMCIA-ATA flash drives. The 28F016SA dual read voltage enables the design of memory cards which can interchangeably be read/written in 3.3V and 5.0V systems. Its x8/x16 architecture allows optimization of the memory-to-processor interface. Its high read performance and flexible block locking enable both storage and execution of operating systems and application software. Manufactured no Intel's 0.6  $\mu$ m ETOXTM IV process technology, the 28F016SA is the most cost effective, highest density monolithic 3.3V FlashFile memory.



ETOX™ and FlashFile™ are trademarks of Intel Corporation.

# 28F016SA 16 Mbit (1 Mbit x 16, 2 Mbit x 8) Flashfile™ Memory

| CONTENTS                                                           | PAGE        | CONTENTS                                                         | PAGE           |
|--------------------------------------------------------------------|-------------|------------------------------------------------------------------|----------------|
| 1.0 INTRODUCTION                                                   |             | 5.4 DC Characteristics for $V_{CC} = 3.3V \pm 0.3V$              |                |
| 1.1 Product Overview                                               | 3-361       | 5.5 DC Characteristics for                                       |                |
| 2.0 DEVICE PINOUT/PACKAGES                                         | 3-362       | $V_{CC} = 5.0V \pm 0.5V \dots$                                   |                |
| 2.1 Lead Descriptions                                              | 3-364       | 5.6 AC Characteristics—F Operations                              |                |
| 3.0 MEMORY MAPS                                                    | 3-366       | 5.7 Power-Up and Reset                                           | Γimings 3-387  |
| 3.1 Extended Status Registers M<br>Map                             | 3-367       | 5.8 AC Characteristics for<br>Controlled Command W<br>Operations | /rite          |
| 4.0 BUS OPERATIONS, COMMANI<br>AND STATUS REGISTER<br>DEFINITIONS  | 3-368       | 5.9 AC Characteristics for<br>Controlled Command W<br>Operations | /rite          |
| 4.1 Bus Operations for Word-Wid<br>Mode (Byte# = V <sub>IH</sub> ) | le<br>3-368 | 5.10 AC Characteristics for<br>Buffer Write Operations           | or Page        |
| 4.2 Bus Operations for Byte-Wide Mode (Byte# = V <sub>IL</sub> )   | 3-368       | 5.11 Erase and Word/Byt<br>Performance                           | e Write        |
| 4.3 28F008SA—Compatible Mod<br>Command Bus Definitions             | le<br>3-369 | 6.0 DERATING CURVES                                              | 3-397          |
| 4.4 28F016SA—Performance<br>Enhancement Command Bus<br>Definitions | 3-370       | 7.0 MECHANICAL SPECIFIC FOR TSOP                                 |                |
| 4.5 Compatible Status Register .                                   | 3-371       | 8.0 MECHANICAL SPECIFIC                                          | CATIONS        |
| 4.6 Global Status Register                                         | 3-372       | FOR SSOP                                                         | 3-401          |
| 4.7 Block Status Register                                          |             | DEVICE NOMENCLATURE ORDERING INFORMATION                         |                |
| <b>5.0 COMMERCIAL TEMPERATUR</b>                                   |             |                                                                  |                |
| ELECTRICAL SPECIFICATIONS                                          |             | ADDITIONAL INFORMATION                                           | <b>N</b> 3-402 |
| 5.1 Absolute Maximum Ratings .                                     |             | DATASHEET REVISION HIS                                           | STORY 3-402    |
| 5.2 Capacitance                                                    | 3-375       |                                                                  | 2.23 3.102     |
| 5.3 Timing Nomenclature                                            | 3-376       |                                                                  |                |



#### 1.0 INTRODUCTION

The documentation of the Intel 28F016SA memory device includes this data sheet, a detailed user's manual, and a number of application notes, all of which are referenced at the end of this data sheet.

The data sheet is intended to give an overview of the chip feature-set and of the operating AC/DC specifications. The 28F016SA User's Manual provides complete descriptions of the user modes, system interface examples and detailed descriptions of all principles of operation. It also contains the full list of software algorithm flowcharts, and a brief section on compatibility with Intel 28F008SA.

#### 1.1 Product Overview

The 28F016SA is a high performance 16 Mbit (16,777,216 bit) block erasable non-volatile random access memory organized as either 1 Mword x 16 or 2 Mbyte x 8. The 28F016SA includes thirty-two 64 KB (65,536) blocks or thirty-two 32-KW (32,768) blocks. A chip memory map is shown in Figure 3.

The implementation of a new architecture, with many enhanced features, will improve the device operating characteristics and results in greater product reliability and ease of use.

Among the significant enhancements on the 28F016SA:

- 3.3V Low Power Capability
- Improved Write Performance
- Dedicated Block Write/Erase Protection

A 3/5# input pin reconfigures the device internally for optimized 3.3V or 5.0V read/write operation.

The 28F016SA is available in both a 56-lead, 1.2mm thick, 14mm x 20mm TSOP type 1 package or a 56-lead, 1.8mm thick, 16mm x 23.7mm SSOP package. The TSOP form factor and pinout allow for very high board layout densities.

A Command User Interface (CUI) serves as the system interface between the microprocessor or microcontroller and the internal memory operation.

Internal Algorithm Automation allows Byte/Word Writes and Block Erase operations to be executed using a Two-Write command sequence to the CUI in the same way as the 28F008SA 8-Mbit FlashFile™ memory.

A Superset of commands have been added to the basic 28F008SA command-set to achieve higher write performance and provide additional capabilities. These new commands and features include:

- · Page Buffer Writes to Flash
- Command Queuing Capability
- Automatic Data Writes During Erase
- Software Locking of Memory Blocks
- Two-Byte Successive Writes in 8-bit Systems
- Erase All Unlocked Blocks

Writing of memory data is performed in either byte or word increments typically within 6  $\mu$ sec, a 33% improvement over the 28F008SA. A Block Erase operation erases one of the 32 blocks in typically 0.6 sec, independent of the other blocks, which is about 65% improvement over the 28F008SA.

Each block can be written and erased a minimum of 100,000 cycles. Systems can achieve typically 1 million Block Erase Cycles by providing graceful block retirement. This technique has already been employed in Hard Disk Drive designs. Additionally, wear leveling of block erase cycles can be used to minimize the write/erase performance differences across blocks.

The 28F016SA incorporates two Page Buffers of 256 Bytes (128 Words) each to allow page data writes. This feature can improve a system write performance by up to 4.8 times over previous flash memory devices.

All operations are started by a sequence of Write commands to the device. Three Status Registers (described in detail later) and a RY/BY# output pin provide information on the progress of the requested operation.

While the 28F008SA requires an operation to complete before the next operation can be requested, the 28F016SA allows queuing of the next operation while the memory executes the current operation. This eliminates system overhead when writing several bytes in a row to the array or erasing several blocks at the same time. The 28F016SA can also perform write operations to one block of memory while performing erase of another block.

The 28F016SA provides user-selectable block locking to protect code or data such as Device Drivers, PCMCIA card information, ROM-Executable O/S or Application Code. Each block has an associated non-volatile lock-bit which determines the lock status of the block. In addition, the 28F016SA has a master Write Protect pin (WP#) which prevents any modifications to memory blocks whose lock-bits are set.



The 28F016SA contains three types of Status Registers to accomplish various functions:

- A Compatible Status Register (CSR) which is 100% compatible with the 28F008SA FlashFile memory's Status Register. This register, when used alone, provides a straightforward upgrade capability to the 28F016SA from a 28F008SAbased design.
- A Global Status Register (GSR) which informs the system of command Queue status, Page Buffer status, and overall Write State Machine (WSM) status.
- 32 Block Status Registers (BSRs) which provide block-specific status information such as the block lock-bit status.

The GSR and BSR memory maps for Byte-Wide and Word-Wide modes are shown in Figures 4.1 and 4.2.

The 28F016SA incorporates an open drain RY/BY# output pin. This feature allows the user to OR-tie many RY/BY# pins together in a multiple memory configuration such as a Resident Flash Array.

Other configurations of the RY/BY# pin are enabled via special CUI commands and are described in detail in the 28F016SA User's Manual.

The 28F016SA also incorporates a dual chip-enable function with two input pins,  $CE_0\#$  and  $CE_1\#$ . These pins have exactly the same functionality as the regular chip-enable pin CE# on the 28F008SA. For minimum chip designs,  $CE_1\#$  may be tied to ground and use  $CE_0\#$  as the chip enable input. The 28F016SA uses the logical combination of these two signals to enable or disable the entire chip. Both  $CE_0\#$  and  $CE_1\#$  must be active low to enable the device and if either one becomes inactive, the chip will be disabled. This feature, along with the open drain RY/BY# pin, allows the system designer to reduce the number of control pins used in a large array of 16-Mbit devices.

The BYTE# pin allows either x8 or x16 read/writes to the 28F016SA. BYTE# at logic low selects 8-bit mode with address  $A_0$  selecting between low byte

and high byte. On the other hand, BYTE# at logic high enables 16-bit operation with address  $A_1$  becoming the lowest order address and address  $A_0$  is not used (don't care). A device block diagram is shown in Figure 1.

The 28F016SA is specified for a maximum access time of 70 ns ( $t_{ACC}$ ) at 5.0V operation (4.75V to 5.25V) over the commercial temperature range (0°C to +70°C). A corresponding maximum access time of 120 ns at 3.3V (3.0V to 3.6V and 0°C to +70°C) is achieved for reduced power consumption applications.

The 28F016SA incorporates an Automatic Power Saving (APS) feature which substantially reduces the active current when the device is in static mode of operation (addresses not switching).

In APS mode, the typical  $I_{CC}$  current is 1 mA at 5.0V (0.8 mA at 3.3V).

A Deep Power-Down mode of operation is invoked when the RP# (called  $\overline{PWD}$  on the 28F008SA) pin transitions low. This mode brings the device power consumption to less than 1.0  $\mu\text{A}$ , typically, and provides additional write protection by acting as a device reset pin during power transitions. A reset time of 400 ns is required from RP# switching high until outputs are again valid. In the Deep Power-Down state, the WSM is reset (any current operation will abort) and the CSR, GSR and BSR registers are cleared.

A CMOS Standby mode of operation is enabled when either  $CE_0\#$  or  $CE_1\#$  transitions high and RP# stays high with all input control pins at CMOS levels. In this mode, the device typically draws an  $I_{CC}$  standby current of 50  $\mu$ A.

#### 2.0 DEVICE PINOUT/PACKAGES

The 28F016SA 56L-TSOP Type I pinout configuration is shown in Figure 2. The 56L-SSOP pinout configuration is shown in Figure 3.





Figure 1. 28F016SA Block Diagram
Architectural Evolution Includes Page Buffers, Queue Registers and Extended Status Registers.



# 2.1 Lead Descriptions

| Symbol                               | Туре                 | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub>                       | INPUT                | <b>BYTE-SELECT ADDRESS:</b> Selects between high and low byte when device is in $x8$ mode. This address is latched in $x8$ Data Writes. Not used in $x16$ mode (i.e., the $A_0$ input buffer is turned off when BYTE# is high).                                                                                                                                                                                                                                                                                                                                                                                                     |
| A <sub>1</sub> -A <sub>15</sub>      | INPUT                | <b>WORD-SELECT ADDRESSES:</b> Select a word within one 64-Kbyte block. $A_{6-15}$ selects 1 of 1024 rows, and $A_{1-5}$ selects 16 of 512 columns. These addresses are latched during Data Writes.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| A <sub>16</sub> -A <sub>20</sub>     | INPUT                | <b>BLOCK-SELECT ADDRESSES:</b> Select 1 of 32 Erase blocks. These addresses are latched during Data Writes, Erase and Lock-Block operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DQ <sub>0</sub> -DQ <sub>7</sub>     | INPUT/OUTPUT         | LOW-BYTE DATA BUS: Inputs data and commands during CUI write cycles. Outputs array, buffer, identifier or status data in the appropriate Read mode. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                                                                                                                                                                                                                                                                                               |
| DQ <sub>8</sub> -DQ <sub>15</sub>    | INPUT/OUTPUT         | HIGH-BYTE DATA BUS: Inputs data during x16 Data-Write operations. Outputs array, buffer or identifier data in the appropriate Read mode; not used for Status register reads. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                                                                                                                                                                                                                                                                      |
| CE <sub>0</sub> #, CE <sub>1</sub> # | INPUT                | CHIP ENABLE INPUTS: Activate the device's control logic, input buffers, decoders and sense amplifiers. With either CE <sub>0</sub> # or CE <sub>1</sub> # high, the device is de-selected and power consumption reduces to Standby levels upon completion of any current Data-Write or Erase operations. Both CE <sub>0</sub> #, CE <sub>1</sub> # must be low to select the device.  All timing specifications are the same for both signals. Device Selection occurs with the latter falling edge of CE <sub>0</sub> # or CE <sub>1</sub> #. The first rising edge of CE <sub>0</sub> # or CE <sub>1</sub> # disables the device. |
| RP#                                  | INPUT                | RESET/POWER-DOWN: RP# low places the device in a Deep Power-Down state. All circuits that burn static power, even those circuits enabled in standby mode, are turned off. When returning from Deep Power-Down, a recovery time of 400 ns is required to allow these circuits to power-up.  When RP# goes low, any current or pending WSM operation(s) are terminated, and the device is reset. All Status registers return to ready (with all status flags cleared).                                                                                                                                                                |
| OE#                                  | INPUT                | OUTPUT ENABLE: Gates device data through the output buffers when low. The outputs float to tri-state off when OE# is high.  NOTE:  CE <sub>x</sub> # overrides OE#, and OE# overrides WE#.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| WE#                                  | INPUT                | WRITE ENABLE: Controls access to the CUI, Page Buffers, Data Queue Registers and Address Queue Latches. WE# is active low, and latches both address and data (command or array) on its rising edge.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RY/BY#                               | OPEN DRAIN<br>OUTPUT | <b>READY/BUSY:</b> Indicates status of the internal WSM. When low, it indicates that the WSM is busy performing an operation. RY/BY # high indicates that the WSM is ready for new operations (or WSM has completed all pending operations), or Erase is Suspended, or the device is in deep power-down mode. This output is always active (i.e., not floated to tri-state off when OE# or CE <sub>0</sub> #, CE <sub>1</sub> # are high), except if a RY/BY# Pin Disable command is issued.                                                                                                                                        |



# 2.1 Lead Descriptions (Continued)

| Symbol          | Туре   | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WP#             | INPUT  | WRITE PROTECT: Erase blocks can be locked by writing a non-volatile lock-bit for each block. When WP# is low, those locked blocks as reflected by the Block-Lock Status bits (BSR.6), are protected from inadvertent Data Writes or Erases. When WP# is high, all blocks can be Written or Erased regardless of the state of the lock-bits. The WP# input buffer is disabled when RP# transitions low (deep power-down mode). |
| BYTE#           | INPUT  | BYTE ENABLE: BYTE # low places device in x8 mode. All data is then input or output on $DQ_{0-7}$ , and $DQ_{8-15}$ float. Address A0 selects between the high and low byte. BYTE # high places the device in x16 mode, and turns off the $A_0$ input buffer. Address $A_1$ , then becomes the lowest order address.                                                                                                           |
| 3/5#            | INPUT  | 3.3/5.0 VOLT SELECT: 3/5# high configures internal circuits for 3.3V operation. 3/5# low configures internal circuits for 5.0V operation. NOTES: Reading the array with 3/5# high in a 5.0V system could damage the device. There is a significant delay from 3/5# switching to valid data.                                                                                                                                   |
| V <sub>PP</sub> | SUPPLY | <b>ERASE/WRITE POWER SUPPLY:</b> For erasing memory array blocks or writing words/bytes/pages into the flash array.                                                                                                                                                                                                                                                                                                           |
| V <sub>CC</sub> | SUPPLY | <b>DEVICE POWER SUPPLY (3.3V</b> $\pm$ <b>0.3V, 5.0V</b> $\pm$ <b>0.5V):</b> Do not leave any power pins floating.                                                                                                                                                                                                                                                                                                            |
| GND             | SUPPLY | GROUND FOR ALL INTERNAL CIRCUITRY: Do not leave any ground pins floating.                                                                                                                                                                                                                                                                                                                                                     |
| NC              |        | NO CONNECT: No internal connection to die, lead may be driven or left floating.                                                                                                                                                                                                                                                                                                                                               |



Figure 2. TSOP Pinout Configuration





**Figure 3. SSOP Pinout Configuration** 

# 3.0 MEMORY MAPS



Figure 4. 28F016SA Memory Map (Byte-wide mode)



# 3.1 Extended Status Registers Memory Map

| -                                                 |                                                                           |
|---------------------------------------------------|---------------------------------------------------------------------------|
| X8 MODE                                           | A[20:0]                                                                   |
| RESERVED GSR RESERVED BSR31 RESERVED RESERVED     | 1F0006H<br>1F0005H<br>1F0004H<br>1F0003H<br>1F0002H<br>1F0000H            |
| RESERVED                                          | 010002H                                                                   |
| RESERVED  GSR  RESERVED  BSR0  RESERVED  RESERVED | 000006H<br>000005H<br>000004H<br>000003H<br>000002H<br>000001H<br>000000H |

Figure 5.1 Extended Status Register Memory Map (Byte-wide mode)



Figure 5.2 Extended Status Register Memory Map (Word-wide mode)



### 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS

## 4.1 Bus Operations for Word-Wide Mode (BYTE $\# = V_{IH}$ )

| Mode            | Notes | RP#             | CE <sub>1</sub> #                                     | CE <sub>0</sub> #                  | OE#             | WE#             | A <sub>1</sub>  | DQ <sub>0-15</sub> | RY/BY#          |
|-----------------|-------|-----------------|-------------------------------------------------------|------------------------------------|-----------------|-----------------|-----------------|--------------------|-----------------|
| Read            | 1,2,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                    | V <sub>IL</sub> | V <sub>IH</sub> | Х               | D <sub>OUT</sub>   | Х               |
| Output Disable  | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                    | V <sub>IH</sub> | V <sub>IH</sub> | Х               | High Z             | X               |
| Standby         | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IH</sub><br>V <sub>IH</sub> | Х               | X               | X               | High Z             | Х               |
| Deep Power-Down | 1,3   | V <sub>IL</sub> | Х                                                     | Х                                  | Х               | Х               | Х               | High Z             | V <sub>OH</sub> |
| Manufacturer ID | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                    | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 0089H              | V <sub>OH</sub> |
| Device ID       | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                    | V <sub>IL</sub> | V <sub>IH</sub> | ·VIH            | 66A0H              | V <sub>OH</sub> |
| Write           | 1,5,6 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                    | V <sub>IH</sub> | V <sub>IL</sub> | Х               | D <sub>IN</sub>    | Х               |

# 4.2 Bus Operations For Byte-Wide Mode (BYTE $\# = V_{IL}$ )

| Mode            | Notes | RP#             | CE <sub>1</sub> #                                     | CE <sub>0</sub> #                                     | OE#             | WE#             | A <sub>0</sub>  | DQ <sub>0-7</sub> | RY/BY#            |
|-----------------|-------|-----------------|-------------------------------------------------------|-------------------------------------------------------|-----------------|-----------------|-----------------|-------------------|-------------------|
| Read            | 1,2,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | X               | D <sub>OUT</sub>  | Х                 |
| Output Disable  | 1,6,7 | V <sub>IH</sub> | VIL                                                   | VIL                                                   | V <sub>IH</sub> | V <sub>IH</sub> | Х               | High Z            | Х                 |
| Standby         | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IH</sub> | Х               | Х               | ×               | High Z            | Х                 |
| Deep Power-Down | 1,3   | V <sub>IL</sub> | X                                                     | Х                                                     | .X              | ×               | Х               | High Z            | V <sub>OH</sub>   |
| Manufacturer ID | 4     | V <sub>IH</sub> | · V <sub>IL</sub>                                     | V <sub>IL</sub>                                       | VIL             | V <sub>IH</sub> | V <sub>IL</sub> | 89H               | V <sub>OH</sub> ` |
| Device ID       | 4     | V <sub>IH</sub> | VIL                                                   | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | A0H               | V <sub>OH</sub>   |
| Write           | 1,5,6 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IL</sub> | Х               | D <sub>IN</sub>   | х                 |

#### **NOTES:**

- 1. X can be VIH or VIL for address or control pins except for RY/BY#, which is either VOL or VOH.
- 2. RY/BY# output is open drain. When the WSM is ready, Erase is suspended or the device is in deep power-down mode, RY/BY# will be at  $V_{OH}$  if it is tied to  $V_{CC}$  through a resistor. RY/BY# at  $V_{OH}$  is independent of OE# while a WSM operation is in progress.
- 3. RP# at GND ± 0.2V ensures the lowest deep power-down current.
- 4. Ao and A1 at VIL provide manufacturer ID codes in x8 and x16 modes repectively.
- A<sub>0</sub> and A<sub>1</sub> at V<sub>IH</sub> provide device ID codes in x8 and x16 modes repectively. All other addresses are set to zero.
- 5. Commands for different Erase operations, Data Write operations or Lock-Block operations can only be successfully completed when V<sub>PP</sub> = V<sub>PPH</sub>.
- 6. While the WSM is running, RY/BY# in Level-Mode (default) stays at V<sub>OL</sub> until all operations are complete. RY/BY# goes to V<sub>OH</sub> when the WSM is not busy or in erase suspend mode.
- 7. RY/BY# may be at V<sub>OL</sub> while the WSM is busy performing various operations. For example, a status register read during a write operation.



### 4.3 28F008SA—Compatible Mode Command Bus Definitions

| Command                         | Notes | Fir   | st Bus Cy | cle  | Second Bus Cycle |      |      |
|---------------------------------|-------|-------|-----------|------|------------------|------|------|
| Communa                         | Notes | Oper  | Addr      | Data | Oper             | Addr | Data |
| Read Array                      |       | Write | Х         | FFH  | Read             | AA   | AD   |
| intelligent identifier          | 1     | Write | Х         | 90H  | Read             | IA   | ID   |
| Read Compatible Status Register | 2     | Write | Х         | 70H  | Read             | Х    | CSRD |
| Clear Status Register           | 3     | Write | Х         | 50H  |                  |      |      |
| Word/Byte Write                 |       | Write | Х         | 40H  | Write            | WA   | WD   |
| Alternate Word/Byte Write       |       | Write | Х         | 10H  | Write            | WA   | WD   |
| Block Erase/Confirm             |       | Write | Х         | 20H  | Write            | BA   | D0H  |
| Erase Suspend/Resume            |       | Write | X         | вон  | Write            | X    | D0H  |

#### **ADDRESS**

AA = Array Address
BA = Block Address
IA = Identifier Address
WA = Write Address
X = Don't Care

#### DATA

AD = Array Data CSRD = CSR Data ID = Identifier Data WD = Write Data

#### NOTES:

- 1. Following the intelligent identifier command, two Read operations access the manufacturer and device signature codes.
- 2. The CSR is automatically available after device enters Data Write, Erase, or Suspend operations.
- Clears CSR.3, CSR.4 and CSR.5. Also clears GSR.5 and all BSR.5 and BSR.2 bits.
   See Status register definitions.



#### 4.4 28F016SA—Performance Enhancement Command Bus Definitions

| Command                              | Mode   | Notes    | First Bus Cycle |      | Second Bus Cycle |       |                | Third Bus Cycle |       |      |         |
|--------------------------------------|--------|----------|-----------------|------|------------------|-------|----------------|-----------------|-------|------|---------|
| Command                              | in ouc |          | Oper            | Addr | Data             | Oper  | Addr           | Data            | Oper  | Addr | Data    |
| Read Extended<br>Status Register     |        | 1        | Write           | Х    | 71H              | Read  | RA             | GSRD<br>BSRD    |       |      |         |
| Page Buffer Swap                     |        | 7        | Write           | Х    | 72H              |       |                |                 |       |      |         |
| Read Page Buffer                     |        |          | Write           | Х    | 75H              | Read  | PA             | PD              |       |      |         |
| Single Load to<br>Page Buffer        |        |          | Write           | ×    | 74H              | Write | PA             | PD              |       | ,    |         |
| Sequential Load to                   | х8     | 4,6,10   | Write           | Х    | E0H              | Write | Х              | BCL             | Write | Х    | ВСН     |
| Page Buffer                          | x16    | 4,5,6,10 | Write           | Х    | E0H              | Write | Х              | WCL .           | Write | Х    | WCH     |
| Page Buffer Write                    | х8     | 3,4,9,10 | Write           | Х    | 0CH              | Write | A <sub>0</sub> | BC(L,H)         | Write | WA   | BC(H,L) |
| to Flash                             | x16    | 4,5,10   | Write           | Х    | 0CH              | Write | Х              | WCL             | Write | WA   | WCH     |
| Two-Byte Write                       | х8     | 3        | Write           | Х    | FBH              | Write | A <sub>0</sub> | WD(L,H)         | Write | WA   | WD(H,L) |
| Lock Block/Confirm                   |        |          | Write           | Х    | 77H              | Write | ВА             | D0H             |       |      |         |
| Upload Status<br>Bits/Confirm        |        | 2        | Write           | х    | 97H              | Write | Х              | D0H             |       |      |         |
| Upload Device<br>Information         |        |          | Write           | X    | 99H              | Write | Х              | D0H             |       |      | . *     |
| Erase All Unlocked<br>Blocks/Confirm |        | -        | Write           | Х    | А7Н              | Write | Х              | D0H             | ,     |      |         |
| RY/BY# Enable to<br>Level-Mode       |        | 8        | Write           | х    | 96H              | Write | Х              | 01H             |       |      |         |
| RY/BY# Pulse-On-<br>Write            | ,      | 8        | Write           | Х    | 96H              | Write | Х              | 02H             |       |      |         |
| RY/BY# Pulse-On-<br>Erase            |        | 8        | Write           | X    | 96H              | Write | Х              | 03H             |       |      |         |
| RY/BY# Disable                       |        | 8        | Write           | Х    | 96H              | Write | Х              | 04H             |       |      |         |
| Sleep                                |        |          | Write           | Х    | FOH              |       |                |                 |       |      |         |
| Abort                                |        |          | Write           | Х    | 80H              |       |                |                 |       |      |         |

#### **ADDRESS**

BA = Block Address PA = Page Buffer Address RA = Extended Register Address

WA = Write Address

X = Don't Care

#### DATA

AD = Array Data PD = Page Buffer Data BSRD = BSR Data

GSRD = GSR Data

WC (L,H) = Word Count (Low, High) BC (L,H) = Byte Count (Low, High) WD (L,H) = Write Data (Low, High)



#### NOTES:

- 1. RA can be the GSR address or any BSR address. See Figures 4.1 and 4.2 for Extended Status Register Memory Maps.
- 2. Upon device power-up, all BSR lock-bits come up locked. The Upload Status Bits command must be written to reflect the actual lock-bit status.
- 3. A<sub>0</sub> is automatically complemented to load second byte of data. BYTE# must be at V<sub>IL</sub>.
- $A_0$  value determines which WD/BC is supplied first:  $A_0 = 0$  looks at the WDL/BCL,  $A_0 = 1$  looks at the WDH/BCH.
- 4. BCH/WCH must be at 00H for this product because of the 256-Byte (128 Word) Page Buffer size and to avoid writing the Page Buffer contents into more than one 256-Byte segment within an array block. They are simply shown for future Page Buffer expandability.
- 5. In x16 mode, only the lower byte DQ<sub>0-7</sub> is used for WCL and WCH. The upper byte DQ<sub>8-15</sub> is a don't care.
- 6. PA and PD (whose count is given in cycles 2 and 3) are supplied starting in the 4th cycle which is not shown.
- 7. This command allows the user to swap between available Page Buffers (0 or 1).
- 8. These commands reconfigure RY/BY# output to one of two pulse-modes or enable and disable the RY/BY# function.
- 9. Write address, WA, is the Destination address in the flash array which must match the Source address in the Page Buffer. Refer to the 28F016SA User's Manual.
- 10. BCL = 00H corresponds to a Byte count of 1. Similarly, WCL = 00H corresponds to a Word count of 1.

### 4.5 Compatible Status Register

| WSMS | ESS | ES | DWS | VPPS | R | R | R |
|------|-----|----|-----|------|---|---|---|
| 7    | 6   | 5  | 4   | 3    | 2 | 1 | 0 |

CSR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

RY/BY# output or WSMS bit must be checked to determine completion of an operation (Erase Suspend, Erase or Data Write) before the appropriate Status bit (ESS, ES or DWS) is checked for success.

CSR.6 = ERASE-SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

CSR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

improper command sequence was entered. Clear the CSR and attempt the operation again.

CSR.4 = DATA-WRITE STATUS

1 = Error in Data Write

0 = Data Write Successful

CSR.3 = Vpp STATUS

1 = Vpp Low Detect, Operation

Abort

 $0 = V_{PP} OK$ 

The VPPS bit, unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM interrogates V<sub>PP</sub>'s level only after the Data-Write or Erase command sequences have been entered, and informs the system if V<sub>PP</sub> has not been switched on. VPPS is not guaranteed to report accurate feedback between V<sub>PPI</sub> and V<sub>PPH</sub>.

If DWS and ES are set to "1" during an erase attempt, an

CSR.2-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the CSR.



## 4.6 Global Status Register

| WSMS | OSS | DOS | DSS | QS             | PBAS | PBS | PBSS |
|------|-----|-----|-----|----------------|------|-----|------|
| 7    | 6   | 5   | 4   | <sup>1</sup> 3 | 2    | . 1 | 0    |

GSR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busv

NOTES:

[1] RY/BY# output or WSMS bit must be checked to determine completion of an operation (Block Lock, Suspend, any RY/BY# reconfiguration, Upload Status Bits, Erase or Data Write) before the appropriate Status bit (OSS or DOS) is checked for success.

GSR.6 = OPERATION SUSPEND STATUS

1 = Operation Suspended

0 = Operation in Progress/Completed

GSR.5 = DEVICE OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

GSR.4 = DEVICE SLEEP STATUS

1 = Device in Sleep

0 = Device Not in Sleep

MATRIX 5/4

0 0 = Operation Successful or Currently Running

0 1 = Device in Sleep Mode or Pending Sleep

10 = Operation Unsuccessful

1 1 = Operation Unsuccessful or Aborted

If operation currently running, then GSR.7 = 0. If device pending sleep, then GSR.7 = 0.

Operation aborted: Unsuccessful due to Abort command.

GSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

GSR.2 = PAGE BUFFER AVAILABLE STATUS

1 = One or Two Page Buffers Available

0 = No Page Buffer Available

The device contains two Page Buffers.

GSR.1 = PAGE BUFFER STATUS

1 = Selected Page Buffer Ready

0 = Selected Page Buffer Busy

Selected Page Buffer is currently busy with WSM operation

GSR.0 = PAGE BUFFER SELECT STATUS

1 = Page Buffer 1 Selected

0 = Page Buffer 0 Selected

#### NOTE:

1. When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



#### 4.7 Block Status Register

| BS | BLS | BOS | BOAS | QS | VPPS | R | R |
|----|-----|-----|------|----|------|---|---|
| 7  | 6   | 5   | 4    | 3  | 2    | 1 | 0 |

BSR.7 = BLOCK STATUS

1 = Ready

0 = Busy

NOTES:

[1] RY/BY# output or BS bit must be checked to determine completion of an operation (Block Lock, Suspend, Erase or Data Write) before the appropriate Status bits (BOS, BLS) is checked for success.

BSR.6 = BLOCK-LOCK STATUS

1 = Block Unlocked for Write/Erase

0 = Block Locked for Write/Erase

BSR.5 = BLOCK OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

BSR.4 = BLOCK OPERATION ABORT STATUS

1 = Operation Aborted

The BOAS bit will not be set until BSR.7=1.

0 = Operation Not Aborted

MATRIX 5/4

0.0 = Operation Successful or

Currently Running
0 1 = Not a Valid Combination

1 0 = Operation Unsuccessful

1 1 = Operation Aborted

Operation halted via Abort command.

BSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

BSR.2 = V<sub>PP</sub> STATUS

1 = V<sub>PP</sub> Low Detect, Operation Abort

 $0 = V_{PP} OK$ 

#### NOTES:

BSR.1-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the BSRs.

1. When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



#### 5.0 ELECTRICAL SPECIFICATIONS

#### 5.1 Absolute Maximum Ratings\*

Temperature Under Bias ......0°C to +80°C Storage Temperature .....-65°C to +125°C

NOTICE: This data sheet contains preliminary information on new products in production. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### **COMMERCIAL TEMPERATURE OPERATION**

 $V_{CC} = 3.3V \pm 0.3V \text{ Systems}^{(5)}$ 

| Symbol          | Parameter                                                                         | Notes | Min  | Max                      | Units | Test Conditions     |
|-----------------|-----------------------------------------------------------------------------------|-------|------|--------------------------|-------|---------------------|
| T <sub>A</sub>  | Operating Temperature, Commercial                                                 | 1     | 0    | 70                       | .°C   | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                               | 2     | -0.2 | 7.0                      | ٧     |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                                | 2,3   | -0.2 | 14.0                     | ٧     |                     |
| V               | Voltage on any Pin (except V <sub>CC</sub> ,V <sub>PP</sub> ) with Respect to GND | 2     | -0.5 | V <sub>CC</sub><br>+ 0.5 | ٧     |                     |
| 1               | Current into any Non-Supply Pin                                                   |       |      | ± 30                     | mA    |                     |
| lout            | Output Short Circuit Current                                                      | 4     |      | 100                      | mA    |                     |

# $V_{CC} = 5.0V \pm 0.5V$ , $V_{CC} = 5.0V \pm 0.25V$ Systems<sup>(5,6)</sup>

| Symbol          | Parameter                                                                         | Notes | Min  | Max  | Units | Test Conditions     |
|-----------------|-----------------------------------------------------------------------------------|-------|------|------|-------|---------------------|
| T <sub>A</sub>  | Operating Temperature, Commercial                                                 | 1     | 0    | 70   | °C    | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                               | 2     | -0.2 | 7.0  | ٧     |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                                | 2,3   | -0.2 | 14.0 | ٧     |                     |
| ٧               | Voltage on any Pin (except V <sub>CC</sub> ,V <sub>PP</sub> ) with Respect to GND | 2     | -2.0 | 7.0  | ٧     |                     |
| I               | Current into any Non-Supply Pin                                                   |       |      | ± 30 | mA    | ,                   |
| lout            | Output Short Circuit Current                                                      | 4     |      | 100  | mA    |                     |

#### NOTES

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC}+0.5$ V which, during transitions, may overshoot to  $V_{CC}+2.0$ V for periods <20 ns.
- 3. Maximum DC voltage on V<sub>PP</sub> may overshoot to +14.0V for periods <20ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.
- 6. 5% V<sub>CC</sub> specifications refer to the 28F016SA-70 in its High Speed Test configuration.



# 5.2 Capacitance

# For a 3.3V System:

| Symbol            | Parameter                                                    | Note | Тур | Max | Units | Test Conditions                          |
|-------------------|--------------------------------------------------------------|------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin              | 1    | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an Output Pin                       | 1    | 8   | 12  | pF    | T <sub>A</sub> = 25°C, f = 1.0 MHz       |
| C <sub>LOAD</sub> | Load Capacitance Driven by Outputs for Timing Specifications | 1    |     | 50  | pF    | For $V_{CC} = 3.3V \pm 0.3V$             |
|                   | Equivalent Testing Load Circuit                              |      |     | 2.5 | ns    | $50\Omega$ transmission line delay       |

#### For a 5.0V System:

| Symbol                                               | Parameter                                             | Note | Тур | Max | Units | Test Conditions                             |
|------------------------------------------------------|-------------------------------------------------------|------|-----|-----|-------|---------------------------------------------|
| C <sub>IN</sub>                                      | Capacitance Looking into an Address/Control Pin       | 1    | 6   | 8   | pF.   | $T_A = 25^{\circ}C$ , $f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>                                     | Capacitance Looking into an Output Pin                | 1    | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$    |
| C <sub>LOAD</sub> Load Capacitance Driven by Outputs |                                                       | 1    |     | 100 | pF    | For $V_{CC} = 5.0V \pm 0.5V$                |
|                                                      | for Timing Specifications                             |      |     | 30  | pF    | For $V_{CC} = 5.0V \pm 0.25V$               |
|                                                      | Equivalent Testing Load Circuit for $V_{CC} \pm 10\%$ |      |     | 2.5 | ns    | $25\Omega$ transmission line delay          |
|                                                      | Equivalent Testing Load Circuit for $V_{CC} \pm 5\%$  |      |     | 2.5 | ns    | $83\Omega$ transmission line delay          |

## NOTE:

<sup>1.</sup> Sampled, not 100% tested.



### 5.3 Timing Nomenclature

All 3.3V system timings are measured from where signals cross 1.5V.

For 5.0V systems use the standard JEDEC cross point definitions.

Each timing parameter consists of 5 characters. Some common examples are defined below:

t<sub>CE</sub> t<sub>ELQV</sub> time(t) from CE# (E) going low (L) to the outputs (Q) becoming valid (V)

t<sub>OE</sub> t<sub>GLQV</sub> time(t) from OE# (G) going low (L) to the outputs (Q) becoming valid (V)

t<sub>ACC</sub> t<sub>AVQV</sub> time(t) from address (A) valid (V) to the outputs (Q) becoming valid (V)

t<sub>AS</sub> t<sub>AVWH</sub> time(t) from address (A) valid (V) to WE# (W) going high (H)

t<sub>DH</sub> t<sub>WHDX</sub> time(t) from WE# (W) going high (H) to when the data (D) can become undefined (X)

| · · · · · · · · · · · · · · · · · · · | Pin Characters                  |   | Pin States                        |
|---------------------------------------|---------------------------------|---|-----------------------------------|
| Α                                     | Address Inputs                  | Н | High                              |
| D                                     | Data Inputs                     | L | Low                               |
| Q                                     | Data Outputs                    | V | Valid                             |
| Е                                     | CE# (Chip Enable)               | Х | Driven, but not necessarily valid |
| F                                     | BYTE# (Byte Enable)             | Z | High Impedance                    |
| G                                     | OE# (Output Enable)             |   |                                   |
| W                                     | WE# (Write Enable)              |   | :                                 |
| Р                                     | RP# (Deep Power-Down Pin)       |   |                                   |
| R                                     | RY/BY# (Ready Busy)             |   |                                   |
| V                                     | Any Voltage Level               |   |                                   |
| Υ                                     | 3/5# Pin                        |   | ·                                 |
| 5V                                    | V <sub>CC</sub> at 4.5V Minimum |   |                                   |
| 3V                                    | V <sub>CC</sub> at 3.0V Minimum |   |                                   |





290489-4

AC test inputs are driven at  $V_{OH}$  (2.4 VTTL) for a Logic "1" and  $V_{OL}$  (0.45 VTTL) for a Logic "0". Input timing begins at  $V_{IH}$  (2.0 VTTL) and  $V_{IL}$  (0.8 VTTL). Output timing ends at  $V_{IH}$  and  $V_{IL}$ . Input rise and fall times (10% to 90%) < 10 ns.

Figure 6. Transient Input/Output Reference Waveform ( $V_{CC} = 5.0V \pm 10\%$ ) for Standard Test Configuration(1)



AC test inputs are driven at 3.0V for a Logic "1" and 0.0V for a Logic "0". Input timing begins, and output timing ends, at 1.5V. Input rise and fall times (10% to 90%) < 10 ns.

Figure 7. Transient Input/Output Reference Waveform (V<sub>CC</sub> = 3.3V) High Speed Reference Waveform<sup>(2)</sup> (V<sub>CC</sub> = 5.0V  $\pm$  5%)

#### NOTES:

- 1. Testing characteristics for 28F016SA-080/28F016SA-100.
- 2. Testing characteristics for 28F016SA-070/28F016SA-120/28F016SA-150.





Figure 8. Transient Equivalent Testing Load Circuit ( $V_{CC} = 5.0V \pm 10\%$ )



Figure 9. Transient Equivalent Testing Load Circuit ( $V_{CC}=3.3V\pm0.3V$ )



Figure 10. High Speed Transient Equivalent Testing Load Circuit (V $_{CC} = 5.0 V \pm 5\%$ )



# 5.4 DC Characteristics: COMMERCIAL TEMPERATURE

 $V_{CC}=3.3V\pm0.3V,\,T_A=0^{\circ}C$  to  $+70^{\circ}C$  3/5# = Pin Set High for 3.3V Operations

| Symbol             | Parameter                                  | Notes   | Min | Тур | Max | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|--------------------------------------------|---------|-----|-----|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IĮL                | Input Load Current                         | 1       |     |     | ±1  | μΑ    | V <sub>CC</sub> = V <sub>CC</sub> Max, V <sub>IN</sub> = V <sub>CC</sub> or GND                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ILO                | Output Leakage<br>Current                  | 1       |     |     | ±10 | μА    | $V_{CC} = V_{CC} Max$ , $V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Iccs               | V <sub>CC</sub> Standby Current            | 1, 5    |     | 50  | 100 | μΑ    | $\begin{split} &V_{CC} = V_{CC}  \text{Max,} \\ &CE_0\#, CE_1\#, RP\#, = V_{CC} \pm 0.2V \\ &BYTE\#, WP\#, 3/5\# = V_{CC} \pm \\ &0.2V  \text{or GND} \pm 0.2V \end{split}$                                                                                                                                                                                                                                                                                                                                                           |
|                    |                                            | ,       |     | 1   | 4   | mA    | $V_{CC} = V_{CC}$ Max,<br>$CE_0\#$ , $CE_1\#$ , $RP\# = V_{IH}$<br>BYTE#, $WP\#$ , 3/5# = $V_{IH}$ or $V_{IL}$                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ICCD               | V <sub>CC</sub> Deep Power-Down<br>Current | 1       |     | 1   | 5   | μΑ    | $\label{eq:RP#} \begin{split} \text{RP\#} &= \text{GND}  \pm  0.2 \text{V} \\ \text{BYTE\#} &= \text{V}_{\text{CC}}  \pm  0.2 \text{V}  \text{or GND}  \pm  0.2 \text{V} \end{split}$                                                                                                                                                                                                                                                                                                                                                 |
| ICCR1              | V <sub>CC</sub> Read Current               | 1, 4, 5 |     | 30  | 35  | mA    | $\begin{split} &V_{CC} = V_{CC} \text{ Max,} \\ &C\text{MOS: CE}_0 \#, \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ &\text{BYTE} \# = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ &\text{Inputs} = \text{GND} \pm 0.2 \text{V or} \\ &V_{CC} \pm 0.2 \text{V,} \\ &\text{TTL: CE}_0 \#, \text{CE}_1 \# = \text{V}_{IL}, \\ &\text{BYTE} \# = \text{V}_{IL} \text{ or } \text{V}_{IH} \\ &\text{Inputs} = \text{V}_{IL} \text{ or } \text{V}_{IH}, \\ &\text{f} = 8 \text{ MHz, I}_{OUT} = 0 \text{ mA} \end{split}$ |
| I <sub>CCR</sub> 2 | V <sub>CC</sub> Read Current               | 1, 4, 5 |     | 15  | 20  | mA    | $\begin{split} &V_{CC} = V_{CC}\text{Max},\\ &C\text{MOS: CE}_0\#, \text{CE}_1\# =\\ &\text{GND} \pm 0.2\text{V, BYTE}\# = V_{CC}\\ &\pm 0.2\text{V or GND} \pm 0.2\text{V}\\ &\text{Inputs} = \text{GND} \pm 0.2\text{V or}\\ &V_{CC} \pm 0.2\text{V,}\\ &\text{TTL: CE}_0\#, \text{CE}_1\# = \text{V}_{IL}\\ &\text{BYTE}\# = \text{V}_{IH}\text{or}\text{V}_{IL}\\ &\text{Inputs} = \text{V}_{IL}\text{or}\text{V}_{IH},\\ &\text{f} = 4\text{MHz, I}_{OUT} = 0\text{mA} \end{split}$                                              |
| Iccw               | V <sub>CC</sub> Write Current              | 1       |     | 8   | 12  | mA    | Word/Byte Write in<br>Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ICCE               | V <sub>CC</sub> Block Erase<br>Current     | 1       |     | 6   | 12  | mA    | Block Erase in Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ICCES              | V <sub>CC</sub> Erase Suspend<br>Current   | 1, 2    |     | 3   | 6   | mA    | $CE_0\#$ , $CE_1\#=V_{IH}$<br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| I <sub>PPS</sub>   | V <sub>PP</sub> Standby Current            | 1       |     | ±1  | ±10 | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| I <sub>PPD</sub>   | V <sub>PP</sub> Deep Power-Down<br>Current | 1       |     | 0.2 | 5   | μА    | RP# = GND ±0.2V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



#### 5.4 DC Characteristics: COMMERCIAL TEMPERATURE (Continued)

 $V_{CC}=3.3V\pm0.3V, T_A=0^{\circ}C$  to  $+70^{\circ}C$  3/5# = Pin Set High for 3.3V Operations

| Symbol            | Parameter                                         | Notes | Min                   | Тур  | Max                   | Units | Test Conditions                                                     |
|-------------------|---------------------------------------------------|-------|-----------------------|------|-----------------------|-------|---------------------------------------------------------------------|
| I <sub>PPR</sub>  | V <sub>PP</sub> Read Current                      | 1     | 65                    |      | 200                   | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                   |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                     | 1     |                       | 10   | 15                    | - mA  | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Word/Byte Write in Progress |
| IPPE              | V <sub>PP</sub> Erase Current                     | 1     |                       | 4    | 10                    | mA .  | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Block Erase in Progress     |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend<br>Current          | 1     | 65                    |      | 200                   | μА    | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Block Erase Suspended       |
| V <sub>IL</sub>   | Input Low Voltage                                 |       | -0.3                  |      | 0.8                   | ٧     |                                                                     |
| V <sub>IH</sub>   | Input High Voltage                                |       | 2.0                   |      | V <sub>CC</sub> + 0.3 | ٧     |                                                                     |
| V <sub>OL</sub>   | Output Low Voltage                                |       | ,                     |      | 0.4                   | ٧     | $V_{CC} = V_{CC}$ Min and $I_{OL} = 4$ mA                           |
| V <sub>OH</sub> 1 | Output High Voltage                               | ,     | 2.4                   |      |                       | ٧     | $I_{OH} = -2.0 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$            |
| V <sub>OH</sub> 2 |                                                   |       | V <sub>CC</sub> - 0.2 |      |                       |       | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$            |
| V <sub>PPL</sub>  | V <sub>PP</sub> during Normal<br>Operations       | 3     | 0.0                   |      | 6.5                   | V     |                                                                     |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Write/<br>Erase Operations |       | 11.4                  | 12.0 | 12.6                  | ٧     |                                                                     |
| V <sub>LKO</sub>  | V <sub>CC</sub> Erase/Write<br>Lock Voltage       |       | 2.0                   |      |                       | . V   |                                                                     |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 3.3V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum of  $I_{CCE}$  and  $I_{CCR}$ .

  3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the
- range between VPPH and VPPL.
- 4. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA in static operation.
- 5. CMOS Inputs are either  $V_{CC}$   $\pm$  0.2V or GND  $\pm$  0.2V. TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .



## 5.5 DC Characteristics: COMMERCIAL TEMPERATURE

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$  3/5# Pin Set Low for 5V Operations

| Symbol             | Parameter                                     | Notes   | Min | Тур | Max | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|-----------------------------------------------|---------|-----|-----|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| l <sub>IL</sub>    | Input Load<br>Current                         | 1       |     |     | ±1  | μА    | $V_{CC} = V_{CC} Max$ $V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| lLO                | Output Leakage<br>Current                     | 1       |     |     | ±10 | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Iccs               | V <sub>CC</sub> Standby<br>Current            | 1,5     |     | 50  | 100 | μΑ    | $V_{CC} = V_{CC} \text{ Max}$<br>$CE_0\#, CE_1\#, RP\# = V_{CC} \pm 0.2V$<br>BYTE#, WP#, 3/5# = $V_{CC} \pm 0.2V$ or GND $\pm 0.2V$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    |                                               |         |     | 2   | 4   | mA    | $V_{CC} = V_{CC}$ Max $CE_0\#$ , $CE_1\#$ , $RP\# = V_{IH}$ BYTE#, $WP\#$ , $3/5\# = V_{IH}$ or $V_{IL}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ICCD               | V <sub>CC</sub> Deep<br>Power-Down<br>Current | 1       |     | 1   | 5   | μΑ    | RP# = GND $\pm$ 0.2V<br>BYTE# = V <sub>CC</sub> $\pm$ 0.2V or GND $\pm$ 0.2V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| I <sub>CCR</sub> 1 | V <sub>CC</sub> Read<br>Current               | 1, 4, 5 |     | 50  | 60  | mA    | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max,} \\ \text{CMOS: CE}_0\#, \text{CE}_1\# = \text{GND} \pm 0.2\text{V} \\ \text{BYTE}\# = \text{GND} \pm 0.2\text{V or V}_{CC} \pm 0.2\text{V} \\ \text{Inputs} = \text{GND} \pm 0.2\text{V or V}_{CC} \pm 0.2\text{V} \\ \text{Inputs} = \text{GND} \pm 0.2\text{V or V}_{CC} \pm 0.2\text{V}, \\ \text{TTL: CE}_0\#, \text{CE}_1\# = \text{V}_{IL}, \\ \text{BYTE}\# = \text{V}_{IL} \text{ or V}_{IH} \\ \text{Inputs} = \text{V}_{IL} \text{ or V}_{IH}, \\ \text{f} = 10 \text{ MHz, I}_{OUT} = 0 \text{ mA} \end{array}$                                                                   |
| I <sub>CCR</sub> 2 | V <sub>CC</sub> Read<br>Current               | 1, 4, 5 |     | 30  | 35  | mA    | $\begin{split} &V_{CC} = V_{CC} \text{ Max,} \\ &C\text{MOS: } \text{CE}_0 \text{\#, } \text{CE}_1 \text{\#} = \\ &\text{GND} \pm 0.2 \text{V} \\ &\text{BYTE} \text{\#} = V_{CC} \pm 0.2 \text{V or} \\ &\text{GND} \pm 0.2 \text{V} \\ &\text{Inputs} = \text{GND} \pm 0.2 \text{V or} \\ &V_{CC} \pm 0.2 \text{V} \\ &\text{TTL: } \text{CE}_0 \text{\#, } \text{CE}_1 \text{\#} = \text{V}_{\text{IL}}, \\ &\text{BYTE} \text{\#} = \text{V}_{\text{IH}} \text{ or } \text{V}_{\text{IL}} \\ &\text{Inputs} = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ &\text{f} = 5 \text{ MHz, } \text{I}_{\text{OUT}} = 0 \text{ mA} \end{split}$ |
| Iccw               | V <sub>CC</sub> Write<br>Current              | 1       |     | 25  | 35  | mA    | Word/Byte in Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ICCE               | V <sub>CC</sub> Block<br>Erase Current        | 1       |     | 18  | 25  | mA    | Block Erase in Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ICCES              | V <sub>CC</sub> Erase<br>Suspend Current      | 1, 2    |     | 5   | 10  | mA    | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| I <sub>PPS</sub>   | V <sub>PP</sub> Standby<br>Current            | 1       |     | ±1  | ±10 | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |



#### 5.5 DC Characteristics: COMMERCIAL TEMPERATURE (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$  3/5# Pin Set Low for 5V Operations

| Symbol            | Parameter                                         | Notes | Min                     | Тур  | Max                   | Units | Test Conditions                                                   |
|-------------------|---------------------------------------------------|-------|-------------------------|------|-----------------------|-------|-------------------------------------------------------------------|
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-<br>Down Current       | 1     | ,                       | 0.2  | 5                     | μΑ    | RP# = GND ± 0.2V                                                  |
| I <sub>PPR</sub>  | V <sub>PP</sub> Read Current                      | 1     | -                       | 65   | 200                   | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                 |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                     | 1     | ·                       | 7    | 12                    | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Word/Byte Write in Progress |
| IPPE              | V <sub>PP</sub> Block Erase<br>Current            | 1     |                         | 5    | 10                    | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress     |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend<br>Current          | 1     |                         | 65   | 200                   | μΑ    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended       |
| V <sub>IL</sub>   | Input Low Voltage                                 |       | -0.5                    |      | 0.8                   | ٧     |                                                                   |
| V <sub>IH</sub>   | Input High Voltage                                |       | 2.0                     |      | V <sub>CC</sub> + 0.5 | ٧     | 4                                                                 |
| V <sub>OL</sub>   | Output Low Voltage                                |       |                         |      | 0.45                  | ٧     | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                           |
| V <sub>OH</sub> 1 | Output High Voltage                               |       | 0.85<br>V <sub>CC</sub> |      |                       | ٧     | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$          |
| V <sub>OH</sub> 2 |                                                   |       | V <sub>CC</sub> - 0.4   |      |                       | ·     | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$          |
| V <sub>PPL</sub>  | V <sub>PP</sub> during Normal<br>Operations       | 3     | 0.0                     |      | 6.5                   | ٧     |                                                                   |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Erase/<br>Write Operations |       | 11.4                    | 12.0 | 12.6                  | ٧     |                                                                   |
| V <sub>LKO</sub>  | V <sub>CC</sub> Erase/Write<br>Lock Voltage       |       | 2.0                     |      |                       | V     |                                                                   |

<sup>1.</sup> All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (package and speeds).

<sup>2.</sup> ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum

<sup>3.</sup> Block Erases, Word/Byte Writes and Lock Block operations are inhibited when V<sub>PP</sub> = V<sub>PPL</sub> and not guaranteed in the range between V<sub>PPH</sub> and V<sub>PPL</sub>.

<sup>4.</sup> Automatic Power Saving (APS) reduces I<sub>CCR</sub> to less than 2 mA in Static operation.

<sup>5.</sup> CMOS Inputs are either  $V_{CC} \pm 0.2V$  or GND  $\pm 0.2V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .



# 5.6 AC Characteristics—Read Only Operations: COMMERCIAL TEMPERATURE(1) $V_{CC}=3.3V\pm0.3V$ $T_A=0^{\circ}$ to $+70^{\circ}C$

|                                        | Versions (5)                                                              |       | 28F016 | SA-120 | 28F016 | SA-150 |       |
|----------------------------------------|---------------------------------------------------------------------------|-------|--------|--------|--------|--------|-------|
| Symbol                                 | Parameter                                                                 | Notes | Min    | Max    | Min    | Max    | Units |
| t <sub>AVAV</sub>                      | Read Cycle Time                                                           |       | 120    |        | 150    |        | ns    |
| t <sub>AVQV</sub>                      | Address to Output Delay                                                   |       |        | 120    |        | 150    | ns    |
| t <sub>ELQV</sub>                      | CE# to Output Delay                                                       | 2     |        | 120    |        | 150    | ns    |
| t <sub>PHQV</sub>                      | RP# High to Output Delay                                                  |       |        | 620    |        | 750    | ns    |
| tGLQV                                  | OE# to Output Delay                                                       | 2     | ,      | 45     |        | 50     | ns    |
| t <sub>ELQX</sub>                      | CE# to Output in Low Z                                                    | 3     | 0      |        | 0      |        | ns    |
| t <sub>EHQZ</sub>                      | CE# to Output in High Z                                                   | 3     |        | 50     |        | 55     | ns    |
| tGLQX                                  | OE# to Output in Low Z                                                    | 3     | 0      |        | 0      |        | ns    |
| tGHQZ                                  | OE# to Output in High Z                                                   | 3     |        | 30     |        | 40     | ns    |
| <sup>t</sup> OH                        | Output Hold from Address,<br>CE# or OE# Change,<br>Whichever Occurs First | 3     | 0      |        | 0      |        | ns    |
| t <sub>FLQV</sub><br>t <sub>FHQV</sub> | BYTE# to Output Delay                                                     | 3     |        | 120    | ·      | 150    | ns    |
| t <sub>FLQZ</sub>                      | BYTE# Low to Output in High Z                                             | 3     |        | 30     |        | 40     | ns    |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> | CE# Low to BYTE#<br>High or Low                                           | 3     |        | 5      |        | 5      | ns    |

# For Extended Status Register Reads

| Versions (5)      |                                |       | 28F016 | SA-120 | 28F0169 | SA-150 | Haita |
|-------------------|--------------------------------|-------|--------|--------|---------|--------|-------|
| Symbol            | Parameter                      | Notes | Min    | Max    | Min     | Max    | Units |
| <sup>t</sup> AVEL | Address Setup to CE# Going Low | 3, 4  | 0      |        | 0       |        | ns    |
| t <sub>AVGL</sub> | Address Setup to OE# Going Low | 3, 4  | 0      |        | 0       |        | ns    |



# 5.6 AC Characteristics—Read Only Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                                        | Versions(5)                                                                     | V <sub>CC</sub> ± 5%  | 28F0169 | SA-070 <sup>(6)</sup> |                             |     |         | -     |    |
|----------------------------------------|---------------------------------------------------------------------------------|-----------------------|---------|-----------------------|-----------------------------|-----|---------|-------|----|
| V GI SIONS                             |                                                                                 | V <sub>CC</sub> ± 10% |         |                       | 28F016SA-080 <sup>(7)</sup> |     | 28F0165 | Units |    |
| Symbol                                 | Parameter                                                                       | Notes                 | Min     | Max                   | Min                         | Max | Min     | Max   | 1  |
| t <sub>AVAV</sub>                      | Read Cycle Time                                                                 |                       | 70      |                       | 80                          |     | 100     | ` `   | ns |
| t <sub>AVQV</sub>                      | Address to Output<br>Delay                                                      |                       |         | 70                    |                             | 80  |         | 100   | ns |
| t <sub>ELQV</sub>                      | CE# to Output<br>Delay                                                          | 2                     |         | 70                    |                             | 80  |         | 100   | ns |
| t <sub>PHQV</sub>                      | RP# to Output<br>Delay                                                          |                       |         | 400                   |                             | 480 |         | 550   | ns |
| tGLQV                                  | OE# to Output<br>Delay                                                          | 2                     | -       | 30                    |                             | 35  |         | 40    | ns |
| t <sub>ELQX</sub>                      | CE# to Output in Low Z                                                          | , 3                   | 0       |                       | 0                           |     | 0       |       | ns |
| t <sub>EHQZ</sub>                      | CE# to Output in<br>High Z                                                      | 3                     |         | 25                    |                             | 30  |         | 35    | ns |
| t <sub>GLQX</sub>                      | OE# to Output in<br>Low Z                                                       | 3                     | 0       |                       | 0                           |     | 0       |       | ns |
| t <sub>GHQZ</sub>                      | OE# to Output in<br>High Z                                                      | 3                     |         | 25                    |                             | 30  |         | 35    | ns |
| t <sub>OH</sub>                        | Output Hold<br>from Address,<br>CE# or OE#<br>Change, Whichever<br>Occurs First | 3                     | 0       |                       | 0                           |     | 0       |       | ns |
| t <sub>FLQV</sub>                      | BYTE# to Output<br>Delay                                                        | 3                     |         | 70                    |                             | 80  |         | 100   | ns |
| t <sub>FLQZ</sub>                      | BYTE# Low to<br>Output in High Z                                                | 3                     |         | 25                    |                             | 30  |         | 30    | ns |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> | CE# Low to BYTE#<br>High or Low                                                 | 3                     |         | 5                     |                             | 5   |         | 5     | ns |

# For Extended Status Register Reads

|                   | ersions(5)                     | V <sub>CC</sub> ± 5%  | 28F016SA-070 <sup>(6)</sup> |     |                             |     |                             |     |       |
|-------------------|--------------------------------|-----------------------|-----------------------------|-----|-----------------------------|-----|-----------------------------|-----|-------|
| •                 | ersions(*)                     | V <sub>CC</sub> ± 10% |                             |     | 28F016SA-080 <sup>(7)</sup> |     | 28F016SA-100 <sup>(7)</sup> |     | Units |
| Symbol            | Parameter                      | Notes                 | Min                         | Max | Min                         | Max | Min                         | Max |       |
| t <sub>AVEL</sub> | Address Setup to CE# Going Low | 3, 4                  | 0                           |     | 0                           |     | 0                           |     | ns    |
| t <sub>AVGL</sub> | Address Setup to OE# Going Low | 3, 4                  | 0                           |     | 0                           |     | 0                           |     | ns    |

#### NOTES:

- 1. See AC Input/Output Reference Waveforms for timing measurements, Figures 6 and 7.
- OE# may be delayed up to t<sub>ELQV</sub>-t<sub>GLQV</sub> after the falling edge of CE# without impact on t<sub>ELQV</sub>.
- 3. Sampled, not 100% tested.
- 4. This timing parameter is used to latch the correct BSR data onto the outputs.
- 5. Device Speeds are defined as:

70/80 ns at  $V_{CC}=5.0V$  equivalent to 120 ns at  $V_{CC}=3.3V$  100 ns at  $V_{CC}=5.0V$  equivalent to 150 ns at  $V_{CC}=3.3V$ 

- 6. See AC Input/Output Reference Waveforms and AC Testing Load Circuits for High Speed Test Configuration.
- 7. See Standard AC Input/Output Reference Waveforms and AC Testing Load Circuit.





Figure 11. Read Timing Waveforms





Figure 12. BYTE# Timing Waveforms



# 5.7 Power-Up and Reset Timings: COMMERCIAL TEMPERATURE



Figure 13. V<sub>CC</sub> Power-Up and RP# Reset Waveforms

| Symbol                                 | Parameter                                                                 | Note | Min | Max | Unit |
|----------------------------------------|---------------------------------------------------------------------------|------|-----|-----|------|
| t <sub>PLYL</sub><br>t <sub>PLYH</sub> | RP# Low to 3/5# Low (High)                                                |      | 0   |     | μs   |
| t <sub>YLPH</sub><br>t <sub>YHPH</sub> | 3/5# Low (High) to RP# High                                               | 1    | 2   |     | μs   |
| t <sub>PL5V</sub><br>t <sub>PL3V</sub> | RP# Low to $V_{CC}$ at 4.5V Minimum (to $V_{CC}$ at 3.0V min or 3.6V max) | 2    | 0   |     | μs   |
| t <sub>AVQV</sub>                      |                                                                           |      |     | 80  | ns   |
| <sup>t</sup> PHQV                      | RP# High to Data Valid for<br>V <sub>CC</sub> = 5V ± 10%                  | 3    |     | 480 | ns   |

#### NOTES:

CE<sub>0</sub>#, CE<sub>1</sub># and OE# are switched low after Power-Up.

- 1. Minimum of 2  $\mu s$  is required to meet the specified t<sub>PHOV</sub> times.
- 2. The power supply may start to switch concurrently with RP# going Low.
- 3. The address access time and RP# high to data valid time are shown for 5V V<sub>CC</sub> operation. Refer to the AC Characteristics Read Only Operations 3.3V V<sub>CC</sub> operation and all other speed options.



# 5.8 AC Characteristics for WE #—Controlled Command Write Operations: COMMERCIAL TEMPERATURE(1)

 $V_{CC} = 3.3V \pm 0.3V$   $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                     | Versions                                                                                   |       | 28F016SA-120 |     |        | 28   | -150 | Unit   |      |
|---------------------|--------------------------------------------------------------------------------------------|-------|--------------|-----|--------|------|------|--------|------|
| Symbol              | Parameter                                                                                  | Notes | Min          | Тур | Max    | Min  | Тур  | Max    | Unit |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                           |       | 120          |     |        | 150  |      |        | ns   |
| t <sub>VPWH</sub>   | V <sub>PP</sub> Setup to WE# Going High                                                    | 3     | 100          |     |        | 100  |      |        | ns   |
| t <sub>PHEL</sub>   | RP# Setup to CE# Going Low                                                                 |       | 480          |     |        | 480  |      |        | ns   |
| tELWL               | CE# Setup to WE# Going Low                                                                 |       | 10           |     |        | 10   |      |        | ns   |
| <sup>t</sup> AVWH   | Address Setup to WE#<br>Going High                                                         | 2, 6  | 75           |     |        | 75   |      |        | ns   |
| t <sub>DVWH</sub>   | Data Setup to WE# Going High                                                               | 2, 6  | 75           |     |        | 75   |      |        | ns   |
| twLwH               | WE# Pulse Width                                                                            |       | 75           |     |        | 75   |      |        | ns   |
| twHDX               | Data Hold from WE# High                                                                    | 2     | 10           |     |        | 10   |      |        | ns   |
| twhax               | Address Hold from WE# High                                                                 | 2     | 10           |     |        | 10   |      |        | ns   |
| twheh               | CE# Hold from WE# High                                                                     |       | 10           |     |        | · 10 |      |        | ns   |
| twhwL               | WE# Pulse Width High                                                                       |       | 45           |     |        | 75   |      | ,      | ns   |
| tGHWL               | Read Recovery before Write                                                                 |       | 0            |     |        | 0    |      |        | ns   |
| twhrl               | WE# High to RY/BY# Going Low                                                               |       |              |     | 100    |      |      | 100    | ns   |
| <sup>t</sup> RHPL   | RP# Hold from Valid Status<br>Register (CSR, GSR, BSR) Data<br>and RY/BY# High             | 3     | 0            |     |        | 0    |      |        | ns   |
| t <sub>PHWL</sub>   | RP# High Recovery to WE# Going Low                                                         | , i   | 1            |     |        | 1    |      |        | μs   |
| twhgL               | Write Recovery before Read                                                                 |       | 95           |     |        | 120  |      |        | ns   |
| t <sub>QVVL</sub>   | V <sub>PP</sub> Hold from Valid Status<br>Register (CSR, GSR, BSR) Data<br>and RY/BY# High |       | 0            |     |        | 0    |      |        | μs   |
| t <sub>WHQV</sub> 1 | Duration of Word/Byte<br>Write Operation                                                   | 4, 5  | 5            | 9   | Note 7 | 5    | 9    | Note 7 | μs   |
| t <sub>WHQV</sub> 2 | Duration of Block<br>Erase Operation                                                       | 4     | 0.3          |     | 10     | 0.3  |      | 10     | sec  |



# AC Characteristics for WE#—Controlled Command Write Operations<sup>(1)</sup> (Continued) $V_{CC} = 5.0V \pm 0.5V$ $T_A = 0^{\circ}C$ to $+70^{\circ}C$

|                     | Versions                                                                                         | V <sub>CC</sub> ±5%   | 28  | F016S | A-070  |     |       |        |     |       |              |      |
|---------------------|--------------------------------------------------------------------------------------------------|-----------------------|-----|-------|--------|-----|-------|--------|-----|-------|--------------|------|
|                     | Versions                                                                                         | V <sub>CC</sub> ± 10% |     |       |        | 28  | F016S | A-080  | 28  | F016S | <b>A-100</b> | Unit |
| Symbol              | Parameter                                                                                        | Notes                 | Min | Тур   | Max    | Min | Тур   | Max    | Min | Тур   | Max          |      |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                                 |                       | 70  |       |        | 80  |       |        | 100 |       |              | ns   |
| t <sub>VPWH</sub>   | V <sub>PP</sub> Setup to WE#<br>Going High                                                       | 3                     | 100 |       |        | 100 |       |        | 100 |       |              | ns   |
| t <sub>PHEL</sub>   | RP# Setup to CE#<br>Going Low                                                                    |                       | 480 |       |        | 480 |       |        | 480 |       |              | ns   |
| tELWL               | CE# Setup to WE#<br>Going Low                                                                    |                       | 0   |       |        | С   |       |        | 0   |       |              | ns   |
| t <sub>AVWH</sub>   | Address Setup to WE# Going High                                                                  | 2, 6                  | 50  |       |        | 50  |       |        | 50  |       |              | ns   |
| t <sub>DVWH</sub>   | Data Setup to WE#<br>Going High                                                                  | 2, 6                  | 50  |       |        | 50  |       |        | 50  |       |              | ns   |
| tWLvVH:             | WE# Pulse Width                                                                                  |                       | 40  |       |        | 50  |       |        | 50  |       |              | ns   |
| twHDX               | Data Hold from<br>WE# High                                                                       | 2                     | 0   |       |        | 0   |       |        | 0   |       |              | ns   |
| twhax               | Address Hold from<br>WE# High                                                                    | 2                     | 10  |       |        | 10  |       |        | 10  |       |              | ns   |
| twheh               | CE# Hold from<br>WE# High                                                                        |                       | 10  |       |        | 10  |       |        | 10  |       |              | ns   |
| twhwL               | WE# Pulse Width<br>High                                                                          |                       | 30  |       | 1      | 30  |       |        | 50  |       |              | ns   |
| t <sub>GHWL</sub>   | Read Recovery before Write                                                                       |                       | 0   |       |        | 0   |       |        | 0   |       |              | ns   |
| t <sub>WHRL</sub>   | WE# High to RY/<br>BY# Going Low                                                                 |                       |     |       | 100    |     |       | 100    |     |       | 100          | ns   |
| t <sub>RHPL</sub>   | RP# Hold from<br>Valid Status<br>Register (CSR,<br>GSR, BSR) Data<br>and RY/BY# High             | 3                     | 0   | -     |        | 0   |       |        | 0   |       |              | ns   |
| t <sub>PHWL</sub>   | RP# High<br>Recovery to WE#<br>Going Low                                                         |                       | 1   |       |        | 1   |       | ·      | 1   |       |              | μs   |
| twHGL               | Write Recovery before Read                                                                       | ,                     | 60  |       |        | 65  |       |        | 80  |       |              | ns   |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid<br>Status Register<br>(CSR, GSR, BSR)<br>Data and RY/BY#<br>High |                       | 0   |       |        | 0   |       |        | 0   |       |              | μs   |
| t <sub>WHQV</sub> 1 | Duration of Word/<br>Byte Write<br>Operation                                                     | 4, 5                  | 4.5 | 6     | Note 7 | 4.5 | 6     | Note 7 | 4.5 | 6     | Note 7       | μs   |
| t <sub>WHQV</sub> 2 | Duration of Block<br>Erase Operation                                                             | 4                     | 0.3 |       | 10     | 0.3 |       | 10     | 0.3 |       | 10           | sec  |



#### NOTES:

CE# is defined as the latter of CE $_0$ # or CE $_1$ # going Low or the first of CE $_0$ # or CE $_1$ # going High.

- 1. Read timings during write and erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, but not 100% tested.
- 4. Write/Erase durations are measured to valid Status Register (CSR) Data.
- 5. Word/Byte write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of WE# for all Command Write operations.
- This information will be available in a technical paper. Please call Intel's Application Hotline or your local sales office for more information.



Figure 14. AC Waveforms for Command Write Operations



# 5.9 AC Characteristics for CE #—Controlled Command Write Operations: COMMERCIAL TEMPERATURE(1)

 $V_{CC} = 3.3V \pm 0.3V$   $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                     | Versions                                                                                  |       | 28  | F016S | A-120  | 28  | A-150 | Unit   |     |
|---------------------|-------------------------------------------------------------------------------------------|-------|-----|-------|--------|-----|-------|--------|-----|
| Symbol              | Parameter                                                                                 | Notes | Min | Тур   | Max    | Min | Тур   | Max    |     |
| t <sub>AVAV</sub>   | Write Cycle Time                                                                          |       | 120 |       |        | 150 |       |        | ns  |
| t <sub>VPEH</sub>   | V <sub>PP</sub> Setup to CE# Going high                                                   | 3     | 100 |       | _      | 100 |       |        | ns  |
| t <sub>PHWL</sub>   | RP# Setup to WE# Going Low                                                                |       | 480 |       |        | 480 |       |        | ns  |
| t <sub>WLEL</sub>   | WE# Setup to CE# Going Low                                                                |       | 0   |       |        | 0   |       |        | ns  |
| <sup>t</sup> AVEH   | Address Setup to CE# Going High                                                           | 2, 6  | 75  |       |        | 75  |       |        | ns  |
| <sup>t</sup> DVEH   | Data Setup to CE# Going High                                                              | 2, 6  | 75  |       |        | 75  |       |        | ns  |
| t <sub>ELEH</sub>   | CE# Pulse Width                                                                           |       | 75  |       |        | 75  |       |        | ns  |
| t <sub>EHDX</sub>   | Data Hold from CE# High                                                                   | 2     | 10  |       |        | 10  |       |        | ns  |
| tEHAX               | Address Hold from CE# High                                                                | 2     | 10  |       |        | 10  |       |        | ns  |
| t <sub>EHWH</sub>   | WE# Hold from CE# High                                                                    |       | 10  |       |        | 10  |       |        | ns  |
| t <sub>EHEL</sub>   | CE# Pulse Width High                                                                      |       | 45  |       |        | 75  |       |        | ns  |
| tGHEL               | Read Recovery before Write                                                                |       | 0   |       |        | 0   |       |        | ns  |
| t <sub>EHRL</sub>   | CE# High to RY/BY# Going Low                                                              |       |     |       | 100    |     |       | 100    | ns  |
| <sup>t</sup> RHPL   | RP# Hold from Valid Status<br>Register (CSR, GSR, BSR) Data<br>and RY/BY# High            | 3     | 0   |       |        | 0   |       |        | ns  |
| t <sub>PHEL</sub>   | RP# High Recovery to CE# Going Low                                                        |       | 1   |       |        | 1   |       |        | μs  |
| t <sub>EHGL</sub>   | Write Recovery before Read                                                                |       | 95  |       |        | 120 |       |        | ns  |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid Status<br>Register (CSR, GSR, BSR) Data<br>at RY/BY# High |       | 0   |       |        | 0   |       |        | μs  |
| t <sub>EHQV</sub> 1 | Duration of Word/Byte<br>Write Operation                                                  | 4, 5  | 5   | 9     | Note 7 | 5   | 9     | Note 7 | μs  |
| t <sub>EHQV</sub> 2 | Duration of Block<br>Erase Operation                                                      | 4     | 0.3 |       | 10     | 0.3 |       | 10     | sec |



## AC Characteristics for CE #—Controlled Command Write Operations(1) (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = 0^{\circ} \text{ to } +70^{\circ}\text{C}$ 

|                     | Versions                                                                                         | V <sub>CC</sub> ±5%   | 28  | F016S | <b>A-070</b> |     | ٠.     |              |     |       |        |      |
|---------------------|--------------------------------------------------------------------------------------------------|-----------------------|-----|-------|--------------|-----|--------|--------------|-----|-------|--------|------|
|                     | versions                                                                                         | V <sub>CC</sub> ± 10% |     |       |              | 28  | F016S/ | <b>A-080</b> | 28  | F016S | A-100  | Unit |
| Symbol              | Parameter                                                                                        | Notes                 | Min | Тур   | Max          | Min | Тур    | Max          | Min | Тур   | Max    |      |
| tavav               | Write Cycle Time                                                                                 |                       | 70  |       |              | 80  | ,      |              | 100 |       |        | ns   |
| t <sub>VPEH</sub>   | V <sub>PP</sub> Setup to CE#<br>Going High                                                       | 3                     | 100 |       | ,            | 100 |        |              | 100 |       |        | ns   |
| t <sub>PHWL</sub>   | RP# Setup to WE#<br>Going Low                                                                    | 3                     | 480 |       |              | 480 |        |              | 480 |       |        | ns   |
| t <sub>WLEL</sub>   | WE# Setup to CE#<br>Going Low                                                                    |                       | 0   |       |              | 0   |        |              | 0   |       |        | ns   |
| t <sub>AVEH</sub>   | Address Setup to CE# Going High                                                                  | 2, 6                  | 50  |       |              | 50  |        |              | 50  |       |        | ns   |
| <sup>t</sup> DVEH   | Data Setup to CE#<br>Going High                                                                  | 2, 6                  | 50  |       |              | 50  |        |              | 50  | •     |        | ns   |
| t <sub>ELEH</sub>   | CE# Pulse Width                                                                                  |                       | 40  |       |              | 50  |        |              | 50  |       |        | ns   |
| t <sub>EHDX</sub>   | Data Hold from<br>CE# High                                                                       | 2                     | 0   |       |              | 0   |        |              | 0   |       |        | ns   |
| tEHAX               | Address Hold from<br>CE# High                                                                    | 2                     | 10  |       |              | 10  |        |              | 10  |       |        | ns   |
| t <sub>EHWH</sub>   | WE# Hold from<br>CE# High                                                                        |                       | 10  | ,     | ,            | 10  |        |              | 10  |       |        | ns   |
| t <sub>EHEL</sub>   | CE# Pulse Width<br>High                                                                          |                       | 30  |       |              | 30  |        |              | 50  |       |        | ns   |
| <sup>t</sup> GHEL   | Read Recovery before Write                                                                       |                       | 0   |       |              | 0   | -      |              | 0   |       | ,      | ns   |
| t <sub>EHRL</sub>   | CE# High to RY/<br>BY# Going Low                                                                 |                       |     |       | 100          |     |        | 100          |     |       | 100    | ns   |
| <sup>t</sup> RHPL   | RP# Hold from<br>Valid Status<br>Register (CSR,<br>GSR, BSR) Data<br>and RY/BY# High             | 3                     | 0   |       |              | 0   |        |              | 0   |       |        | ns   |
| <sup>†</sup> PHEL   | RP# High<br>Recovery to CE#<br>Going Low                                                         |                       | 1   |       |              | . 1 |        |              | 1   |       |        | μs   |
| tEHGL               | Write Recovery before Read                                                                       |                       | 60  |       |              | 65  |        |              | 80  |       |        | ns   |
| <sup>t</sup> QVVL   | V <sub>PP</sub> Hold from Valid<br>Status Register<br>(CSR, GSR, BSR)<br>Data and RY/BY#<br>High |                       | 0   |       |              | 0   |        |              | 0   |       |        | μs   |
| t <sub>EHQV</sub> 1 | Duration of Word/<br>Byte Write<br>Operation                                                     | 4, 5                  | 4.5 | 6     | Note 7       | 4.5 | 6      | Note 7       | 4.5 | 6     | Note 7 | μs   |
| t <sub>EHQV</sub> 2 | Duration of Block<br>Erase Operation                                                             | 4                     | 0.3 |       | 10           | 0.3 |        | 10           | 0.3 |       | 10     | sec  |



#### NOTES:

CE# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going Low or the first of CE<sub>0</sub># or CE<sub>1</sub># going High.

- 1. Read timings during write and erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, but not 100% tested.
- 4. Write/Erase durations are measured to valid Status Data.
- 5. Word/Byte write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of CE# for all Command Write Operations.
- This information will be available in a technical paper. Please call Intel's Application Hotline or your local sales office for more information.



Figure 15. Alternate AC Waveforms for Command Write Operations



# 5.10 AC Characteristics for Page Buffer Write Operations: COMMERCIAL TEMPERATURE(1)

 $V_{CC} = 3.3V \pm 0.3V$   $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ .

|                   | Versions                       |       | 281 | F016SA | -120 | 28F | -016SA | -150 | Unit     |
|-------------------|--------------------------------|-------|-----|--------|------|-----|--------|------|----------|
| Symbol            | Parameter                      | Notes | Min | Тур    | Max  | Min | Тур    | Max  | O I II I |
| t <sub>AVAV</sub> | Write Cycle Time               |       | 120 |        |      | 150 |        |      | ns       |
| t <sub>ELWL</sub> | CE# Setup to WE# Going Low     |       | 10  |        |      | 10  |        |      | ns       |
| t <sub>AVWL</sub> | Address Setup to WE# Going Low | 3     | 0   |        |      | 0   |        |      | ns       |
| t <sub>DVWH</sub> | Data Setup to WE# Going High   | 2     | 75  |        |      | 50  |        |      | ns       |
| t <sub>WLWH</sub> | WE# Pulse Width                |       | 75  |        |      | 75  |        | -    | ns       |
| t <sub>WHDX</sub> | Data Hold from WE# High        | 2     | 10  |        |      | 10  |        |      | ns       |
| t <sub>WHAX</sub> | Address Hold from WE# High     | 2     | 10  |        |      | 10  |        |      | ns       |
| twheh             | CE# Hold from WE# High         |       | 10  |        |      | 10  |        |      | ns       |
| twHWL             | WE# Pulse Width High           |       | 45  |        |      | 75  |        |      | ns       |
| tGHWL             | Read Recovery before Write     |       | 0   |        |      | 0   |        |      | ns       |
| twHGL             | Write Recovery before Read     |       | 95  |        |      | 120 |        |      | ns       |

 $V_{CC}$  = 5.0V  $\pm$  0.5V,  $T_A$  = 0°C to +70°C

|                   | Versions                        |       | 28F | 016SA | -070 | 28F016SA-080 |     |     | 28F016SA-100 |     |     | Unit |
|-------------------|---------------------------------|-------|-----|-------|------|--------------|-----|-----|--------------|-----|-----|------|
| Symbol            | Parameter                       | Notes | Min | Тур   | Max  | Min          | Тур | Max | Min          | Тур | Max | Unit |
| t <sub>AVAV</sub> | Write Cycle Time                |       | 70  |       |      | 80           |     |     | 100          |     |     | ns   |
| tELWL             | CE# Setup to<br>WE# Going Low   |       | 0   |       |      | 0            |     | ,   | 0            |     |     | ns   |
| t <sub>AVWL</sub> | Address Setup to WE# Going Low  | 3     | 0   |       |      | . 0          |     |     | , 0          |     |     | ns   |
| <sup>t</sup> DVWH | Data Setup to<br>WE# Going High | 2     | 50  |       |      | 50           |     |     | 50           |     |     | ns   |
| twLwH             | WE# Pulse Width                 |       | 40  |       |      | 50           |     |     | 50           |     |     | ns   |
| t <sub>WHDX</sub> | Data Hold from<br>WE# High      | 2     | 0   |       |      | 0            |     |     | 0            |     |     | ns   |
| twhax             | Address Hold from WE# High      | 2     | 10  |       |      | 10           |     |     | 10           |     |     | ns   |
| twheh             | CE# Hold from<br>WE# High       |       | 10  | ·     |      | 10           |     |     | 10           |     | -   | ns   |
| t <sub>WHWL</sub> | WE# Pulse Width<br>High         |       | 30  |       |      | - 30         |     |     | 50           |     |     | ns   |
| tGHWL             | Read Recovery before Write      |       | 0   |       |      | 0            |     | -   | 0            |     |     | ns   |
| twHGL             | Write Recovery<br>before Read   |       | 60  |       |      | 65           |     |     | 80           |     |     | ns   |

#### NOTES

CE# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going Low or the first of CE<sub>0</sub># or CE<sub>1</sub># going High.

- 1. These are WE#-controlled write timings, equivalent CE#-controlled write timings apply.
- 2. Sampled, but not 100% tested.
- 3. Address must be valid during the entire WE# Low pulse or the entire CE# Low pulse for CE#-controlled writes.





Figure 16. Page Buffer Write Timing Waveforms (Loading Data to the Page Buffer)



# 5.11 Erase and Word/Byte Write Performance, Cycling Performance and Suspend Latency(1, 3)

 $V_{CC} = 3.3V \pm 0.3V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol              | Parameter                           | Notes   | Min     | Тур       | Max    | Units  | Test Conditions |
|---------------------|-------------------------------------|---------|---------|-----------|--------|--------|-----------------|
|                     | Page Buffer Byte Write Time         | 1, 2, 4 |         | 3.26      | Note 6 | μs     |                 |
|                     | Page Buffer Word Write Time         | 1, 2, 4 |         | 6.53      | Note 6 | μs     |                 |
| t <sub>WHRH</sub> 1 | Word/Byte Write Time                | 1, 2    |         | 9         | Note 6 | μs     |                 |
| t <sub>WHRH</sub> 2 | Block Write Time                    | 1, 2    |         | 0.6       | 2.1    | Sec    | Byte Write Mode |
| t <sub>WHRH</sub> 3 | Block Write Time                    | 1, 2    |         | 0.3       | 1.0    | Sec    | Word Write Mode |
|                     | Block Erase Time                    | 1, 2    |         | 0.8       | 10     | Sec    |                 |
|                     | Full Chip Erase Time                | 1, 2    |         | 25.6      |        | Sec    |                 |
|                     | Erase Suspend Latency Time to Read  |         |         | 7.0       |        | μs     |                 |
|                     | Erase Suspend Latency Time to Write |         |         | 10.0      |        | μs     |                 |
|                     | Erase Cycles                        | 5       | 100,000 | 1,000,000 |        | Cycles |                 |

 $V_{CC} = 5.0V \pm 0.5V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Symbol              | Parameter                           | Notes   | Min     | Тур       | Max    | Units  | Test Conditions |
|---------------------|-------------------------------------|---------|---------|-----------|--------|--------|-----------------|
|                     | Page Buffer Byte Write Time         | 1, 2, 4 |         | 2.76      | Note 6 | μs     |                 |
|                     | Page Buffer Word Write Time         | 1, 2, 4 |         | 5.51      | Note 6 | μs     |                 |
| t <sub>WHRH</sub> 1 | Word Byte/Write Time                | 1, 2    |         | 6         | Note 6 | μs     |                 |
| t <sub>WHRH</sub> 2 | Block Write Time                    | 1, 2    |         | 0.4       | 2.1    | Sec    | Byte Write Mode |
| t <sub>WHRH</sub> 3 | Block Write Time                    | 1, 2    |         | 0.2       | 1.0    | Sec    | Word Write Mode |
|                     | Block Erase Time                    | 1, 2    |         | 0.6       | 10     | Sec    |                 |
|                     | Full Chip Erase Time                | 1, 2    |         | 19.2      |        | Sec    |                 |
|                     | Erase Suspend Latency Time to Read  |         |         | 5.0       |        | μs     |                 |
|                     | Erase Suspend Latency Time to Write |         | ·       | 8.0       |        | μs     |                 |
|                     | Erase Cycles                        | 5       | 100,000 | 1,000,000 |        | Cycles |                 |

#### NOTES:

- 1. 25°C,  $V_{CC} = 3.3V$  or 5V nominal, 10K cycles.
- 2. Excludes system-level overhead.
- 3. These performance numbers are valid for all speed versions.
- 4. This assumes using the full Page Buffer to Write to Flash (256 bytes or 128 words).
- 5. Typical 1,000,000 cycle performance assumes the application uses block retirement techniques.
- 6. This information will be available in a technical paper. Please call Intel's Application hotline or your local sales office for more information.



## 6.0 DERATING CURVES



Figure 17. I<sub>CC</sub> vs Frequency (V<sub>CC</sub> = 5.5V) for x8 or x16 Operation



Figure 18. I<sub>CC</sub> vs Frequency (V<sub>CC</sub> = 3.6V) for x8 or x16 Operation



Figure 19. I<sub>CC</sub> during Block Erase





Figure 20. Ipp during Block Erase



Figure 21. Access Time (t<sub>ACC</sub>) vs Output Loading





Figure 22. Ipp during Word Write Operation



Figure 23. Ipp during Page Buffer Write Operation



## 7.0 MECHANICAL SPECIFICATIONS FOR TSOP



Figure 24. Mechanical Specifications of the 28F016SA 56-L-TSOP Type 1 Package

|                | Family: | Thin Small Outline Pa | ackage  |       |  |  |  |  |  |
|----------------|---------|-----------------------|---------|-------|--|--|--|--|--|
| Ob ol          |         | Millimeters           |         |       |  |  |  |  |  |
| Symbol         | Minimum | Nominal               | Maximum | Notes |  |  |  |  |  |
| Α              |         | ,                     | 1.20    |       |  |  |  |  |  |
| A <sub>1</sub> | 0.50    |                       |         |       |  |  |  |  |  |
| A <sub>2</sub> | 0.965   | 0.995                 | 1.025   |       |  |  |  |  |  |
| b              | 0.100   | 0.150                 | 0.200   |       |  |  |  |  |  |
| С              | 0.115   | 0.125                 | 0.135   | ·     |  |  |  |  |  |
| D <sub>1</sub> | 18.20   | 18.40                 | 18.60   |       |  |  |  |  |  |
| E              | 13.80   | 14.00                 | 14.20   |       |  |  |  |  |  |
| е              | ·       | 0.50                  |         |       |  |  |  |  |  |
| D              | 19.80   | 20.00                 | 20.20   |       |  |  |  |  |  |
| L .            | 0.500   | 0.600                 | 0.700   |       |  |  |  |  |  |
| N              |         | 56                    |         |       |  |  |  |  |  |
| Ø              | 0°      | 3°                    | 5°      |       |  |  |  |  |  |
| Υ              |         |                       | 0.100   |       |  |  |  |  |  |
| Z              | 0.150   | 0.250                 | 0.350   |       |  |  |  |  |  |



## 8.0 MECHANICAL SPECIFICATIONS FOR SSOP



Figure 25. Mechanical Specifications of the 56-Lead SSOP Package

|                | Family: S | Shrink Small Outline F | Package |       |
|----------------|-----------|------------------------|---------|-------|
| Symbol         | ·         | Notes                  |         |       |
| Symbol         | Minimum   | Nominal                | Maximum | Notes |
| Α              |           | 1.80                   | 1.90    |       |
| A1             | 0.47      | 0.52                   | 0.57    |       |
| A2             | 1.18      | 1.28                   | 1.38    |       |
| B.             | 0.25      | 0.30                   | 0.20    |       |
| С              | 0.13      | 0.15                   | 0.20    | -     |
| D              | 23.40     | 23.70                  | 24.00   |       |
| E              | 13.10     | 13.30                  | 13.50   |       |
| e <sub>1</sub> | ·         | 0.80                   |         |       |
| He             | 15.70     | 16.00                  | 16.30   |       |
| N              |           | 56                     |         |       |
| L <sub>1</sub> | 0.45      | 0.50                   | 0.55    |       |
| Υ              |           |                        | 0.10    |       |
| а              | 2°        | 3°                     | 4°      |       |
| b              | 3°        | 4°                     | 5°      |       |
| R1             | 0.15      | 0.20                   | 0.25    |       |
| R2             | 0.15      | 0.20                   | 0.25    |       |



## **DEVICE NOMENCLATURE AND ORDERING INFORMATION**



|        |                | Valid Combinations               |                                              |                                            |  |  |  |  |
|--------|----------------|----------------------------------|----------------------------------------------|--------------------------------------------|--|--|--|--|
| Option | Order Code     | $V_{CC}=3.3V\pm0.3V,$ 50 pF Load | V <sub>CC</sub> = 5.0V ± 10%,<br>100 pF Load | V <sub>CC</sub> = 5.0V ± 5%,<br>30 pF Load |  |  |  |  |
| 1      | E28F016SA-070  | E28F016SA-120                    | E28F016SA-080                                | E28F016SA-070                              |  |  |  |  |
| -2     | E28F016SA-100  | E28F016SA-150                    | E28F016SA-100                                |                                            |  |  |  |  |
| 3      | DA28F016SA-070 | DA28F016SA-120                   | DA28F016SA-080                               | DA28F016SA-070                             |  |  |  |  |
| 4      | DA28F016SA-100 | DA28F016SA-150                   | DA28F016SA-100                               |                                            |  |  |  |  |

## **ADDITIONAL INFORMATION**

|        | Item                                                                          | Order Number |
|--------|-------------------------------------------------------------------------------|--------------|
|        | 28F016SA 16-Mbit FlashFile™ Memory User's Manual                              | 297372       |
|        | DD28F032SA 32-Mbit FlashFile™ Memory Data Sheet                               | 290489       |
|        | 28F016SV FlashFile™ Memory Data Sheet                                         | 290528       |
|        | 28F008SA Data Sheet                                                           | 290435       |
| AP-393 | "28F016SV Compatibility with 28F016SA"                                        | 292144       |
| AP-378 | "System Optimization Using the Enhanced Features of the 28F016SA"             | 292127       |
| AP-377 | "28F016SA Software Drivers"                                                   | 292126       |
| AP-375 | "Upgrade Considerations from the 28F008SA to the 28F016SA"                    | 292124       |
| AP-357 | "Power Supply Solutions for Flash Memory"                                     | 292092       |
| AP-374 | "Flash Memory Write Protection Techniques"                                    | 292123       |
| AP-607 | "Multi-Site Layout Planning with Intel's FlashFile™ Components Including ROM" | 292159       |
|        | "Small and Low-Cost Power Supply Solution for Intel's Flash Memory Products"  | 297534       |
| ER-33  | "ETOX™ Flash Memory Technology—Insight to Intel's Fourth Generation           | 294016       |
|        | Process Innovation"                                                           |              |
|        | FLASHBuilder Design Resource Tool                                             | 297508       |

Please check with Intel Literature for availability.

## **DATASHEET REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -002   | <ul> <li>Added 56-Lead SSOP Package</li> <li>Separated AC Read Timing Specs T<sub>AVEL</sub>, T<sub>AVGL</sub> for Extended Status Register Reads</li> <li>Modified DEVICE NOMENCLATURE</li> <li>Added ORDERING INFORMATION</li> <li>Added Page Buffer Typical Write Performance numbers</li> <li>Added Typical Erase Suspend Latencies</li> <li>For I<sub>CCD</sub> (Deep Power-Down current, BYTE # must be at CMOS levels)</li> <li>Added SSOP package mechanical specifications</li> </ul> |



## EXTENDED TEMPERATURE 28F016SA 16 MBIT (1 MBIT x 16, 2 MBIT x 8) FlashFile™ MEMORY

- Extended Temperature Operation— -40°C to +85°C
- User-Selectable 3.3V or 5V V<sub>CC</sub>
- 100 ns Maximum Access Time at 5V (Extended Temperature Range)
- 1 Million Typical Erase Cycles per Block
- 20 MB/sec Burst Write Transfer Rate
- User-Configurable x8 or x16 Operation
- 56-Lead 1.8 mm x 16 mm x 23.7 mm SSOP Package

- **■** Revolutionary Architecture
  - Multiple Command Execution
  - Write during Erase
  - Command Super-Set of the Intel 28F008SA
  - Page Buffer Write
- 1 mA Typical I<sub>CC</sub> in Static Mode
- 3 μA Typical Deep Power-Down
- 32 Independently Lockable Blocks
- State-of-the-Art 0.6 µm ETOX™ IV Flash Technology

Intel's 28F016SA 16-Mbit FlashFile™ memory is a revolutionary architecture which is the ideal choice for designing embedded direct-execute code and mass storage data/file flash memory systems. With innovative capabilities, low-power, extended temperature operation and high read/write performance, the 28F016SA enables the design of truly mobile, high-performance communications and computing products.

The 28F016SA is the highest density, highest performance non-volatile read/write solution for solid-state storage applications. Its symmetrically blocked architecture (100% compatible with the 28F008SA 8-Mbit FlashFile memory), extended cycling, extended temperature operation, flexible V<sub>CC</sub>, fast write and read performance and selective block locking provide highly flexible memory components suitable for resident flash arrays, high-density memory cards and PCMCIA-ATA flash drives. The 28F016SA dual read voltage enables the design of memory cards which can interchangeably be read/written in 3.3V and 5.0V systems. Its x8/x16 architecture allows optimization of the memory-to-processor interface. Its high read performance and flexible block locking enable both storage and execution of operating systems and application software. Manufactured on Intel's 0.6  $\mu$ m ETOXTM IV process technology, the 28F016SA is the most cost effective, highest density monolithic 3.3V FlashFile memory.



290541-1

## EXTENDED TEMPERATURE 28F016SA 16 MBIT (1 MBIT x 16, 2 MBIT x 8) FlashFile™ MEMORY

| CONTENTS                                                                                                                                                         | PAGE                     | CONTENTS                                                                                                                                                                                                     | PAGE                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| 1.0 INTRODUCTION                                                                                                                                                 |                          | 5.0 ELECTRICAL SPECIFICATIONS 5.1 Absolute Maximum Ratings                                                                                                                                                   |                         |
| 2.0 DEVICE PINOUT  2.1 Lead Descriptions  3.0 MEMORY MAPS  3.1 Extended Status Registers Memo Map                                                                | . 3-408<br>. 3-410<br>ry | 5.2 Capacitance 5.3 Timing Nomenclature 5.4 DC Characteristics 5.5 DC Characteristics 5.6 AC Characteristics—Read Only Operations                                                                            | 3-420<br>3-422<br>3-424 |
| 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS  4.1 Bus Operations for Word-Wide Mode (BYTE# = V <sub>IH</sub> )  4.2 Bus Operations for Byte-Wide | . 3-412                  | <ul> <li>5.7 Power-Up and Reset Timings</li> <li>5.8 AC Characteristics for WE#— Controlled Command Write Operations</li> <li>5.9 AC Characteristics for CE#— Controlled Command Write Operations</li> </ul> | 3-431                   |
| Mode (BYTE# = V <sub>IL</sub> )                                                                                                                                  | . 3-413                  | <ul> <li>5.10 AC Characteristics for WE#— Controlled Page Buffer Write Operations</li> <li>5.11 Erase and Word/Byte Write Performance, Cycling Performance</li> <li>and Suspend Latency</li> </ul>           | 3-437<br>ce<br>3-439    |
| 4.6 Global Status Register                                                                                                                                       |                          | 6.0 MECHANICAL SPECIFICATIONS DEVICE NOMENCLATURE/ORDERI INFORMATION                                                                                                                                         | NG                      |
|                                                                                                                                                                  |                          | ADDITIONAL INFORMATION                                                                                                                                                                                       | 3-442                   |
|                                                                                                                                                                  |                          | DATASHEET REVISION HISTORY .                                                                                                                                                                                 | 3-442                   |



#### 1.0 INTRODUCTION

The documentation of the Intel 28F016SA memory device includes this datasheet, a detailed user's manual, a number of application notes, all of which are referenced at the end of this datasheet.

The datasheet is intended to give an overview of the chip feature-set and of the operating AC/DC specifications. The 28F016SA User's Manual provides complete descriptions of the user modes, system interface examples and detailed descriptions of all principles of operation. It also contains the full list of software algorithm flowcharts, and a brief section on compatibility with the Intel 28F008SA.

#### 1.1 Product Overview

The 28F016SA is a high-performance, 16-Mbit (16,777,216-bit) block erasable non-volatile random access memory organized as either 1 MWord x 16 or 2 MByte x 8. The 28F016SA includes thirty-two 64-KB (65,536) blocks or thirty-two 32-KW (32,768) blocks. A chip memory map is shown in Figure 3.

The implementation of a new architecture, with many enhanced features, will improve the device operating characteristics and results in greater product reliability and ease of use.

Among the significant enhancements on the 28F016SA:

- 3.3V Low Power Capability
- Improved Write Performance
- Dedicated Block Write/Erase Protection

A 3/5# input pin reconfigures the device internally for optimized 3.3V or 5.0V read/write operation.

The 28F016SA will be available in a 56-lead, 1.8 mm thick, 16 mm x 23.7mm SSOP package. This form factor and pinout allow for very high board layout densities.

A Command User Interface (CUI) serves as the system interface between the microprocessor or microcontroller and the internal memory operation.

Internal Algorithm Automation allows Byte/Word Writes and Block Erase operations to be executed using a Two-Write command sequence to the CUI in the same way as the 28F008SA 8-Mbit FlashFile memory.

A Superset of commands have been added to the basic 28F008SA command-set to achieve higher write performance and provide additional capabilities. These new commands and features include:

- · Page Buffer Writes to Flash
- Command Queuing Capability
- · Automatic Data Writes during Erase
- Software Locking of Memory Blocks
- Two-Byte Successive Writes in 8-Bit Systems
- · Erase All Unlocked Blocks

Writing of memory data is performed in either byte or word increments typically within 6  $\mu$ s, a 33% improvement over the 28F008SA. A Block Erase operation erases one of the 32 blocks in typically 0.6 sec, independent of the other blocks, which is about 65% improvement over the 28F008SA.

Each block can be written and erased a minimum of 100,000 cycles. Systems can achieve typically 1 million Block Erase Cycles by providing graceful block retirement. This technique has already been employed in Hard Disk Drive designs. Additionally, wear leveling of block erase cycles can be used to minimize the write/erase time differences across blocks.

The 28F016SA incorporates two Page Buffers of 256 bytes (128 words) each to allow page data writes. This feature can improve a system write performance by up to 4 times over previous flash memory devices.

All operations are started by a sequence of Write commands to the device. Three Status Registers (described in detail later) and a RY/BY# output pin provide information on the progress of the requested operation.

While the 28F008SA requires an operation to complete before the next operation can be requested, the 28F016SA allows queuing of the next operation while the memory executes the current operation. This eliminates system overhead when writing several bytes in a row to the array or erasing several blocks at the same time. The 28F016SA can also perform write operations to one block of memory while performing Erase of another block.



The 28F016SA provides user-selectable block locking to protect code or data such as Device Drivers, PCMCIA card information, ROM-Executable O/S or Application Code. Each block has an associated non-volatile lock-bit which determines the lock status of the block. In addition, the 28F016SA has a master Write Protect pin (WP#) which prevents any modifications to memory blocks whose lock-bits are set.

The 28F016SA contains three types of Status Registers to accomplish various functions:

- A Compatible Status Register (CSR) which is 100% compatible with the 28F008SA FlashFile memory's Status Register. This register, when used alone, provides a straightforward upgrade capability to the 28F016SA from a 28F008SAbased design.
- A Global Status Register (GSR) which informs the system of command Queue status, Page Buffer status, and overall Write State Machine (WSM) status.
- 32 Block Status Registers (BSRs) which provide block-specific status information such as the block lock-bit status.

The GSR and BSR memory maps for Byte-Wide and Word-Wide modes are shown in Figures 4a and 4b.

The 28F016SA incorporates an open drain RY/BY# output pin. This feature allows the user to OR-tie many RY/BY# pins together in a multiple memory configuration such as a Resident Flash Array.

Other configurations of the RY/BY# pin are enabled via special CUI commands and are described in detail in the 28F016SA User's Manual.

The 28F016SA also incorporates a dual chip-enable function with two input pins,  $CE_0\#$  and  $CE_1\#$ . These pins have exactly the same functionality as the regular chip-enable pin,  $CE_{\#}$ , on the 28F008SA. For minimum chip designs,  $CE_{\#}\#$  may be tied to ground and use  $CE_0\#$  as the chip enable input. The 28F016SA uses the logical combination of these two signals to enable or disable the entire chip. Both  $CE_0\#$  and  $CE_{\#}\#$  must be active low to enable the device and if either one becomes inactive, the chip will be disabled. This feature, along with the open drain RY/BY# pin, allows the system designer to reduce the number of control pins used in a large array of 16-Mbit devices.

The BYTE# pin allows either x8 or x16 read/writes to the 28F016SA. BYTE# at logic low selects 8-bit mode with address  $A_0$  selecting between low byte and high byte. On the other hand, BYTE# at logic high enables 16-bit operation with address  $A_1$  becoming the lowest order address and address  $A_0$  is not used (don't care). A device block diagram is shown in Figure 1.

The 28F016SA is specified for a maximum access time of 100 ns ( $t_{ACC}$ ) at 5.0V operation (4.5V to 5.5V) over the extended temperature range ( $-45^{\circ}$ C to  $+85^{\circ}$ C). A corresponding maximum access time of 150 ns at 3.3V (3.0V to 3.6V and  $-45^{\circ}$ C to  $+85^{\circ}$ C) is achieved for reduced power consumption applications.

The 28F016SA incorporates an Automatic Power Saving (APS) feature which substantially reduces the active current when the device is in static mode of operation (addresses not switching).

In APS mode, the typical  $I_{CC}$  current is 1 mA at 5.0V (0.8 mA at 3.3V).

A Deep Power-Down mode of operation is invoked when the RP# (called  $\overline{PWD}$  on the 28F008SA) pin transitions low. This mode brings the device power consumption to less than 3.0  $\mu\text{A}$ , typically, and provides additional write protection by acting as a device reset pin during power transitions. A reset time of 550 ns is required from RP# switching high until outputs are again valid. In the Deep Power-Down state, the WSM is reset (any current operation will abort) and the CSR, GSR and BSR registers are cleared.

A CMOS Standby mode of operation is enabled when either  $CE_0\#$  or  $CE_1\#$  transitions high and RP# stays high with all input control pins at CMOS levels. In this mode the device typically draws an  $I_{CC}$  standby current of 70  $\mu$ A.

#### 2.0 DEVICE PINOUT

The 28F016SA 56L SSOP pinout configuration is shown in Figure 2.





Figure 1. 28F016SA Block Diagram Architectural Evolution Includes Page Buffers, Queue Registers and Extended Status Registers



## 2.1 Lead Descriptions

| Symbol                               | Туре                 | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub>                       | INPUT                | <b>BYTE-SELECT ADDRESS:</b> Selects between high and low byte when device is in $x8$ mode. This address is latched in $x8$ Data Writes. Not used in $x16$ mode (i.e., the $A_0$ input buffer is turned off when BYTE # is high).                                                                                                                                                                                                                                                            |
| A <sub>1</sub> -A <sub>15</sub>      | INPUT                | <b>WORD-SELECT ADDRESSES:</b> Select a word within one 64-KByte block. $A_{6-15}$ selects 1 of 1024 rows, and $A_{1-15}$ selects 16 of 512 columns. These addresses are latched during Data Writes.                                                                                                                                                                                                                                                                                         |
| A <sub>16</sub> -A <sub>20</sub>     | INPUT                | <b>BLOCK-SELECT ADDRESSES:</b> Select 1 of 32 Erase block. These addresses are latched during Data Writes, Erase and Lock-Block operations.                                                                                                                                                                                                                                                                                                                                                 |
| DQ <sub>0</sub> –DQ <sub>7</sub>     | INPUT/<br>OUTPUT     | LOW-BYTE DATA BUS: Inputs data and commands during CUI write cycles. Outputs array, buffer, identifier or status data in the appropriate Read mode. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                                                                                                                                                       |
| DQ <sub>8</sub> -DQ <sub>15</sub>    | INPUT/<br>OUTPUT     | HIGH-BYTE DATA BUS: Inputs data during x16 Data-Write operations. Outputs array, buffer or identifier data in the appropriate Read mode; not used for Status Register reads. Floated when the chip is de-selected or the outputs are disabled.                                                                                                                                                                                                                                              |
| CE <sub>0</sub> #, CE <sub>1</sub> # | INPUT                | <b>CHIP ENABLE INPUTS:</b> Activate the device's control logic, input buffers, decoders and sense amplifiers. With either $CE_0\#$ or $CE_1\#$ high, the device is de-selected and power consumption reduces to Standby levels upon completion of any current Data-Write or Erase operations. Both $CE_0\#$ and $CE_1\#$ must be low to select the device.                                                                                                                                  |
|                                      |                      | All timing specifications are the same for both signals. Device Selection occurs with the latter falling edge of $CE_0\#$ or $CE_1\#$ . The first rising edge of $CE_0\#$ or $CE_1\#$ disables the device.                                                                                                                                                                                                                                                                                  |
| RP#                                  | INPUT                | RESET/POWER-DOWN: RP# low places the device in a Deep Power-Down state. All circuits that static power, even those circuits enabled in standby mode, are turned off. When returning from Deep Power-Down, a recovery time of 400 ns is required to allow these circuits to power-up.                                                                                                                                                                                                        |
|                                      |                      | When RP# goes low, any current or pending WSM operation(s) are terminated, and the device is reset. All Status Registers return to ready (with all status flags cleared).                                                                                                                                                                                                                                                                                                                   |
| OE#                                  | INPUT                | OUTPUT ENABLE: Gates device data through the output buffers when low. The outputs float to tri-state off when OE# is high.  NOTE:  CE <sub>x</sub> # overrides OE#, and OE# overrides WE#.                                                                                                                                                                                                                                                                                                  |
| WE#                                  | INPUT                | WRITE ENABLE: Controls access to the CUI, Page Buffers, Data Queue Registers and Address Queue Latches. WE# is active low, and latches both address and data (command or array) on its rising edge.                                                                                                                                                                                                                                                                                         |
| RY/BY#                               | OPEN DRAIN<br>OUTPUT | <b>READY/BUSY:</b> Indicates status of the internal WSM. When low, it indicates that the WSM is busy performing an operation. RY/BY# high indicates that the WSM is ready for new operations (or WSM has completed all pending operations), or Erase is Suspended, or the device is in deep power-down mode. This output is always active (i.e., not floated to tri-state off when OE# or CE <sub>0</sub> #, CE <sub>1</sub> # are high), except if a RY/BY# Pin Disable command is issued. |



## 2.1 Lead Descriptions (Continued)

| Symbol          | Туре   | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WP#             | INPUT  | WRITE PROTECT: Erase blocks can be locked by writing a non-volatile lock-bit for each block. When WP# is low, those locked blocks as reflected by the Block-Lock Status bits (BSR.6), are protected from inadvertent Data Writes or Erases. When WP# is high, all blocks can be Written or Erased regardless of the state of the lock-bits. The WP# input buffer is disabled when RP# transitions low (deep power-down mode). |
| BYTE#           | INPUT  | BYTE ENABLE: BYTE# low places device in x8 mode. All data is then input or output on $DQ_{0-7}$ , and $DQ_{8-15}$ float. Address $A_0$ selects between the high and low byte. BYTE# high places the device in x16 mode, and turns off the $A_0$ input buffer. Address $A_1$ then becomes the lowest order address.                                                                                                            |
| 3/5#            | INPUT  | 3.3/5.0 VOLT SELECT: 3/5# high configures internal circuits for 3.3V operation. 3/5# low configures internal circuits for 5.0V operation. NOTES: Reading the array with 3/5# high in a 5.0V system could damage the device. There is a significant delay from 3/5# switching to valid data.                                                                                                                                   |
| V <sub>PP</sub> | SUPPLY | <b>ERASE/WRITE POWER SUPPLY:</b> For erasing memory array blocks or writing words/ bytes/pages into the flash array                                                                                                                                                                                                                                                                                                           |
| Vcc             | SUPPLY | <b>DEVICE POWER SUPPLY (3.3V <math>\pm</math> 0.3V, 5.0V <math>\pm</math> 0.5V): Don't leave any power pins floating.</b>                                                                                                                                                                                                                                                                                                     |
| GND             | SUPPLY | GROUND FOR ALL INTERNAL CIRCUITRY: Do not leave any ground pins floating.                                                                                                                                                                                                                                                                                                                                                     |
| NC              |        | NO CONNECT: No internal connection to die, lead may be driven or left floating.                                                                                                                                                                                                                                                                                                                                               |



Figure 2. 56-Lead SSOP Pinout Configuration



### 3.0 MEMORY MAPS



Figure 3. 28F016SA Memory Map (Byte-Wide Mode)



## 3.1 Extended Status Registers Memory Map



Figure 4a. Extended Status Register Memory Map (Byte-Wide Mode)



Figure 4b. Extended Status Register Memory Map (Word-Wide Mode)



## 4.0 BUS OPERATIONS, COMMANDS AND STATUS REGISTER DEFINITIONS

## 4.1 Bus Operations for Word-Wide Mode (BYTE $\# = V_{IH}$ )

| Mode            | Notes | RP#             | CE <sub>1</sub> #                                     | CE <sub>O</sub> #                                     | OE#             | WE#             | A <sub>1</sub>  | DQ <sub>0-15</sub> | RY/BY#          |
|-----------------|-------|-----------------|-------------------------------------------------------|-------------------------------------------------------|-----------------|-----------------|-----------------|--------------------|-----------------|
| Read            | 1,2,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | Х               | D <sub>OUT</sub>   | Х               |
| Output Disable  | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | High Z             | Х               |
| Standby         | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IH</sub> | X               | Х               | Х               | High Z             | Х               |
| Deep Power-Down | 1,3   | $V_{IL}$        | Х                                                     | Х                                                     | Х               | Х               | Х               | High Z             | V <sub>OH</sub> |
| Manufacturer ID | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 0089H              | V <sub>OH</sub> |
| Device ID       | 4     | ν <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | 66A0H              | V <sub>OH</sub> |
| Write           | 1,5,6 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IL</sub> | Х               | D <sub>IN</sub>    | Х               |

## 4.2 Bus Operations for Byte-Wide Mode (BYTE $\# = V_{IL}$ )

|                 |       |                 |                                                       |                                                       |                 | 1                 |                 |                   |                 |
|-----------------|-------|-----------------|-------------------------------------------------------|-------------------------------------------------------|-----------------|-------------------|-----------------|-------------------|-----------------|
| Mode            | Notes | RP#             | CE <sub>1</sub> #                                     | CE <sub>0</sub> #                                     | OE#             | WE#               | A <sub>0</sub>  | DQ <sub>0-7</sub> | RY/BY#          |
| Read            | 1,2,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | VIL             | V <sub>IH</sub>   | Х               | DOUT              | Х               |
| Output Disable  | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | VIH             | V <sub>IH</sub> . | Х               | High Z            | Х               |
| Standby         | 1,6,7 | V <sub>IH</sub> | V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>IH</sub> | V <sub>IH</sub><br>V <sub>IL</sub><br>V <sub>IH</sub> | X               | <b>X</b>          | X               | High Z            | Х               |
| Deep Power-Down | 1,3   | V <sub>IL</sub> | Х                                                     | х                                                     | х               | х                 | Х               | High Z            | V <sub>OH</sub> |
| Manufacturer ID | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub>   | V <sub>IL</sub> | 89H               | V <sub>OH</sub> |
| Device ID       | 4     | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IL</sub> | V <sub>IH</sub>   | V <sub>IH</sub> | A0H               | V <sub>OH</sub> |
| Write           | 1,5,6 | V <sub>IH</sub> | V <sub>IL</sub>                                       | V <sub>IL</sub>                                       | V <sub>IH</sub> | V <sub>IL</sub>   | X               | D <sub>IN</sub>   | Х               |

#### **NOTES:**

- 1. X can be  $V_{IH}$  or  $V_{IL}$  for address or control pins except for RY/BY#, which is either  $V_{OL}$  or  $V_{OH}$ .
- RY/BY# output is open drain. When the WSM is ready, Erase is suspended or the device is in deep power-down mode, RY/BY# will be at V<sub>OH</sub> if it is tied to V<sub>CC</sub> through a resistor. RY/BY# at V<sub>OH</sub> is independent of OE# while a WSM operation is in progress.
- 3. RP# at GND  $\pm$  0.2V ensures the lowest deep power-down current.
- 4. A<sub>0</sub> and A<sub>1</sub> at V<sub>IL</sub> provide device manufacturer ID codes in x8 and x16 modes respectively.
  - A<sub>0</sub> and A<sub>1</sub> at V<sub>IH</sub> provide device ID codes in x8 and x16 modes respectively. All other addresses are set to zero.
- Commands for different Erase operations, Data Write operations or Lock-Block operations can only be successfully completed when V<sub>PP</sub> = V<sub>PPH</sub>.
- While the WSM is running, RY/BY# in Level-Mode (default) stays at V<sub>OL</sub> until all operations are complete. RY/BY# goes to V<sub>OH</sub> when the WSM is not busy or in erase suspend mode.
- RY/BY# may be at V<sub>OL</sub> while the WSM is busy performing various operations. For example, a Status Register read during a Write operation.



### 4.3 28F008SA—Compatible Mode Command Bus Definitions

| Command                         | Notes | Fire  | st Bus Cy | cle  | Second Bus Cycle |      |      |
|---------------------------------|-------|-------|-----------|------|------------------|------|------|
|                                 |       | Oper  | Addr      | Data | Oper             | Addr | Data |
| Read Array                      |       | Write | X         | FFH  | Read             | AA   | AD   |
| Intelligent Identifier          | 1     | Write | Х         | 90H  | Read             | IA   | ID   |
| Read Compatible Status Register | 2     | Write | Х         | 70H  | Read             | Х    | CSRD |
| Clear Status Register           | 3     | Write | Х         | 50H  |                  |      |      |
| Word/Byte Write                 |       | Write | Х         | 40H  | Write            | WA   | WD   |
| Alternate Word/Byte Write       |       | Write | Х         | 10H  | Write            | WA   | WD   |
| Block Erase/Confirm             |       | Write | Х         | 20H  | Write            | BA   | D0H  |
| Erase Suspend/Resume            |       | Write | Х         | вон  | Write            | X    | D0H  |

#### **ADDRESS**

AA = Array Address

BA = Block Address

IA = Identifier Address

WA = Write Address X = Don't Care

#### **DATA**

AD = Array Data

CSRD = CSR Data

ID = Identifier Data

WD = Write Data

#### NOTES

1. Following the Intelligent Identifier command, two Read operations access the manufacturer and device signature codes.

2. The CSR is automatically available after device enters Data Write, Erase, or Suspend operations.

Clears CSR.3, CSR.4 and CSR.5. Also clears GSR.5 and all BSR.5 and BSR.2 bits. See Status Register definitions.



## 4.4 28F016SA—Performance Enhancement Command Bus Definitions

| Command                              | Mode | Notes    | First | Bus C | ycle | Sec   | ond Bu         | s Cycle      | Thi   | rd Bus | Cycle   |
|--------------------------------------|------|----------|-------|-------|------|-------|----------------|--------------|-------|--------|---------|
| Command                              | Wode | Notes    | Oper  | Addr  | Data | Oper  | Addr           | Data         | Oper  | Addr   | Data    |
| Read Extended<br>Status Register     |      | 1        | Write | ×     | 71H  | Read  | RA             | GSRD<br>BSRD |       |        | •       |
| Page Buffer Swap                     |      | 7        | Write | X     | 72H  |       |                |              |       |        |         |
| Read Page Buffer                     |      |          | Write | Х     | 75H  | Read  | PA             | PD           |       |        |         |
| Single Load to<br>Page Buffer        |      |          | Write | Х     | 74H  | Write | PA             | PD           |       |        |         |
| Sequential Load                      | x8   | 4,6,10   | Write | Х     | E0H  | Write | Х              | BCL          | Write | Х      | всн     |
| to Page Buffer                       | x16  | 4,5,6,10 | Write | Х     | E0H  | Write | X.             | WCL          | Write | Χ      | WCH     |
| Page Buffer                          | x8   | 3,4,9,10 | Write | Х     | 0CH  | Write | A <sub>0</sub> | BC(L,H)      | Write | WA     | BC(H,L) |
| Write to Flash                       | x16  | 4,5,10   | Write | Х     | 0CH  | Write | Х              | WCL          | Write | WA     | WCH     |
| Two-Byte Write                       | x8   | 3        | Write | Х     | FBH  | Write | A <sub>0</sub> | WD(L,H)      | Write | WA     | WD(H,L) |
| Lock Block/Confirm                   |      |          | Write | Х     | 77H  | Write | ВА             | D0H          |       |        |         |
| Upload Status<br>Bits/Confirm        |      | 2        | Write | Х     | 97H  | Write | ×              | D0H          |       |        |         |
| Upload Device<br>Information         |      |          | Write | Х     | 99H  | Write | Х              | D0H          |       |        |         |
| Erase All Unlocked<br>Blocks/Confirm |      |          | Write | X     | А7Н  | Write | Х              | D0H          |       | -      |         |
| RY/BY# Enable<br>to Level-Mode       |      | 8        | Write | Х     | 96H  | Write | Х              | D0H          |       |        |         |
| RY/BY# Pulse-<br>On-Write            |      | 8        | Write | Х     | 96H  | Write | Х              | 02H          |       |        |         |
| RY/BY# Pulse-<br>On-Erase            |      | . 8      | Write | Х     | 96H  | Write | Х              | 03H          |       |        |         |
| RY/BY# Disable                       |      | 8        | Write | Х     | 96H  | Write | . X            | 04H          |       |        |         |
| Sleep                                |      |          | Write | Х     | F0H  | ,     |                |              |       |        |         |
| Abort                                |      | 1.       | Write | Х     | 80H  |       |                |              |       |        |         |

#### **ADDRESS**

BA = Block Address

PA = Page Buffer Address

RA = Extended Register Address

WA = Write Address

X = Don't Care

#### DATA

AD = Array Data

PD = Page Buffer Data

BSRD = BSR Data

GSRD = GSR Data

WC (L,H) = Word Count (Low, High)

BC(L,H) = Byte Count(Low, High)

WD (L,H) = Write Data (Low, High)



#### NOTES:

- 1. RA can be the GSR address or any BSR address. See Figures 4a and 4b for Extended Status Register Memory Maps.
- Upon device power-up, all BSR lock-bits come up locked. The Upload Status Bits command must be written to reflect the actual lock-bit status.
- A<sub>0</sub> is automatically complemented to load second byte of data. BYTE# must be at V<sub>IL</sub>.
   A<sub>0</sub> value determines which WD/BC is supplied first: A<sub>0</sub> = 0 looks at the WDL/BCL, A<sub>0</sub> = 1 looks at the WDH/BCH.
- 4. BCH/WCH must be at 00H for this product because of the 256-byte (128-word) Page Buffer size, and to avoid writing the Page Buffer contents to more than one 256-byte segment within an array block. They are simply shown for future Page Buffer expandability.
- 5. In x16 mode, only the lower byte DQ<sub>0-7</sub> is used for WCL and WCH. The upper byte DQ<sub>8-15</sub> is a don't care.
- 6. PA and PD (whose count is given in cycles 2 and 3) are supplied starting in the 4th cycle, which is not shown.
- 7. This command allows the user to swap between available Page Buffers (0 or 1).
- 8. These commands reconfigure RY/BY# output to one of two pulse-modes or enable and disable the RY/BY# function.
- Write address, WA, is the Destination address in the flash array which must match the Source address in the Page Buffer. Refer to the 28F016SA User's Manual.
- 10. BCL = 00H corresponds to a Byte count of 1. Similarly, WCL = 00H corresponds to a Word count of 1.

## 4.5 Compatible Status Register

| WSMS | ESS | ES | DWS | VPPS | R | R | R |
|------|-----|----|-----|------|---|---|---|
| 7    | 6   | 5  | 4   | 3    | 2 | 1 | 0 |

#### NOTES:

#### CSR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

RY/BY# output or WSMS bit must be checked to determine completion of an operation (Erase Suspend, Erase, or Data Write) before the appropriate Status bit (ESS, ES or DWS) is checked for success.

#### CSR.6 = ERASE-SUSPEND STATUS

1 = Erase Suspended

0 = Erase In Progress/Completed

#### CSR.5 = ERASE STATUS

1 = Error In Block Erasure

0 = Successful Block Erase

#### CSR.4 = DATA-WRITE STATUS

1 = Error in Data Write

0 = Data Write Successful

#### $CSR.3 = V_{PP} STATUS$

1 = V<sub>PP</sub> Low Detect, Operation Abort

 $0 = V_{PP} OK$ 

If DWS and ES are set to "1" during an erase attempt, an improper command sequence was entered. Clear the CSR and attempt the operation again.

The VPPS bit, unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM interrogates V<sub>PP</sub>'s level only after the Data-Write or Erase command sequences have been entered, and informs the system if V<sub>PP</sub> has not been switched on. VPPS is not guaranteed to report accurate feedback between V<sub>PPI</sub> and V<sub>PPH</sub>.

#### CSR.2-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the CSR.



4.6 Global Status Register

| WSMS | oss | DOS | DSS | QS | PBAS | PBS | PBSS |
|------|-----|-----|-----|----|------|-----|------|
| 7    | 6   | 5   | 4   | 3  | 2    | 1   | 0    |

#### GSR.7 = WRITE STATE MACHINE STATUS

- 1 = Ready
- 0 = Busy

#### NOTES:

1. RY/BY# output or WSMS bit must be checked to determine completion of an operation (Block Lock, Suspend, any RY/BY# reconfiguration, Upload Status Bits, Erase or Data Write) before the appropriate Status bit (OSS or DOS) is checked for success.

#### GSR.6 = OPERATION SUSPEND STATUS

- 1 = Operation Suspended
- 0 = Operation in Progress/Completed

#### GSR.5 = DEVICE OPERATION STATUS

- 1 = Operation Unsuccessful
- 0 = Operation Successful or Currently Running

#### GSR.4 = DEVICE SLEEP STATUS

- 1 = Device in Sleep
- 0 = Device Not in Sleep

#### MATRIX 5/4

- 0 0 = Operation Successful or Currently Running
- 0 1 = Device in Sleep mode or Pending Sleep
- 1 0 = Operation Unsuccessful
- 1 1 = Operation Unsuccessful or Aborted

If operation currently running, then GSR.7 = 0. If device pending sleep, then GSR.7 = 0.

Operation aborted: Unsuccessful due to Abort command.

#### GSR.3 = QUEUE STATUS

- 1 = Queue Full
- 0 = Queue Available

#### GSR.2 = PAGE BUFFER AVAILABLE STATUS

- 1 = One or Two Page Buffers Available
- 0 = No Page Buffer Available

#### GSR.1 = PAGE BUFFER STATUS

- 1 = Selected Page Buffer Ready
- 0 = Selected Page Buffer Busy

#### GSR.0 = PAGE BUFFER SELECT STATUS

- 1 = Page Buffer 1 Selected
- 0 = Page Buffer 0 Selected

## The device contains two Page Buffers.

Selected Page Buffer is currently busy with WSM operation.

#### NOTE:

 When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



## 4.7 Block Status Register

| BS | BLS | BOS | BOAS | QS | VPPS | VPPL | R |
|----|-----|-----|------|----|------|------|---|
| 7  | 6   | 5   | 4    | 3  | 2    | 1    | 0 |

#### NOTES:

BSR.7 = BLOCK STATUS

1 = Ready

0 = Busy

1. RY/BY# output or BS bit must be checked to determine completion of an operation (Block Lock, Suspend, Erase or Data Write) before the appropriate Status bits (BOS, BLS) is checked for success.

BSR.6 = BLOCK-LOCK STATUS

1 = Block Unlocked for Write/Erase

0 = Block Locked for Write/Erase

BSR.5 = BLOCK OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

BSR.4 = BLOCK OPERATION ABORT STATUS

1 = Operation Aborted

0 = Operation Not Aborted

MATRIX 5/4

0 0 = Operation Successful or

Currently Running
0 1 = Not a Valid Combination

1 0 = Operation Unsuccessful

1 1 = Operation Aborted

BSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

BSR.2 = V<sub>PP</sub> STATUS

1 = V<sub>PP</sub> Low Detect, Operation Abort

 $0 = V_{PP} OK$ 

Operation halted via Abort Command.

The BOAS bit will not be set until BSR.7 = 1.

#### NOTE:

BSR.1-0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use; mask them out when polling the BSRs.

 When multiple operations are queued, checking BSR.7 only provides indication of completion for that particular block. GSR.7 provides indication when all queued operations are completed.



#### 5.0 ELECTRICAL SPECIFICATIONS

### 5.1 Absolute Maximum Ratings\*

Temperature under Bias  $\dots -40^{\circ}$ C to  $+85^{\circ}$ C Storage Temperature  $\dots -65^{\circ}$ C to  $+125^{\circ}$ C

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### **EXTENDED TEMPERATURE OPERATING CONDITIONS**

 $V_{CC} = 3.3V \pm 0.3V$  Systems

| Symbol          | Parameter                                                            | Notes | Min  | Max                   | Units | Test Conditions     |
|-----------------|----------------------------------------------------------------------|-------|------|-----------------------|-------|---------------------|
| TA              | Operating Temperature,<br>Extended Temperature                       | 1     | -40  | 85                    | ů     | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                  | 2     | -0.2 | 7.0                   | ٧     |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with<br>Respect to GND                | 2,3   | -0.2 | 14.0                  | ٧     |                     |
| V               | Voltage on any Pin (except $V_{CC}$ , $V_{PP}$ ) with Respect to GND | 2     | -0.5 | V <sub>CC</sub> + 0.5 | ٧     |                     |
| 1.,             | Current into any Non-Supply Pin                                      |       |      | ±30                   | mA    | ,                   |
| lout            | Output Short Circuit Current                                         | 4     |      | 100                   | mA    |                     |

#### $V_{CC} = 5.0V \pm 0.5V$ Systems

| Symbol          | Parameter                                                            | Notes | Min  | Max  | Units | Test Conditions     |
|-----------------|----------------------------------------------------------------------|-------|------|------|-------|---------------------|
| TA              | Operating Temperature, Extended Temperature                          | 1     | -40  | 85   | °C    | Ambient Temperature |
| V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND                                  | 2     | -0.2 | 7.0  | ٧     |                     |
| V <sub>PP</sub> | V <sub>PP</sub> Supply Voltage with Respect to GND                   | 2,3   | -0.2 | 14.0 | ٧     |                     |
| V               | Voltage on any Pin (except $V_{CC}$ , $V_{PP}$ ) with Respect to GND | 2     | -2.0 | 7.0  | ٧     |                     |
| 1               | Current into any Non-Supply Pin                                      |       |      | ±30  | mA    |                     |
| lout            | Output Short Circuit Current                                         | 4     |      | 100  | mA    |                     |

#### NOTES:

1. Operating temperature is for extended temperature product defined by this specification.

Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is V<sub>CC</sub> + 0.5V which, during transitions, may overshoot to V<sub>CC</sub> + 2.0V for periods <20 ns.</li>

3. Maximum DC voltage on Vpp may overshoot to +14.0V for periods <20 ns.

4. Output shorted for no more than one second. No more than one output shorted at a time.



## 5.2 Capacitance

For a 3.3V  $\pm$  0.3V System:

| Symbol            | Parameter                                                       | Notes | Тур | Max | Units | Test Conditions                          |
|-------------------|-----------------------------------------------------------------|-------|-----|-----|-------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                 | 1     | 6   | 8   | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an<br>Output Pin                       | 1     | 8   | 12  | pF    | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing Specifications | 1     |     | 50  | pF    | For $V_{CC} = 3.3V \pm 0.3V$             |
|                   | Equivalent Load Timing Circuit                                  |       |     | 2.5 | ns    | 50Ω Transmission<br>Line Delay           |

### For 5.0V ± 0.5V System:

| Symbol            | Parameter                                                       | Notes | Тур | Max | Units           | Test Conditions                          |
|-------------------|-----------------------------------------------------------------|-------|-----|-----|-----------------|------------------------------------------|
| C <sub>IN</sub>   | Capacitance Looking into an Address/Control Pin                 | 1     | 6   | 8   | pF <sub>.</sub> | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>OUT</sub>  | Capacitance Looking into an Output Pin                          | · 1   | 8   | 12  | pF              | $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ |
| C <sub>LOAD</sub> | Load Capacitance Driven by<br>Outputs for Timing Specifications | 1     |     | 100 | pF              | For $V_{CC} = 5.0V \pm 0.5V$             |
|                   | Equivalent Testing Load Circuit                                 |       |     | 2.5 | ns              | 25Ω Transmission<br>Line Delay           |

#### NOTE:

1. Sampled, not 100% tested.



## 5.3 Timing Nomenclature

All 3.3V system timings are measured from where signals cross 1.5V.

For 5.0V systems use the standard JEDEC cross point definitions.

Each timing parameter consists of 5 characters. Some common examples are defined below:

t<sub>CE</sub> t<sub>ELQV</sub> time(t) from CE# (E) going low (L) to the outputs (Q) becoming valid (V)

t<sub>OF</sub> t<sub>GLOV</sub> time(t) from OE# (G) going low (L) to the outputs (Q) becoming valid (V)

t<sub>ACC</sub> t<sub>AVQV</sub> time(t) from address (A) valid (V) to the outputs (Q) becoming valid (V)

t<sub>AS</sub> t<sub>AVWH</sub> time(t) from address (A) valid (V) to WE# (W) going high (H)

t<sub>DH</sub> t<sub>WHDX</sub> time(t) from WE# (W) going high (H) to when the data (D) can become undefined (X)

|    | Pin Characters                  |     | Pin States                        |
|----|---------------------------------|-----|-----------------------------------|
| Α  | Address Inputs                  | Н   | High                              |
| D  | Data Inputs                     | L   | Low                               |
| Q  | Data Outputs                    | V   | Valid                             |
| E. | CE# (Chip Enable)               | . X | Driven, but Not Necessarily Valid |
| F  | BYTE# (Byte Enable)             | Z   | High Impedance                    |
| G  | OE# (Output Enable)             | i   |                                   |
| W  | WE# (Write Enable)              |     |                                   |
| Р  | RP# (Deep Power-Down Pin)       |     |                                   |
| R  | RY/BY# (Ready Busy)             |     |                                   |
| V  | Any Volltage Level              |     | 1.5                               |
| Y  | 3/5# Pin (28F016SA Only)        |     |                                   |
| 5V | V <sub>CC</sub> at 4.5V Minimum |     |                                   |
| 3V | V <sub>CC</sub> at 3.0V Minimum |     |                                   |





Figure 5. Transient Input/Output Reference Waveform ( $V_{CC} = 5.0V \pm 10\%$ )



Figure 6. Transient Input/Output Reference Waveform ( $V_{CC} = 3.3V \pm 0.3V$ )



Figure 7. Transient Equivalent Testing Load Circuit ( $V_{CC} = 5.0V \pm 10\%$ )



Figure 8. Transient Equivalent Testing Load Circuit ( $V_{CC}=3.3V\pm0.3V$ )



## 5.4 DC Characteristics: EXTENDED TEMPERATURE OPERATION

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

| Symbol | Parameter                                   | Notes | Min | Тур | Max  | Units            | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|---------------------------------------------|-------|-----|-----|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| lu     | Input Load Current                          | 1     |     |     | ±1   | μΑ               | $V_{CC} = V_{CC} Max$ ,<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| lLO    | Output Leakage Current                      | 1     |     |     | ± 10 | μΑ               | $V_{CC} = V_{CC} Max$ ,<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Iccs   | V <sub>CC</sub> Standby<br>Current          | 1,5   |     | 70  | 250  | μ <b>Α</b><br>,^ | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC}  \text{Max}, \\ \text{CE}_0\#, \text{CE}_1\#, \text{RP}\# = \text{V}_{CC} \\ \pm  0.2\text{V} \\ \text{BYTE}\#, \text{WP}\# = \text{V}_{CC} \pm  0.2\text{V} \\ \text{or GND}  \pm  0.2\text{V} \end{array}$                                                                                                                                                                                                                                                                                                                                                       |
|        |                                             |       |     | 1   | 10   | mA               | $\begin{split} &V_{CC} = V_{CC}Max,\\ &CE_0\#, CE_1\#, RP\# = V_{IH}\\ &BYTE\#, WP\# = V_{IH}orV_{IL} \end{split}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ICCD   | V <sub>CC</sub> Deep Power-<br>Down Current | 1     |     | 3   | 35   | μΑ               | $\label{eq:RP#} \begin{aligned} RP\# &= GND \pm 0.2V \\ BYTE\# &= V_{CC} \pm 0.2V \ or \\ GND &\pm 0.2V \end{aligned}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Iccn1  | V <sub>CC</sub> Read Current                | 1,4,5 |     | 30  | 40   | mA               | $\begin{split} & \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ & \text{CMOS: CE}_0 \#, \text{CE}_1 \# = \text{GND} \\ & \pm 0.2 \text{V} \\ & \text{BYTE} \# = \text{GND} \pm 0.2 \text{V or} \\ & \text{V}_{CC} \pm 0.2 \text{V} \\ & \text{Inputs} = \text{GND} \pm 0.2 \text{V or} \\ & \text{V}_{CC} \pm 0.2 \text{V} \\ & \text{TTL: CE}_0 \#, \text{CE}_1 \# \text{V}_{\text{IL}}, \\ & \text{BYTE} \# \text{V}_{\text{IL}} \text{ or V}_{\text{IH}}, \\ & \text{INPUTS} = \text{V}_{\text{IL}} \text{ or V}_{\text{IH}}, \\ & \text{f} = 6.67 \text{ MHz}, \text{I}_{\text{OUT}} = 0 \text{ mA} \end{split}$ |
| ICCR2  | V <sub>CC</sub> Read Current                | 1,4,5 |     | 15  | 25   | mA               | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ \text{CMOS: CE}_0 \#, \text{CE}_1 \# = \text{GND} \\ \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V or} \\ \text{V}_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V or} \\ \text{V}_{CC} \pm 0.2 \text{V} \\ \text{TTL: CE}_0 \#, \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ \text{BYTE} \# = \text{V}_{\text{IL}} \text{ or V}_{\text{IH}} \\ \text{INPUTS} = \text{V}_{\text{IL}} \text{ or V}_{\text{IH}}, \\ \text{f} = 4 \text{ MHz, I}_{OUT} = 0 \text{ mA} \end{array}$                                  |



### 5.4 DC Characteristics: EXTENDED TEMPERATURE OPERATION

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$  (Continued)

| Symbol                         | Parameter                                           | Notes | Min                     | Тур  | Max                     | Units | Test Conditions                                                                 |
|--------------------------------|-----------------------------------------------------|-------|-------------------------|------|-------------------------|-------|---------------------------------------------------------------------------------|
| Iccw                           | V <sub>CC</sub> Write Current                       | 1     |                         | 8    | 12                      | mA    | Word/Byte Write in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                     |
| ICCE                           | V <sub>CC</sub> Block Erase<br>Current              | 1     |                         | 6    | 12                      | mA    | Block Erase in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                         |
| ICCES                          | V <sub>CC</sub> Erase<br>Suspend Current            | 1,2   |                         | 3    | 6                       | mA    | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended |
| IPPS                           | V <sub>PP</sub> Standby/Read                        | 1     |                         | ±1   | ±10                     | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                               |
| IPPR                           | Current                                             |       |                         | 65   | 200                     | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                               |
| I <sub>PPD</sub>               | V <sub>PP</sub> Deep Power-<br>Down Current         | 1     |                         | 0.2  | 5                       | μΑ    | RP# = GND ± 0.2V                                                                |
| I <sub>PPW</sub>               | V <sub>PP</sub> Write Current                       | 1     |                         | 10   | 15                      | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Word/Byte Write in Progress                     |
| IPPE                           | V <sub>PP</sub> Erase Current                       | 1     |                         | 4    | 10                      | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress                         |
| I <sub>PPES</sub>              | V <sub>PP</sub> Erase<br>Suspend Current            | 1     |                         | 65   | 200                     | μΑ    | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Block Erase Suspended                   |
| V <sub>IL</sub>                | Input Low Voltage                                   |       | -0.3                    |      | 0.8                     | V     |                                                                                 |
| V <sub>IH</sub>                | Input High Voltage                                  |       | 2.0                     |      | V <sub>CC</sub><br>+0.3 | V     |                                                                                 |
| V <sub>OL</sub>                | Output Low<br>Voltage                               |       |                         |      | 0.4                     | ٧     | $V_{CC} = V_{CC}$ Min and $I_{OL} = 4$ mA                                       |
| V <sub>OH</sub> <sup>(1)</sup> | Output High<br>Voltage                              |       | 2.4                     |      |                         | ٧     | $I_{OH} = -2.0 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                        |
| V <sub>OH</sub> <sup>(2)</sup> |                                                     |       | V <sub>CC</sub><br>-0.2 |      |                         | ٧     | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$                        |
| V <sub>PPL</sub>               | V <sub>PP</sub> during<br>Normal Operations         | 3     | 0.0                     |      | 6.5                     | V     |                                                                                 |
| V <sub>PPH</sub>               | V <sub>PP</sub> during<br>Write/Erase<br>Operations | 3     | 11.4                    | 12.0 | 12.6                    | V     |                                                                                 |
| V <sub>LKO</sub>               | V <sub>CC</sub> Erase/Write<br>Lockout Voltage      |       | 1.5                     |      |                         | ٧     |                                                                                 |

#### NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 3.3V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. I<sub>CCES</sub> is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum
- of I<sub>CCES</sub> and I<sub>CCR</sub>.

  3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when V<sub>PP</sub> ≤ V<sub>PPL</sub> and not guaranteed in the range between VPPH(min) and VPPL(max).
- 4. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to <1 mA in static operation.
- 5. CMOS Inputs are either  $V_{CC} \pm 0.2V$  or GND  $\pm 0.2V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .



## 5.5 DC Characteristics: EXTENDED TEMPERATURE OPERATION

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

| Symbol            | Parameter                                   | Notes | Min | Тур | Max | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|---------------------------------------------|-------|-----|-----|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tu ·              | Input Load Current                          | 1     |     |     | ±1  | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| l <sub>LO</sub> ` | Output Leakage<br>Current                   | 1     |     |     | ±10 | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Iccs              | V <sub>CC</sub> Standby<br>Current          | 1,5   | ,   | 70  | 250 | μΑ    | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC} \text{ Max} \\ \text{CE}_0\#, \text{CE}_1\#, \text{RP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{BYTE}\#, \text{WP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{or GND} \pm 0.2\text{V} \end{array}$                                                                                                                                                                                                                                                                                                                                                                                 |
| -                 |                                             |       |     | 2   | 10  | mA    | $V_{CC} = V_{CC}$ Max $CE_0\#$ , $CE_1\#$ , $RP\# = V_{IH}$ BYTE#, $WP\# = V_{IH}$ or $V_{IL}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ICCD              | V <sub>CC</sub> Deep Power-<br>Down Current | 1     |     | 10  | 60  | μΑ    | $\begin{aligned} \text{RP\#} &= \text{GND} \pm 0.2\text{V} \\ \text{BYTE\#} &= \text{V}_{\text{CC}} \pm 0.2\text{V} \text{ or} \\ \text{GND} &\pm 0.2\text{V} \end{aligned}$                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Iccn1             | V <sub>CC</sub> Read Current                | 1,4,5 |     | 55  | 70  | mA    | $\begin{split} &V_{CC} = V_{CC} \text{ Max,} \\ &C\text{MOS: } \text{CE}_0 \# \text{ ,CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ &\text{BYTE} \# = \text{GND} \pm 0.2 \text{V} \text{ or} \\ &V_{CC} \pm 0.2 \text{V} \\ &\text{Inputs} = \text{GND} \pm 0.2 \text{V} \\ &\text{or } V_{CC} \pm 0.2 \text{V} \\ &\text{TTL: } \text{CE}_0 \# \text{, } \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ &\text{BYTE} \# = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}} \\ &\text{Inputs} = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ &\text{f} = 10 \text{ MHz, } \text{I}_{\text{OUT}} = 0 \text{ mA} \end{split}$ |
| ICCR2             | V <sub>CC</sub> Read Current                | 1,4,5 |     | 30  | 35  | mA    | $ \begin{array}{c} V_{CC} = V_{CC} \; \text{Max,} \\ \text{CMOS: } \text{CE}_0 \#, \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V} \; \text{or} \\ V_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V} \; \text{or} \\ V_{CC} \pm 0.2 \text{V} \\ \text{TTL: } \text{CE}_0 \#, \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ \text{BYTE} \# = \text{V}_{\text{IL}} \; \text{or} \; \text{V}_{\text{IH}} \\ \text{Inputs} = \text{V}_{\text{IL}} \; \text{or} \; \text{V}_{\text{IH}}, \\ f = 5 \; \text{MHz, } I_{\text{OUT}} = 0 \; \text{mA} \end{array} $             |



#### 5.5 DC Characteristics

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$  (Continued)

| Symbol                         | Parameter                                           | Notes | Min                     | Тур  | Max                      | Units | Test Conditions                                                                 |
|--------------------------------|-----------------------------------------------------|-------|-------------------------|------|--------------------------|-------|---------------------------------------------------------------------------------|
| Iccw                           | V <sub>CC</sub> Write Current                       | 1     |                         | 25   | 35                       | mA    | Word/Byte in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                           |
| ICCE                           | V <sub>CC</sub> Erase<br>Suspend Current            | 1     |                         | 18   | 25                       | mA    | Block Erase in Progress<br>V <sub>PP</sub> = 12.0V ± 5%                         |
| ICCES                          | V <sub>CC</sub> Block Erase<br>Current              | 1,2   |                         | 5    | 10                       | mA    | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended |
| I <sub>PPS</sub>               | V <sub>PP</sub> Standby/Read                        | 1     |                         | ± 1  | ± 10                     | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                               |
| IPPR                           | Current                                             |       |                         | 65   | 200                      | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                               |
| IPPD                           | V <sub>PP</sub> Deep Power-<br>Down Current         | 1     |                         | 0.2  | 5                        | ·μA   | RP# = GND ± 0.2V                                                                |
| I <sub>PPW</sub>               | V <sub>PP</sub> Write Current                       | 1     |                         | 7    | 12                       | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Word/Byte Write in Progress                     |
| IPPE                           | V <sub>PP</sub> Block Erase<br>Current              | 1     |                         | 5    | 10                       | mA    | V <sub>PP</sub> = 12.0V ± 5%<br>Block Erase in Progress                         |
| I <sub>PPES</sub>              | V <sub>PP</sub> Erase<br>Suspend Current            | 1     |                         | 65   | 200                      | μΑ    | V <sub>PP</sub> = V <sub>PPH</sub> , Block<br>Erase Suspended                   |
| V <sub>IL</sub>                | Input Low Voltage                                   |       | -0.5                    |      | 0.8                      | V     |                                                                                 |
| V <sub>IH</sub>                | Input High Voltage                                  |       | 2.0                     |      | V <sub>CC</sub><br>+ 0.5 | V     |                                                                                 |
| V <sub>OL</sub>                | Output Low<br>Voltage                               |       |                         |      | 0.45                     | ٧     | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                                         |
| V <sub>OH</sub> <sup>(1)</sup> | Output High<br>Voltage                              |       | 0.85<br>V <sub>CC</sub> | ^    |                          | ٧     | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                        |
| V <sub>OH</sub> (2)            | ,                                                   |       | V <sub>CC</sub><br>-0.4 |      |                          |       | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$                        |
| V <sub>PPL</sub>               | V <sub>PP</sub> during Normal<br>Operations         | 3     | 0.0                     |      | 6.5                      | ٧     |                                                                                 |
| V <sub>PPH</sub>               | V <sub>PP</sub> during<br>Write/Erase<br>Operations |       | 11.4                    | 12.0 | 12.6                     | ٧     | ,                                                                               |
| V <sub>LKO</sub>               | V <sub>CC</sub> Write/Erase<br>Lockout Voltage      |       | 1.5                     |      |                          | V     |                                                                                 |

#### NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (package and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum of ICCES and ICCR.
- 3. Block Erases, Word/Byte Writes and Lock Block operations are inhibited when V<sub>PP</sub> ≤ V<sub>PPL</sub> and not guaranteed in the ranges between VPPH(min), and VPPL(max).
- 4. Automatic Power Saving (APS) reduces  $I_{CCR}$  to <3 mA typical in Static operation. 5. CMOS Inputs are either  $V_{CC}$   $\pm$  0.2V or GND  $\pm$  0.2V. TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .



# 5.6 AC Characteristics—Read Only Operations<sup>(1)</sup>: EXTENDED TEMPERATURE OPERATION

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = -45^{\circ}C$  to  $+85^{\circ}C$ 

|                   | Versions <sup>(5)</sup>                                             | 28F016 | SA-150   | Units |       |  |
|-------------------|---------------------------------------------------------------------|--------|----------|-------|-------|--|
| Symbol            | Parameter                                                           | Notes  | Min      | Max   | Julia |  |
| t <sub>AVAV</sub> | Read Cycle Time                                                     |        | 150      |       | ns    |  |
| t <sub>AVQV</sub> | Address to Output Delay                                             |        |          | 150   | ns    |  |
| tELQV             | CE# to Output Delay                                                 | 2, 6   |          | 150   | ns    |  |
| t <sub>PHQV</sub> | RP# High to Output Delay                                            |        |          | 750   | ns    |  |
| tGLQV             | OE# to Output Delay                                                 | 2      |          | 50    | ns    |  |
| t <sub>ELQX</sub> | CE# to Output in Low Z                                              | 3, 6   | 0        |       | . ns  |  |
| tEHQZ             | CE# to Output in High Z                                             | 3, 6   |          | 55    | ns    |  |
| t <sub>GLQX</sub> | OE# to Output in Low Z                                              | 3      | 0        |       | ns    |  |
| tghoz             | OE# to Output in High Z                                             | 3      | <u> </u> | 40    | ns    |  |
| t <sub>OH</sub>   | Output Hold from Address, CE# or OE# Change, Whichever Occurs First | 3, 6   | 0        |       | ns    |  |
| t <sub>FLQV</sub> | BYTE# to Output Delay                                               | 3      |          | 150   | ns    |  |
| t <sub>FLQZ</sub> | BYTE# Low to Output in High Z                                       | 3      |          | 40    | ns    |  |
| t <sub>ELFL</sub> | CE# Low to BYTE# High or Low                                        | 3, 6   |          | 5     | ns    |  |
| For Exten         | ded Status Register Reads                                           |        |          |       |       |  |
| tAVEL             | Adress Setup to CE# Going Low                                       | 3, 4   | 0        |       | ns    |  |
| tavgl             | Adress Setup to DE# Going Low                                       | 3, 4   | 0        |       | ns    |  |



## 5.6 AC Characteristics—Read Only Operation(1): EXTENDED TEMPERATURE **OPERATION** (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

|                   | Versions <sup>(5)</sup>                                             | 28F016 | SA-100 | Units |       |  |
|-------------------|---------------------------------------------------------------------|--------|--------|-------|-------|--|
| Symbol            | Parameter                                                           | Notes  | Min    | Max   | Onits |  |
| t <sub>AVAV</sub> | Read Cycle Time                                                     |        | 100    |       | ns    |  |
| t <sub>AVQV</sub> | Address to Output Delay                                             |        |        | 100   | ns    |  |
| t <sub>ELQV</sub> | CE# to Output Delay                                                 | 2, 6   |        | 100   | ns    |  |
| t <sub>PHQV</sub> | RP# High to Output Delay                                            |        |        | 550   | ns    |  |
| tGLQV             | OE# to Output Delay                                                 | 2      |        | 40    | ns    |  |
| t <sub>ELQX</sub> | CE# to Output in Low Z                                              | 3, 6   | 0      |       | ns    |  |
| tEHQZ             | CE# to Output in High Z                                             | 3, 6   |        | 35    | ns    |  |
| t <sub>GLQX</sub> | OE# to Output in Low Z                                              | 3      | 0      |       | ns    |  |
| tGHQZ             | OE# to Output in High Z                                             | 3      |        | 35    | ns    |  |
| tон               | Output Hold from Address, CE# or OE# Change, Whichever Occurs First | 3, 6   | 0      |       | ns    |  |
| t <sub>FLQV</sub> | BYTE# to Output Delay                                               | 3      |        | 100   | ns    |  |
| t <sub>FLQZ</sub> | BYTE# Low to Output in High Z                                       | 3      |        | 30    | ns    |  |
| t <sub>ELFL</sub> | CE# Low to BYTE# High or Low                                        | 3, 6   |        | 5     | ns    |  |
| For Exten         | ded Status Register Reads                                           |        |        |       |       |  |
| tAVEL             | Adress Setup to CE# Going Low                                       | 3, 4   | 0      |       | ns    |  |
| tAVGL             | Adress Setup to DE# Going Low                                       | 3, 4   | 0      |       | ns    |  |

#### **NOTES:**

- 1. See AC Input/Output Reference Waveforms for timing measurements, Figures 5 and 6.
- 2. OE# may be delayed up to t<sub>ELQV</sub>-t<sub>GLQV</sub> after the falling edge of CE#, without impacting t<sub>ELQV</sub>.
- 3. Sampled, not 100% tested.
- 4. This timing parameter is used to latch the correct BSR data onto the outputs.
- 5. Device speeds are defined as:
- 100 ns at  $V_{CC} = 5.0V$  equivalent to 150 ns at  $V_{CC} = 3.3V$ 6.  $CE_X\#$  is defined as the latter of  $CE_0\#$  or  $CE_1\#$  going low, or the first of  $CE_0\#$  or  $CE_1\#$  going high.





Figure 9. Read Timing Waveforms





Figure 10. BYTE # Timing Waveforms



## 5.7 Power-Up and Reset Timings: EXTENDED TEMPERATURE OPERATION



Figure 11. V<sub>CC</sub> Power-Up and RP# Reset Waveforms

| Symbol                                 | Parameter                                                                               | Notes | Min | Max | Unit |
|----------------------------------------|-----------------------------------------------------------------------------------------|-------|-----|-----|------|
| t <sub>PLYL</sub><br>t <sub>PYLH</sub> | RP# Low to 3/5# Low (High)                                                              | ·     | 0   |     | μs   |
| t <sub>YLPH</sub><br>t <sub>YHPH</sub> | 3/5# Low (High) to RP# High                                                             | 1     | 2   |     | μs   |
| t <sub>PL5V</sub>                      | RP# Low to V <sub>CC</sub> at 4.5V Minimum (to V <sub>CC</sub> at 3.0V min or 3.6V max) | 2     | 0   |     | μs   |
| tavqv                                  | Address Valid to Data Valid for $V_{CC} = 5V \pm 10\%$                                  | 3     |     | 100 | ns   |
| t <sub>PHQV</sub>                      | RP# High to Data Valid for $V_{CC} = 5V \pm 10\%$                                       | . 3   |     | 550 | ns   |

#### NOTES:

CE<sub>0</sub>#, CE<sub>1</sub># and OE# are switched low after Power-Up.

- 1. Minimum of 2  $\mu s$  is required to meet the specified  $t_{PHQV}$  times.
- 2. The power supply may start to switch concurrently with RP# going low.
- The address access time and RP# high to data valid time are shown for 5V V<sub>CC</sub> operation. Refer to the AC Characteristics Read Only Operations 3.3V V<sub>CC</sub> operation and all other speed options.



# 5.8 AC Characteristics for WE #—Controlled Command Write Operations(1): EXTENDED TEMPERATURE OPERATION

 $V_{CC}=$  3.3V  $\pm 0.3$ V,  $T_{A}=-40$ °C to +85°C

|                       | Versions                                                                             |       | 2   | 8F016SA | ı-150    | Units  |
|-----------------------|--------------------------------------------------------------------------------------|-------|-----|---------|----------|--------|
| Symbol                | Parameter                                                                            | Notes | Min | Тур     | Max      | Ullits |
| t <sub>AVAV</sub>     | Write Cycle Time                                                                     |       | 150 |         |          | ns     |
| t <sub>VPWH</sub>     | t <sub>VPWH</sub> V <sub>PP</sub> Setup to WE# Going High                            |       | 100 |         |          | ns     |
| t <sub>PHEL</sub>     | RP# Setup to CE# Going Low                                                           | 7     | 480 |         |          | ns     |
| tELWL                 | CE# Setup to WE# Going Low                                                           | 7     | 10  |         |          | ns     |
| t <sub>AVWH</sub>     | Address Setup to WE# Going High                                                      | 2, 6  | 75  |         |          | ns     |
| t <sub>DVWH</sub>     | Data Setup to WE# Going High                                                         | 2, 6  | 75  |         |          | ns     |
| twLWH                 | WE# Pulse Width                                                                      |       | 75  |         |          | ns     |
| twHDX                 | Data Hold from WE# High                                                              | 2     | 10  |         |          | ns     |
| t <sub>WHAX</sub>     | Adderss Hold from WE# High                                                           | 2     | 10  |         |          | ns     |
| twhEH                 | CE# Hold from WE# High                                                               | 7     | 10  |         |          | ns     |
| twhwL                 | WE# Pulse Width High                                                                 |       | 75  |         |          | ns     |
| tGHWL                 | Read Recovery before Write                                                           |       | 0   |         |          | ns     |
| twhrl                 | WE# High to RY/BY# Going Low                                                         |       |     |         | 100      | ns     |
| t <sub>RHPL</sub>     | RP# Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High             | 3     | 0   |         |          | ns     |
| t <sub>PHWL</sub>     | RP# High Recovery to WE# Going Low                                                   |       | 1   |         |          | μs     |
| twhgL                 | Write Recovery before Read                                                           |       | 120 |         | ,        | ns     |
| <sup>t</sup> QVVL     | V <sub>PP</sub> Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High | 3     | 0   |         |          | μs     |
| t <sub>WHQV</sub> (1) | Duration of Word/Byte Write Operation                                                | 4, 5  | 5   | 9       | (Note 8) | μs     |
| t <sub>WHQV</sub> (2) | Duration of Block Erase Operation                                                    | 4     | 0.3 |         | 12       | sec    |



# 5.8 AC Characteristics for WE#—Controlled Command Write Operations<sup>(1)</sup>: EXTENDED TEMPERATURE OPERATION (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

|                       | Versions                                                                             |       | 2    | 8F016SA | -100     | Units  |
|-----------------------|--------------------------------------------------------------------------------------|-------|------|---------|----------|--------|
| Symbol                | Parameter                                                                            | Notes | Min  | Тур     | Max      | Oilles |
| t <sub>AVAV</sub>     | Write Cycle Time                                                                     |       | 100  |         |          | ns     |
| t <sub>VPWH</sub>     | VPWH VPP Setup to WE# Going High                                                     |       | 100  |         |          | ns     |
| t <sub>PHEL</sub>     | RP# Setup to CE# Going Low                                                           | 7     | 480  |         |          | ns     |
| tELWL                 | CE# Setup to WE# Going Low                                                           | 7     | 0    | Ţ       |          | ns     |
| t <sub>AVWH</sub>     | Address Setup to WE# Going High                                                      | 2, 6  | 50   |         |          | ns     |
| t <sub>DVWH</sub>     | Data Setup to WE# Going High                                                         | 2, 6  | . 50 |         |          | ns     |
| twLWH                 | WE# Pulse Width                                                                      |       | 50   |         |          | ns     |
| twHDX                 | Data Hold from WE# High                                                              | 2     | 0    |         |          | ns     |
| twhax                 | Address Hold from WE# High                                                           | 2     | 10   |         |          | ns     |
| twhEH                 | CE# Hold from WE# High                                                               | 7     | -10  | *.      |          | ns     |
| twhwL                 | WE# Pulse Width High                                                                 |       | 50   |         |          | ns     |
| tGHWL                 | Read Recovery before Write                                                           |       | 0    |         |          | ns     |
| twhal                 | WE# High to RY/BY# Going Low                                                         |       |      |         | 100      | ns     |
| t <sub>RHPL</sub>     | RP# Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High             | 3     | 0    |         |          | ns     |
| t <sub>PHWL</sub>     | RP# High Recovery to WE# Going Low                                                   |       | 1    |         |          | μs     |
| twHGL                 | Write Recovery before Read                                                           |       | 80   |         |          | ns     |
| <sup>t</sup> QVVL     | V <sub>PP</sub> Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High | 3     | 0    |         |          | μs     |
| twHQV <sup>(1)</sup>  | Duration of Word/Byte Write Operation                                                | 4, 5  | 4.5  | 6       | (Note 8) | μs     |
| t <sub>WHQV</sub> (2) | Duration of Block Erase Operation                                                    | 4     | 0.3  |         | 10       | sec    |

#### NOTES:

- 1. Read timings during write and erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, not 100% tested.
- 4. Write/Erase durations are measured to valid Status Register (CSR) Data.
- 5. Word/Byte Write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of WE# for all Command Write operations.
- CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
   This information will be available in a technical paper. Please call Intel's Application Hotline or your local sales office.





NOTES:

- 1. This address string depicts Data-Write/Erase cycles with corresponding verification via ESRD.
- 2. This address string depicts Data-Write/Erase cycles with corresponding verification via CSRD.
- 3. This cycle is invalid when using CSRD for verification during Data Write/Erase operations.
- 4. CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- 5. RP# low transition is only to show t<sub>RHPL</sub>; not valid for above Read and Write cycles.

Figure 12. AC Waveforms for Command Write Operations



# 5.9 AC Characteristics for CE#—Controlled Command Write Operations(1): EXTENDED TEMPERATURE OPERATION

 $V_{CC} = 3.3V \pm 0.3V, T_A = -40^{\circ}C + 85^{\circ}C$ 

|                       | Versions                                                                             |         | 2   | 8F0165A | -150     | Units  |
|-----------------------|--------------------------------------------------------------------------------------|---------|-----|---------|----------|--------|
| Symbol                | Parameter                                                                            | Notes   | Min | Тур     | Max      | Oilles |
| t <sub>AVAV</sub>     | Write Cycle Time                                                                     |         | 150 |         | -        | ns     |
| t <sub>PHWL</sub>     | t <sub>PHWL</sub> RP# Setup to WE# Going Low                                         |         | 480 |         |          | ns     |
| t <sub>VPEH</sub>     | V <sub>PP</sub> Setup to CE# Going High                                              | 3, 7    | 100 | -       |          | ns     |
| twlEL                 | WE# Setup to CE# Going Low                                                           | 7       | 0   |         |          | ns     |
| tAVEH                 | Address Setup to CE# Going High                                                      | 2, 6, 7 | 75  |         |          | ns     |
| t <sub>DVEH</sub>     | Data Setup to CE# Going High                                                         | 2, 6, 7 | 75  |         |          | ns     |
| t <sub>ELEH</sub>     | CE# Pulse Width                                                                      | . 7     | 75  |         |          | ns     |
| t <sub>EHDX</sub>     | Data Hold from CE# High                                                              | 2, 7    | 10  |         |          | ns     |
| tEHAX                 | Address Hold from CE# High                                                           | 2, 7    | 10  |         |          | ns     |
| tEHWH                 | WE# Hold from CE# High                                                               |         | 10  |         |          | ns     |
| t <sub>EHEL</sub>     | CE# Pulse Width High                                                                 | 7       | 75  |         |          | ns     |
| tGHEL                 | Read Recovery before Write                                                           |         | 0   |         |          | ns     |
| t <sub>EHRL</sub>     | CE# High to RY/BY# Going Low                                                         | 7       |     |         | 100      | ns     |
| t <sub>RHPL</sub>     | RP# Hold from, Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High            | 3       | 0   |         |          | ns     |
| t <sub>PHEL</sub>     | RP# High Recovery to CE# Going Low                                                   | 7       | 1   |         |          | μs     |
| t <sub>EHGL</sub>     | Write Recovery before Read                                                           |         | 120 |         |          | ns     |
| <sup>t</sup> QVVL     | V <sub>PP</sub> Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High |         | 0   |         |          | μs     |
| t <sub>EHQV</sub> (1) | Duration of Word/Byte Write Operation                                                | 4, 5    | 5   | 9       | (Note 8) | μs     |
| t <sub>EHQV</sub> (2) | Duration of Block Erase Operation                                                    | 4       | 0.3 |         | 12       | sec    |



# 5.9 AC Characteristics for CE#—Controlled Command Write Operations<sup>(1)</sup>: EXTENDED TEMPERATURE OPERATION (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = -40^{\circ}C + 85^{\circ}C$ 

|                       | Versions                                                                             |       | 2   | 8F016SA | -100     | Units |
|-----------------------|--------------------------------------------------------------------------------------|-------|-----|---------|----------|-------|
| Symbol                | Parameter                                                                            | Notes | Min | Тур     | Max      | Omis  |
| tavav                 | Write Cycle Time                                                                     |       | 100 |         |          | ns    |
| t <sub>PHWL</sub>     | RP# Setup to CE# Going Low                                                           |       | 480 |         |          | ns    |
| t <sub>VPEH</sub>     | V <sub>PP</sub> Setup to CE# Going High                                              | 3,7   | 100 |         |          | ns    |
| twlel                 | WE# Setup to CE# Going Low                                                           | 7     | 0   |         |          | ns    |
| taveh                 | Address Setup to CE# Going High                                                      | 2,6,7 | 50  |         |          | ns    |
| toveh                 | Data Setup to CE# Going High                                                         | 2,6,7 | 50  |         |          | ns    |
| tELEH                 | CE# Pulse Width                                                                      | 7     | 50  |         |          | ns    |
| t <sub>EHDX</sub>     | Data Hold from CE# High                                                              | 2,7   | 0   |         |          | ns    |
| tEHAX                 | Address Hold from CE# High                                                           | 2,7   | 10  |         |          | ns    |
| tEHWH                 | WE# Hold from CE# High                                                               |       | 10  |         |          | ns    |
| t <sub>EHEL</sub>     | CE# Pulse Width High                                                                 | 7     | 50  |         |          | ns    |
| tGHEL                 | Read Recovery before Write                                                           |       | 0   |         |          | ns    |
| t <sub>EHRL</sub>     | CE# High to RY/BY# Going Low                                                         | 7     |     |         | 100      | ns    |
| t <sub>RHPL</sub>     | RP# Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High             | 3     | 0   |         |          | ns    |
| t <sub>PHEL</sub>     | RP# High Recovery to CE# Going Low                                                   | 7     | 1   |         |          | μs    |
| tEHGL                 | Write Recovery before Read                                                           |       | 80  |         |          | ns    |
| <sup>t</sup> QVVL     | V <sub>PP</sub> Hold from Valid Status Register (CSR, GSR, BSR) Data and RY/BY# High |       | Ô   |         |          | μs    |
| t <sub>EHQV</sub> (1) | Duration of Word/Byte Write Operation                                                | 4,5   | 4.5 | 6       | (Note 8) | μs    |
| t <sub>EHQV</sub> (2) | Duration of Block Erase Operation                                                    | 4     | 0.3 |         | 10       | sec   |

#### NOTES

- 1. Read timings during write and erase are the same as for normal read.
- 2. Refer to command definition tables for valid address and data values.
- 3. Sampled, not 100% tested.
- 4. Write/Erase durations are measured to valid Status Data.
- 5. Word/Byte Write operations are typically performed with 1 Programming Pulse.
- 6. Address and Data are latched on the rising edge of CE# for all Command Write operations.
  7. CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.
- 8. This information will be available in a technical paper. Please call Intel's Application Hotline or your local sales office.





Figure 13. Alternate AC Waveforms for Command Write Operations



# 5.10 AC Characteristics for WE#—Controlled Page Buffer Write Operations(1): EXTENDED TEMPERATURE OPERATION

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

|                   | Versions                       |       |     | 28F016SA-150 |     |       |  |
|-------------------|--------------------------------|-------|-----|--------------|-----|-------|--|
| Symbol            | Parameter                      | Notes | Min | Тур          | Max | Units |  |
| t <sub>AVAV</sub> | Write Cycle Time               |       | 150 |              |     | ns    |  |
| tELWL             | CE# Setup to WE# Going Low     | 4     | 10  |              |     | ns    |  |
| t <sub>AVWL</sub> | Address Setup to WE# Going Low | 3     | . 0 |              |     | ns    |  |
| t <sub>DVWH</sub> | Data Setup to WE# Going High   | 2     | 50  |              |     | ns    |  |
| twLwH             | WE# Pulse Width                |       | 75  |              |     | ns    |  |
| twHDX             | Data Hold from WE# High        | 2     | 10  |              |     | ns    |  |
| t <sub>WHAX</sub> | Address Hold from WE# High     | 2     | 10  |              |     | ns    |  |
| twheh             | CE# Hold from WE# High         | 4     | 10  |              |     | ns    |  |
| twhwL             | WE# Pulse Width High           |       | 75  |              |     | ns    |  |
| tGHWL             | Read Recovery before Write     |       | 0   |              |     | ns    |  |
| twhgL             | Write Recovery before Read     |       | 120 |              |     | ns    |  |



# 5.10 AC Characteristics for WE#—Controlled Page Buffer Write Operations(1): EXTENDED TEMPERATURE OPERATION (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

|                   | Versions                       |       |     | F016SA-1 | 00  | Units |
|-------------------|--------------------------------|-------|-----|----------|-----|-------|
| Symbol            | Parameter                      | Notes | Min | Тур      | Max | Onits |
| t <sub>AVAV</sub> | Write Cycle Time               |       | 100 |          |     | ns    |
| t <sub>ELWL</sub> | CE# Setup to WE# Going Low     | 4     | 0   |          |     | ns    |
| t <sub>AVWL</sub> | Address Setup to WE# Going Low | 3     | . 0 |          |     | ns    |
| t <sub>DVWH</sub> | Data Setup to WE# Going High   | 2     | 50  |          |     | ns    |
| twLWH             | WE# Pulse Width                |       | 50  |          |     | ns    |
| twHDX             | Data Hold from WE# High        | 2     | ` 0 |          |     | ns    |
| twhax             | Address Hold from WE# High     | 2     | 10  |          |     | ns    |
| twhEH             | CE# Hold from WE# High         | 4     | 10  | 1        |     | ns    |
| twhwL             | WE# Pulse Width High           |       | 50  |          |     | ns    |
| tGHWL             | Read Recovery before Write     |       | 0   |          |     | ns    |
| twHGL             | Write Recovery before Read     |       | 80  |          |     | ns    |

#### NOTES

<sup>1.</sup> These are WE#-controlled write timings, equivalent CE#-controlled write timings apply.

<sup>2.</sup> Sampled, not 100% tested.

<sup>3.</sup> Address must be valid during the entire WE# low pulse or the entire CE# pulse for CE#-controlled writes.

<sup>4.</sup> CEx# is defined as the latter of CE<sub>0</sub># or CE<sub>1</sub># going low, or the first of CE<sub>0</sub># or CE<sub>1</sub># going high.





Figure 14. Page Buffer Write Timing Waveforms (Loading Data to the Page Buffer)

# 5.11 Erase and Word/Byte Write Performance, Cycling Performance and Suspend Latency<sup>(1,3)</sup>: EXTENDED TEMPERATURE OPERATION

 $V_{CC} = 3.3V \pm 0.3V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

| Symbol                | Parameter                              | Notes | Min     | Typ(1)    | Max    | Units  | Test Conditions |
|-----------------------|----------------------------------------|-------|---------|-----------|--------|--------|-----------------|
| ·                     | Page Buffer Byte Write Time            | 1,2,4 |         | 3.26      | Note 6 | μs     |                 |
|                       | Page Buffer Word Write Time            | 1,2,4 |         | 6.53      | Note 6 | μs     |                 |
| t <sub>WHRH</sub> (1) | Word/Byte Write Time                   | 1,2   |         | 9         | Note 6 | μs     |                 |
| t <sub>WHRH</sub> (2) | Block Write Time                       | 1,2   |         | 0.6       | 2.1    | sec    | Byte Write Mode |
| t <sub>WHRH</sub> (3) | Block Write Time                       | 1,2   |         | 0.3       | 1.0    | sec    | Byte Write Mode |
|                       | Block Erase Time                       | 1,2   |         | 1.5       | 12     | sec    |                 |
|                       | Full Chip Erase Time                   | 1,2   |         | 48        |        | sec    |                 |
|                       | Erase Suspend Latency<br>Time to Read  |       |         | 7.0       |        | μs     |                 |
|                       | Erase Suspend Latency<br>Time to Write |       |         | 10.0      |        | μs     |                 |
|                       | Erase Cycles                           | 5     | 100,000 | 1,000,000 |        | Cycles |                 |



# 5.11 Erase and Word/Byte Write Performance, Cycling Performance and Suspend Latency(1,3): EXTENDED TEMPERATURE OPERATION (Continued)

 $V_{CC} = 5.0V \pm 0.5V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ 

| Symbol                | Parameter                              | Notes | Min     | Тур       | Max    | Units  | <b>Test Conditions</b> |
|-----------------------|----------------------------------------|-------|---------|-----------|--------|--------|------------------------|
|                       | Page Buffer Byte Write Time            | 1,2,4 |         | 2.76      | Note 6 | μs     |                        |
|                       | Page Buffer Word Write Time            | 1,2,4 |         | 5.51      | Note 6 | μs     |                        |
| twHRH(1)              | Word/Byte Write Time                   | 1,2   |         | 6         | Note 6 | μs     |                        |
| t <sub>WHRH</sub> (2) | Block Write Time                       | 1,2   |         | 0.4       | 2.1    | sec    | Byte Write Mode        |
| t <sub>WHRH</sub> (3) | Block Write Time                       | 1,2   |         | 0.2       | 1.0    | sec    | Word Write Mode        |
|                       | Block Erase Time                       | 1,2   |         | 1.3       | 10     | sec    |                        |
|                       | Full Chip Erase Time                   | 1,2   |         | 41.6      |        | sec    |                        |
|                       | Erase Suspend Latency<br>Time to Read  |       |         | 5.0       |        | μs     |                        |
|                       | Erase Suspend Latency<br>Time to Write |       |         | 8.0       |        | μs     |                        |
|                       | Erase Cycles                           | 5     | 100,000 | 1,000,000 |        | Cycles |                        |

#### NOTES:

- 1. 25°C,  $V_{CC} = 3.3V$  or 5.0V nominal, 10K cycles.
- 2. Excludes system-level overhead.
- 3. These performance numbers are valid for all speed versions.
- 4. This assumes using the full Page Buffer to Write to Flash (256 Bytes or 128 Words).
- 5. Typical 1,000,000 cycles performance assumes the application uses block retirement techniques.
- This information will be available in a technical paper. Please call Intel's Application hotline or your local sales office for more information.



#### 6.0 MECHANICAL SPECIFICATIONS



Figure 15. Mechanical Specifications of the 56-Lead SSOP Package

|                | Family: Shrink Small Outline Package |         |         |       |  |  |  |
|----------------|--------------------------------------|---------|---------|-------|--|--|--|
| Symbol         | Symbol Millimeters                   |         |         |       |  |  |  |
| Cymbo.         | Minimum                              | Nominal | Maximum | Notes |  |  |  |
| Α              |                                      | 1.80    | 1.90    |       |  |  |  |
| A1             | 0.47                                 | 0.52    | 0.57    |       |  |  |  |
| A2             | 1.18                                 | 1.28    | 1.38    |       |  |  |  |
| В              | 0.25                                 | 0.30    | 0.20    |       |  |  |  |
| С              | 0.13                                 | 0.15    | 0.20    |       |  |  |  |
| D              | 23.40                                | 23.70   | 24.00   |       |  |  |  |
| E              | 13.10                                | 13.30   | 13.50   |       |  |  |  |
| e <sub>1</sub> |                                      | 0.80    |         |       |  |  |  |
| He             | 15.70                                | 16.00   | 16.30   |       |  |  |  |
| N              |                                      | 56      |         |       |  |  |  |
| L <sub>1</sub> | 0.45                                 | 0.50    | 0.55    |       |  |  |  |
| Y              |                                      |         | 0.10    |       |  |  |  |
| a              | 2°                                   | 3°      | 4°      |       |  |  |  |
| b              | 3°                                   | 4°      | 5°      |       |  |  |  |
| R1             | 0.15                                 | 0.20    | 0.25    |       |  |  |  |
| R2             | 0.15                                 | 0.20    | 0.25    |       |  |  |  |



#### **DEVICE NOMENCLATURE/ORDERING INFORMATION**



#### **Valid Combinations**

| Order Code     | $V_{CC} = 3.3V \pm 0.3V$ | $V_{CC} = 5.0V \pm 10\%$ |
|----------------|--------------------------|--------------------------|
| DT28F016SA 100 | DT28F016SA-150           | DT28F016SA-100           |

### **ADDITIONAL INFORMATION**

|        | Item                                                                                      | Order Number     |
|--------|-------------------------------------------------------------------------------------------|------------------|
|        | Commercial Temperature 28F016SA 16 Mbit FlashFile                                         | 290489           |
|        | Commercial Temperature 28F016SV SmartVoltage 16 Mbit                                      | 290528           |
| -      | 28F008SA 8 Mbit FlashFile Memory                                                          | 290429           |
| AP-393 | 28F016SV Compatibility with 28F016SA<br>28F016SA User's Manual                            | 292144<br>297372 |
| AP-377 | 28F016SA Software Drivers                                                                 | 292126           |
| AP-378 | System Optimization Using the Enhanced Features of the 28F016SA                           | 292127           |
| AP-375 | Upgrade Considerations from the 28F0008SA to the 28F016SA                                 | 292124           |
| AP-357 | Power Supply Solutions for Flash Memory                                                   | 292092           |
| AP-374 | Flash Memory Write Protection Techniques                                                  | 292123           |
|        | FLASHBuilder Design Resource Utility                                                      | 297508           |
| AP-607 | Multi-Site Layout Planning with Intel's FlashFile™ Components<br>Including ROM Capability | 292159           |
|        | Small and Low-Cost Power Supply Solution for Intel's Flash Memory<br>Products             | 297534           |
| ER-33  | ETOX™ Flash Memory Technology—Insight to Intel's Fourth Generation Process Innovation     | 294016           |

Please check with Intel Literature for availability.

#### **DATASHEET REVISION HISTORY**

| Number |                  | Description |
|--------|------------------|-------------|
| 001    | Original Version |             |



## 28F008SA 8-MBIT (1-MBIT x 8) FlashFile™ MEMORY

Extended Temperature Specifications Included

- High-Density Symmetrically Blocked Architecture
  - Sixteen 64-Kbvte Blocks
- Extended Cycling Capability
  - 100,000 Block Erase Cycles
  - 1.6 Million Block Erase
     Cycles per Chip
- Automated Byte Write and Block Erase
  - Command User Interface
  - Status Register
- **System Performance Enhancements** 
  - RY/BY # Status Output
  - Erase Suspend Capability
- **■** Deep-Powerdown Mode
  - 0.20 μA I<sub>CC</sub> Typical

- Very High-Performance Read
   85 ns Maximum Access Time
- **SRAM-Compatible Write Interface**
- Hardware Data Protection Feature
   Erase/Write Lockout during Power Transitions
- Industry Standard Packaging — 40-Lead TSOP, 44-Lead PSOP
- ETOX III Nonvolatile Flash Technology — 12V Byte Write/Block Erase
- Independent Software Vendor Support
   Microsoft\* Flash File System (FFS)

Intel's 28F008SA 8-Mbit FlashFile<sup>TM</sup> Memory is the highest density nonvolatile read/write solution for solid state storage. The 28F008SA's extended cycling, symmetrically blocked architecture, fast access time, write automation and low power consumption provide a more reliable, lower power, lighter weight and higher performance alternative to traditional rotating disk technology. The 28F008SA brings new capabilities to portable computing. Application and operating system software stored in resident flash memory arrays provide instanton, rapid execute-in-place and protection from obsolescence through in-system software updates. Resident software also extends system battery life and increases reliability by reducing disk drive accesses.

For high density data acquisition applications, the 28F008SA offers a more cost-effective and reliable alternative to SRAM and battery. Traditional high density embedded applications, such as telecommunications, can take advantage of the 28F008SA's nonvolatility, blocking and minimal system code requirements for flexible firmware and modular software designs.

The 28F008SA is offered in 40-lead TSOP (standard and reverse) and 44-lead PSOP packages. Pin assignments simplify board layout when integrating multiple devices in a flash memory array or subsystem. This device uses an integrated Command User Interface and state machine for simplified block erasure and byte write. The 28F008SA memory map consists of 16 separately erasable 64-Kbyte blocks.

Intel's 28F008SA employs advanced CMOS circuitry for systems requiring low power consumption and noise immunity. Its 85 ns access time provides superior performance when compared with magnetic storage media. A deep powerdown mode lowers power consumption to 1  $\mu$ W typical thru V<sub>CC</sub>, crucial in portable computing, handheld instrumentation and other low-power applications. The RP# power control input also provides absolute data protection during system powerup/down.

Manufactured on Intel's 0.8 micron ETOX process, the 28F008SA provides the highest levels of quality, reliability and cost-effectiveness.

<sup>\*</sup>Microsoft is a trademark of Microsoft Corporation.



#### PRODUCT OVERVIEW

The 28F008SA is a high-performance (8,388,608 bit) memory organized as 1 Mbyte (1,048,576 bytes) of 8 bits each. Sixteen 64-Kbyte (65,536 byte) blocks are included on the 28F008SA. A memory map is shown in Figure 6 of this specification. A block erase operation erases one of the sixteen blocks of memory in typically 1.6 seconds, independent of the remaining blocks. Each block can be independently erased and written 100,000 cycles. Erase Suspend mode allows system software to suspend block erase to read data or execute code from any other block of the 28F008SA.

The 28F008SA is available in the **40-lead TSOP** (Thin Small Outline Package, 1.2 mm thick) and **44-lead PSOP** (Plastic Small Outline) packages. Pinouts are shown in Figures 2 and 4 of this specification.

The **Command User Interface** serves as the interface between the microprocessor or microcontroller and the internal operation of the 28F008SA.

Byte Write and Block Erase Automation allow byte write and block erase operations to be executed using a two-write command sequence to the Command User Interface. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for byte write and block erase operations, including verifications, thereby unburdening the microprocessor or microcontroller. Writing of memory data is performed in byte increments typically within 9  $\mu$ s, an 80% improvement over current flash memory products. Ipp byte write and block erase currents are 10 mA typical, 30 mA maximum. Vpp byte write and block erase voltage is 11.4V to 12.6V.

The **Status Register** indicates the status of the WSM and when the WSM successfully completes the desired byte write or block erase operation.

The RY/BY# output gives an additional indicator of WSM activity, providing capability for both hardware signal of status (versus software polling) and status masking (interrupt masking for background erase, for example). Status polling using RY/BY# minimizes both CPU overhead and system power consumption. When low, RY/BY# indicates that the WSM is performing a block erase or byte write operation. RY/BY# high indicates that the WSM is ready for new commands, block erase is suspended or the device is in deep powerdown mode.

Maximum access time is **85** ns ( $t_{ACC}$ ) over the commercial temperature range (0°C to +70°C) and over V<sub>CC</sub> supply voltage range (4.5V to 5.5V and 4.75V to 5.25V). I<sub>CC</sub> active current (CMOS Read) is **20** mA typical, **35** mA maximum at **8** MHz.

When the CE# and RP# pins are at  $V_{CC}$ , the  $I_{CC}$  CMOS Standby mode is enabled.

A **Deep Powerdown** mode is enabled when the RP# pin is at GND, minimizing power consumption and providing write protection. I<sub>CC</sub> current in deep powerdown is 0.20  $\mu$ A typical. Reset time of 400 ns is required from RP# switching high until outputs are valid to read attempts. Equivalently, the device has a wake time of 1  $\mu$ s from RP# high until writes to the Command User Interface are recognized by the 28F008SA. With RP# at GND, the WSM is reset and the Status Register is cleared.





**Table 1. Pin Description** 

| Symbol                           | Туре         | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>19</sub>  | INPUT        | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                                           |
| DQ <sub>0</sub> -DQ <sub>7</sub> | INPUT/OUTPUT | DATA INPUT/OUTPUTS: Inputs data and commands during Command User Interface write cycles; outputs data during memory array, Status Register and Identifier read cycles. The data pins are active high and float to tri-state off when the chip is deselected or the outputs are disabled. Data is internally latched during a write cycle.                                                                             |
| CE#                              | INPUT        | CHIP ENABLE: Activates the device's control logic, input buffers, decoders, and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels.                                                                                                                                                                                                            |
| RP#                              | INPUT        | RESET/DEEP POWERDOWN: Puts the device in deep powerdown mode. RP# is active low; RP# high gates normal operation. RP# also locks out block erase or byte write operations when active low, providing data protection during power transitions. RP# active resets internal automation. Exit from Deep Powerdown sets device to read-array mode.                                                                        |
| OE#                              | INPUT        | <b>OUTPUT ENABLE:</b> Gates the device's outputs through the data buffers during a read cycle. OE# is active low.                                                                                                                                                                                                                                                                                                     |
| WE#                              | INPUT        | WRITE ENABLE: Controls writes to the Command User Interface and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                  |
| RY/BY#                           | OUTPUT       | READY/BUSY#: Indicates the status of the internal Write State Machine. When low, it indicates that the WSM is performing a block erase or byte write operation. RY/BY# high indicates that the WSM is ready for new commands, block erase is suspended or the device is in deep powerdown mode. RY/BY# is always active and does NOT float to tri-state off when the chip is deselected or data outputs are disabled. |
| V <sub>PP</sub>                  |              | BLOCK ERASE/BYTE WRITE POWER SUPPLY for erasing blocks of the array or writing bytes of each block.  NOTE:  With VPP < VPPLMAX, memory contents cannot be altered.                                                                                                                                                                                                                                                    |
| V <sub>CC</sub>                  |              | DEVICE POWER SUPPLY (5V $\pm$ 10%, 5V $\pm$ 5%)                                                                                                                                                                                                                                                                                                                                                                       |
| GND                              | ·            | GROUND                                                                                                                                                                                                                                                                                                                                                                                                                |





**Figure 2. TSOP Lead Configurations** 





Figure 3. TSOP Serpentine Layout

#### NOTE:

1. Connect all  $V_{CC}$  and GND pins of each device to common power supply outputs. DO NOT leave  $V_{CC}$  or GND inputs disconnected.





**Figure 4. PSOP Lead Configuration** 





Figure 5. 28F008SA Array Interface to Intel386SL Microprocessor Superset through PI Bus (Including RY/BY# Masking and Selective Powerdown), for DRAM Backup during System SUSPEND, Resident O/S and Applications and Motherboard Solid-State Disk.



#### PRINCIPLES OF OPERATION

The 28F008SA includes on-chip write automation to manage write and erase functions. The Write State Machine allows for: 100% TTL-level control inputs; fixed power supplies during block erasure and byte write; and minimal processor overhead with RAM-like interface timings.

After initial device powerup, or after return from deep powerdown mode (see Bus Operations), the 28F008SA functions as a read-only memory. Manipulation of external memory-control pins allow array read, standby and output disable operations. Both Status Register and intelligent identifiers can also be accessed through the Command User Interface when  $V_{\rm DP} = V_{\rm DDI}$ .

This same subset of operations is also available when high voltage is applied to the  $V_{PP}$  pin. In addition, high voltage on  $V_{PP}$  enables successful block erasure and byte writing of the device. All functions associated with altering memory contents—byte write, block erase, status and intelligent identifier—are accessed via the Command User Interface and verified thru the Status Register.

Commands are written using standard microprocessor write timings. Command User Interface contents serve as input to the WSM, which controls the block erase and byte write circuitry. Write cycles also internally latch addresses and data needed for byte write or block erase operations. With the appropriate command written to the register, standard microprocessor read timings output array data, access the intelligent identifier codes, or output byte write and block erase status for verification.

Interface software to initiate and poll progress of internal byte write and block erase can be stored in any of the 28F008SA blocks. This code is copied to, and executed from, system RAM during actual flash memory update. After successful completion of byte write and/or block erase, code/data reads from the 28F008SA are again possible via the Read Array command. Erase suspend/resume capability allows system software to suspend block erase to read data and execute code from any other block.

| FFFFF<br>F0000 | 64-Kbyte Block |
|----------------|----------------|
| EFFFF<br>E0000 | 64-Kbyte Block |
| DFFFF<br>D0000 | 64-Kbyte Block |
| CFFFF<br>C0000 | 64-Kbyte Block |
| BFFFF<br>B0000 | 64-Kbyte Block |
| AFFFF<br>A0000 | 64-Kbyte Block |
| 9FFFF<br>90000 | 64-Kbyte Block |
| 8FFFF<br>80000 | 64-Kbyte Block |
| 7FFFF<br>70000 | 64-Kbyte Block |
| 6FFFF<br>60000 | 64-Kbyte Block |
| 5FFFF<br>50000 | 64-Kbyte Block |
| 4FFFF<br>40000 | 64-Kbyte Block |
| 3FFFF<br>30000 | 64-Kbyte Block |
| 2FFFF 20000    | 64-Kbyte Block |
| 1FFFF<br>10000 | 64-Kbyte Block |
| 0FFFF<br>00000 | 64-Kbyte Block |

Figure 6. Memory Map

# Command User Interface and Write Automation

An on-chip state machine controls block erase and byte write, freeing the system processor for other tasks. After receiving the Erase Setup and Erase Confirm commands, the state machine controls block pre-conditioning and erase, returning progress via the Status Register and RY/BY# output. Byte write is similarly controlled, after destination address and expected data are supplied. The program and erase algorithms of past Intel flash memories are now regulated by the state machine, including pulse repetition where required and internal verification and margining of data.



#### **Data Protection**

Depending on the application, the system designer may choose to make the  $V_{PP}$  power supply switchable (available only when memory byte writes/block erases are required) or hardwired to  $V_{PPH}$ . When  $V_{PP} = V_{PPL}$ , memory contents cannot be altered. The 28F008SA Command User Interface architecture provides protection from unwanted byte write or block erase operations even when high voltage is applied to  $V_{PP}$ . Additionally, all functions are disabled whenever  $V_{CC}$  is below the write lockout voltage  $V_{LKO}$ , or when RP# is at  $V_{IL}$ . The 28F008SA accommodates either design practice and encourages optimization of the processor-memory interface.

The two-step byte write/block erase Command User Interface write sequence provides additional software write protection.

#### **BUS OPERATION**

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles.

#### Read

The 28F008SA has three read modes. The memory can be read from any of its blocks, and information can be read from the intelligent identifier or Status Register. Vpp can be at either VppL or VppH.

The first task is to write the appropriate read mode command to the Command User Interface (array, intelligent identifier, or Status Register). The 28F008SA automatically resets to Read Array mode upon initial device powerup or after exit from deep powerdown. The 28F008SA has four control pins, two of which must be logically active to obtain data at the outputs. Chip Enable (CE#) is the device selection control, and when active enables the selected memory device. Output Enable (OE#) is the data input/output (DQ0-DQ7) direction control, and when active drives data from the selected memory onto the I/O bus. RP# and WE# must also be at V<sub>IH</sub>. Figure 10 illustrates read bus cycle waveforms.

#### **Output Disable**

With OE# at a logic-high level ( $V_{IH}$ ), the device outputs are disabled. Output pins ( $DQ_0-DQ_7$ ) are placed in a high-impedance state.

### Standby

CE# at a logic-high level (V<sub>IH</sub>) places the 28F008SA in standby mode. Standby operation disables much of the 28F008SA's circuitry and substantially reduces device power consumption. The outputs (DQ0-DQ7) are placed in a high-impedence state independent of the status of OE#. If the 28F008SA is deselected during block erase or byte write, the device will continue functioning and consuming normal active power until the operation completes.

**Table 2. Bus Operations** 

| Mode                            | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>0</sub>  | Vpp | DQ <sub>0-7</sub> | RY/BY#          |
|---------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|-------------------|-----------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х   | D <sub>OUT</sub>  | Х               |
| Output Disable                  | 3       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | X   | High Z            | X               |
| Standby                         | 3       | V <sub>IH</sub> | V <sub>iH</sub> | Х               | Х               | Х               | Х   | High Z            | Х               |
| Deep PowerDown                  |         | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х   | High Z            | V <sub>OH</sub> |
| Intelligent Identifier (Mfr)    |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | X   | 89H               | V <sub>OH</sub> |
| Intelligent Identifier (Device) |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х   | A2H               | VoH             |
| Write                           | 3, 4, 5 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х   | D <sub>IN</sub>   | Х               |

#### **NOTES**

- 1. Refer to DC Characteristics. When V<sub>PP</sub> = V<sub>PPL</sub>, memory contents can be read but not written or erased.
- 2. X can be V<sub>IL</sub> or V<sub>IH</sub> for control pins and addresses, and V<sub>PPL</sub> or V<sub>PPH</sub> for V<sub>PP</sub>. See DC Characteristics for V<sub>PPL</sub> and V<sub>PPH</sub> voltages.
- 3. RY/BY# is V<sub>OL</sub> when the Write State Machine is executing internal block erase or byte write algorithms. It is V<sub>OH</sub> when the WSM is not busy, in Erase Suspend mode or deep powerdown mode.
- 4. Command writes involving block erase or byte write are only successfully executed when V<sub>PP</sub> = V<sub>PPH</sub>.
- 5. Refer to Table 3 for valid D<sub>IN</sub> during a write operation.



#### Deep Power-Down

The 28F008SA offers a deep power-down feature, entered when RP# is at  $V_{IL}.$  Current draw thru  $V_{CC}$  is 0.20  $\mu{\rm A}$  typical in deep power-down mode, with current draw through  $V_{PP}$  typically 0.1  $\mu{\rm A}.$  During read modes, RP#-low deselects the memory, places output drivers in a high-impedence state and turns off all internal circuits. The 28F008SA requires time  $t_{PHQV}$  (see AC Characteristics-Read-Only Operations) after return from powerdown until initial memory access outputs are valid. After this wakeup interval, normal operation is restored. The Command User Interface is reset to Read Array, and the upper 5 bits of the Status Register are cleared to value 10000, upon return to normal operation.

During block erase or byte write modes, RP# low will abort either operation. Memory contents of the block being altered are no longer valid as the data will be partially written or erased. Time  $t_{PHWL}$  after RP# goes to logic-high ( $V_{IH}$ ) is required before another command can be written.

This use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset it expects to read from the flash memory. Automated flash memories provide

status information when accessed during write/ erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input. In this application RP# is controlled by the same RESET# signal that resets the system CPU.

#### **Intelligent Identifier Operation**

The intelligent identifier operation outputs the manufacturer code, 89H; and the device code, A2H for the 28F008SA. The system CPU can then automatically match the device with its proper block erase and byte write algorithms.

The manufacturer- and device-codes are read via the Command User Interface. Following a write of 90H to the Command User Interface, a read from address location 00000H outputs the manufacturer code (89H). A read from address 00001H outputs the device code (A2H). It is not necessary to have high voltage applied to V<sub>PP</sub> to read the intelligent identifiers from the Command User Interface.

| Table: | 3. Comm | and De | finitions |
|--------|---------|--------|-----------|
|        |         |        |           |

| Table 6. Communications          |               |         |                 |         |      |                  |         |      |  |
|----------------------------------|---------------|---------|-----------------|---------|------|------------------|---------|------|--|
| Command                          | Bus<br>Cycles | Notes   | First Bus Cycle |         |      | Second Bus Cycle |         |      |  |
|                                  | Req'd         |         | Operation       | Address | Data | Operation        | Address | Data |  |
| Read Array/Reset                 | 1             | 1       | Write           | X       | FFH  |                  |         |      |  |
| Intelligent Identifier           | 3             | 2, 3, 4 | Write           | Х       | 90H  | Read             | IA ·    | IID  |  |
| Read Status Register             | 2             | 3       | Write           | . X     | 70H  | Read             | Х       | SRD  |  |
| Clear Status Register            | 1             |         | Write           | Х       | 50H  |                  |         |      |  |
| Erase Setup/Erase Confirm        | 2             | 2       | Write           | ВА      | 20H  | Write            | BA      | DOH  |  |
| Erase Suspend/Erase Resume       | 2             |         | Write           | Х       | вон  | Write            | Х       | DOH  |  |
| Byte Write Setup/Write           | 2             | 2, 3, 5 | Write           | WA      | 40H  | Write            | WA      | WD   |  |
| Alternate Byte Write Setup/Write | 2             | 2, 3, 5 | Write           | WA      | 10H  | Write            | WA      | WD   |  |

#### NOTES:

- 1. Bus operations are defined in Table 2.
- 2. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
  - BA = Address within the block being erased.
  - WA = Address of memory location to be written.
- 3. SRD = Data read from Status Register. See Table 4 for a description of the Status Register bits.
  - WD = Data to be written at location WA. Data is latched on the rising edge of WE#.
  - IID = Data read from Intelligent Identifiers.
- Following the Intelligent Identifier command, two read operations access manufacture and device codes.
- 5. Either 40H or 10H are recognized by the WSM as the Byte Write Setup command.
- 6. Commands other than those shown above are reserved by Intel for future device implementations and should not be used.



#### Write

Writes to the Command User Interface enable reading of device data and Intelligent Identifiers. They also control inspection and clearing of the Status Register. Additionally, when Vpp = VppH, the Command User Interface controls block erasure and byte write. The contents of the interface register serve as input to the internal state machine.

The Command User Interface itself does not occupy an addressable memory location. The interface register is a latch used to store the command and address and data information needed to execute the command. Erase Setup and Erase Confirm commands require both appropriate command data and an address within the block to be erased. The Byte Write Setup command requires both appropriate command data and the address of the location to be written, while the Byte Write command consists of the data to be written and the address of the location to be written.

The Command User Interface is written by bringing WE# to a logic-low level ( $V_{\rm IL}$ ) while CE# is low. Addresses and data are latched on the rising edge of WE#. Standard microprocessor write timings are used.

Refer to AC Write Characteristics and the AC Waveforms for Write Operations, Figure 11, for specific timing parameters.

#### **COMMAND DEFINITIONS**

When V<sub>PPL</sub> is applied to the V<sub>PP</sub> pin, read operations from the Status Register, intelligent identifiers, or array blocks are enabled. Placing V<sub>PPH</sub> on V<sub>PP</sub> enables successful byte write and block erase operations as well.

Device operations are selected by writing specific commands into the Command User Interface. Table 3 defines the 28F008SA commands.

#### **Read Array Command**

Upon initial device powerup and after exit from deep powerdown mode, the 28F008SA defaults to Read Array mode. This operation is also initiated by writing FFH into the Command User Interface. Microprocessor read cycles retrieve array data. The device remains enabled for reads until the Command User Interface contents are altered. Once the internal Write State Machine has started a block erase or byte write operation, the device will not recognize the Read Array command, until the WSM has completed its operation. The Read Array command is functional when  $\mbox{\sc Vpp} = \mbox{\sc VppH}.$ 

**Table 4. Status Register Definitions** 



SR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

SR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

SR.4 = BYTE WRITE STATUS

1 = Error in Byte Write

0 = Successful Byte Write

 $SR.3 = V_{PP} STATUS$ 

1 = V<sub>PP</sub> Low Detect; Operation Abort

 $0 = V_{PP} OK$ 

SR.2-SR.0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use and should be masked out when polling the Status Register.

#### NOTES:

RY/BY# or the Write State Machine Status bit must first be checked to determine byte write or block erase completion, before the Byte Write or Erase Status bit are checked for success.

If the Byte Write AND Erase Status bits are set to "1"s during a block erase attempt, an improper command sequence was entered. Attempt the operation again.

If  $V_{PP}$  low status is detected, the Status Register must be cleared before another byte write or block erase operation is attempted.

The  $V_{PP}$  Status bit, unlike an A/D converter, does not provide continuous indication of  $V_{PP}$  level. The WSM interrogates the  $V_{PP}$  level only after the byte write or block erase command sequences have been entered and informs the system if  $V_{PP}$  has not been switched on. The  $V_{PP}$  Status bit is not guaranteed to report accurate feedback between  $V_{PPI}$  and  $V_{PPH}$ .



#### Intelligent Identifier Command

The 28F008SA contains an Intelligent Identifier operation, initiated by writing 90H into the Command User Interface. Following the command write, a read cycle from address 00000H retrieves the manufacturer code of 89H. A read cycle from address 00001H returns the device code of A2H. To terminate the operation, it is necessary to write another valid command into the register. Like the Read Array command, the Intelligent Identifier command is functional when  $V_{PP} = V_{PPL}$  or  $V_{PPH}$ .

#### Read Status Register Command

The 28F008SA contains a Status Register which may be read to determine when a byte write or block erase operation is complete, and whether that operation completed successfully. The Status Register may be read at any time by writing the Read Status Register command (70H) to the Command User Interface. After writing this command, all subsequent read operations output data from the Status Register, until another valid command is written to the Command User Interface. The contents of the Status Register are latched on the falling edge of OE# or CE#, whichever occurs last in the read cycle. OE# or CE# must be toggled to VIH before further reads to update the Status Register latch. The Read Status Register command functions when  $V_{PP} = V_{PPI}$  or  $V_{PPH}$ .

### **Clear Status Register Command**

The Erase Status and Byte Write Status bits are set to "1"s by the Write State Machine and can only be reset by the Clear Status Register Command. These bits indicate various failure conditions (see Table 4). By allowing system software to control the resetting of these bits, several operations may be performed (such as cumulatively writing several bytes or erasing multiple blocks in sequence). The Status Register may then be polled to determine if an error occurred during that sequence. This adds flexibility to the way the device may be used.

Additionally, the  $V_{PP}$  Status bit (SR.3) MUST be reset by system software before further byte writes or block erases are attempted. To clear the Status Register, the Clear Status Register command (50H) is written to the Command User Interface. The Clear Status Register command is functional when  $V_{PP} = V_{PPI}$  or  $V_{PPH}$ .

## Erase Setup/Erase Confirm Commands

Erase is executed one block at a time, initiated by a two-cycle command sequence. An Erase Setup

command (20H) is first written to the Command User Interface, followed by the Erase Confirm command (D0H). These commands require both appropriate sequencing and an address within the block to be erased to FFH. Block preconditioning, erase and verify are all handled internally by the Write State Machine, invisible to the system. After the two-command erase sequence is written to it, the 28F008SA automatically outputs Status Register data when read (see Figure 8; Block Erase Flowchart). The CPU can detect the completion of the erase event by analyzing the output of the RY/BY# pin, or the WSM Status bit of the Status Register.

When erase is completed, the Erase Status bit should be checked. If erase error is detected, the Status Register should be cleared. The Command User Interface remains in Read Status Register mode until further commands are issued to it.

This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, reliable block erasure can only occur when  $V_{PP} = V_{PPH}.$  In the absence of this high voltage, memory contents are protected against erasure. If block erase is attempted while  $V_{PP} = V_{PPL},$  the  $V_{PP}$  Status bit will be set to "1". Erase attempts while  $V_{PPL} < V_{PP} < V_{PPH}$  produce spurious results and should not be attempted.

## **Erase Suspend/Erase Resume Commands**

The Erase Suspend command allows block erase interruption in order to read data from another block of memory. Once the erase process starts, writing the Erase Suspend command (B0H) to the Command User Interface requests that the WSM suspend the erase sequence at a predetermined point in the erase algorithm. The 28F008SA continues to output Status Register data when read, after the Erase Suspend command is written to it. Polling the WSM Status and Erase Suspend Status bits will determine when the erase operation has been suspended (both will be set to "1"). RY/BY# will also transition to VOH.

At this point, a Read Array command can be written to the Command User Interface to read data from blocks other than that which is suspended. The only other valid commands at this time are Read Status Register (70H) and Erase Resume (D0H), at which time the WSM will continue with the erase process. The Erase Suspend Status and WSM Status bits of the Status Register will be automatically cleared and RY/BY# will return to  $V_{OL}$ . After the Erase Resume command is written to it, the 28F008SA automatically outputs Status Register data when read (see Figure 9; Erase Suspend/Resume Flowchart). Vpp must remain at  $V_{PPH}$  while the 28F008SA is in Erase Suspend.



# Byte Write Setup/Write Commands (40H or 10H)

Byte write is executed by a two-command sequence. The Byte Write Setup command (40H or 10H) is written to the Command User Interface, followed by a second write specifying the address and data (latched on the rising edge of WE#) to be written. The WSM then takes over, controlling the byte write and write verify algorithms internally. After the two-command byte write sequence is written to it, the 28F008SA automatically outputs Status Register data when read (see Figure 7; Byte Write Flowchart). The CPU can detect the completion of the byte write event by analyzing the output of the RY/BY# pin, or the WSM Status bit of the Status Register. Only the Read Status Register command is valid while byte write is active.

When byte write is complete, the Byte Write Status bit should be checked. If byte write error is detected, the Status Register should be cleared. The internal WSM verify only detects errors for "1"s that do not successfully write to "0"s. The Command User Interface remains in Read Status Register mode until further commands are issued to it. If byte write is attempted while  $V_{PP} = V_{PPL}$ , the  $V_{PP}$  Status bit will be set to "1". Byte write attempts while  $V_{PPL} < V_{PP} < V_{PPH}$  produce spurious results and should not be attempted.

# EXTENDED BLOCK ERASE/BYTE WRITE CYCLING

Intel has designed extended cycling capability into its ETOX flash memory technologies. The 28F008SA is designed for 100,000 byte write/block erase cycles on each of the sixteen 64-Kbyte blocks. Low electric fields, advanced oxides and minimal oxide area per cell subjected to the tunneling electric field combine to greatly reduce oxide stress and the probability of failure. A 20-Mbyte solid-state drive using an array of 28F008SAs has a MTBF (Mean Time Between Failure) of 33.3 million hours(1), over 600 times more reliable than equivalent rotating disk technology.

#### **AUTOMATED BYTE WRITE**

The 28F008SA integrates the Quick-Pulse programming algorithm of prior Intel Flash devices on-chip, using the Command User Interface, Status Register and Write State Machine (WSM). On-chip integration dramatically simplifies system software and provides processor interface timings to the Command User Interface and Status Register. WSM operation, internal verify and V<sub>PP</sub> high voltage presence are monitored and reported via the RY/BY# output and appropriate Status Register bits. Figure 7 shows a

system software flowchart for device byte write. The entire sequence is performed with V<sub>PP</sub> at V<sub>PPH</sub>. Byte write abort occurs when RP# transitions to V<sub>IL</sub>, or V<sub>PP</sub> drops to V<sub>PPL</sub>. Although the WSM is halted, byte data is partially written at the location where byte write was aborted. Block erasure, or a repeat of byte write, is required to initialize this data to a known value.

#### **AUTOMATED BLOCK ERASE**

As above, the Quick-Erase algorithm of prior Intel Flash devices is now implemented internally, including all preconditioning of block data. WSM operation, erase success and V<sub>PP</sub> high voltage presence are monitored and reported through RY/BY# and the Status Register. Additionally, if a command other than Erase Confirm is written to the device following Erase Setup, both the Erase Status and Byte Write Status bits will be set to "1"s. When issuing the Erase Setup and Erase Confirm commands, they should be written to an address within the address range of the block to be erased. Figure 8 shows a system software flowchart for block erase.

Erase typically takes 1.6 seconds per block. The Erase Suspend/Erase Resume command sequence allows suspension of this erase operation to read data from a block other than that in which erase is being performed. A system software flowchart is shown in Figure 9.

The entire sequence is performed with V<sub>PP</sub> at V<sub>PPH</sub>. Abort occurs when RP# transitions to V<sub>IL</sub> or V<sub>PP</sub> falls to V<sub>PPL</sub>, while erase is in progress. Block data is partially erased by this operation, and a repeat of erase is required to obtain a fully erased block.

#### **DESIGN CONSIDERATIONS**

#### Three-Line Output Control

The 28F008SA will often be used in large memory arrays. Intel provides three control inputs to accommodate multiple memory connections. Three-line control provides for:

- a) lowest possible memory power dissipation
- complete assurance that data bus contention will not occur

To efficiently use these control inputs, an address decoder should enable CE#, while OE# should be connected to all memory devices and the system's READ# control line. This assures that only selected memory devices have active outputs while deselected memory devices are in Standby Mode. RP# should be connected to the system Powergood signal to prevent unintended writes during system power transitions. Powergood should also toggle during system reset.

(1)Assumptions: 10-Kbyte file written every 10 minutes. (20-Mbyte array)/(10-Kbyte file) = 2,000 file writes before erase required. (2000 files writes/erase) × (100,000 cycles per 28F008SA block) = 200 million file writes. (200 × 10<sup>6</sup> file writes) × (10 min/write) × (1 hr/60 min) = **33.3** × **10<sup>6</sup> MTBF**.



## RY/BY # and Byte Write/Block Erase Polling

RY/BY# is a full CMOS output that provides a hardware method of detecting byte write and block erase completion. It transitions low time t<sub>WHRL</sub> after a write or erase command sequence is written to the

28F008SA, and returns to  $V_{OH}$  when the WSM has finished executing the internal algorithm.

RY/BY# can be connected to the interrupt input of the system CPU or controller. It is active at all times, not tristated if the 28F008SA CE# or OE# inputs are brought to  $V_{IH}$ . RY/BY# is also  $V_{OH}$  when the device is in Erase Suspend or deep powerdown modes.



| Bus<br>Operation | Command             | Comments                                                                                                                                     |
|------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Write            | Byte Write<br>Setup | Data = 40H (10H)<br>Address = Byte to be written                                                                                             |
| Write            | Byte Write          | Data to be written<br>Address = Byte to be written                                                                                           |
| Standby/Read     | ·                   | Check RY/BY#  VOH = Ready, VOL = Busy or  Read Status Register  Check SR.7  1 = Ready, 0 = Busy  Toggle OE# or CE# to update Status Register |

Repeat for subsequent bytes

Full status check can be done after each byte or after a sequence of bytes

Write FFH after the last byte write operation to reset the device to Ready Array Mode

#### **FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                                                        |
|------------------|---------|---------------------------------------------------------------------------------|
| Optional<br>Read |         | CPU may already have read<br>Status Register data in WSM<br>Ready polling above |
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect                                    |
| Standby          |         | Check SR.4<br>1 = Byte Write Error                                              |

SR.3 MUST be cleared, if set during a byte write attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple bytes are written before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.





| Bus<br>Operation | Command        | Comments                                                                                                                                                            |
|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write            | Erase<br>Setup | Data = 20H<br>Address = Within block to be<br>erased                                                                                                                |
| Write            | Erase          | Data = D0H<br>Address = Within block to be<br>erased                                                                                                                |
| Standby/Read     |                | Check RY/BY #  V <sub>OH</sub> = Ready, V <sub>OL</sub> = Busy or  Read Status Register Check SR.7  1 = Ready, 0 = Busy Toggle OE# or CE# to update Status Register |

Repeat for subsequent bytes

Full status check can be done after each block or after a sequence of blocks

Write FFH after the last block erase operation to reset the device to Ready Array Mode

#### **FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                                                        |
|------------------|---------|---------------------------------------------------------------------------------|
| Optional<br>Read | ·       | CPU may already have read<br>Status Register data in WSM<br>Ready polling above |
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect                                    |
| Standby          |         | Check SR.4,5 Both 1 = Command Sequence Error                                    |
| Standby          |         | Check SR.5<br>1 = Block Erase Error                                             |

SR.3 MUST be cleared, if set during a block erase attempt, before further attempts are allowed by the Write State Machine

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 8. Automated Block Erase Flowchart





Figure 9. Erase Suspend/Resume Flowchart

## **Power Supply Decoupling**

Flash memory power switching characteristics require careful device decoupling. System designers are interested in 3 supply current issues; standby current levels (ISB), active current levels (ICC) and transient peaks produced by falling and rising edges of CE#. Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress transient voltage peaks. Each device should have a 0.1  $\mu F$  ceramic capacitor connected between each  $V_{\rm CC}$  and GND, and between its  $V_{\rm PP}$  and GND. These high frequency, low inherent-inductance capacitors should be placed as close as possible to package leads. Additionally, for

every 8 devices, a 4.7  $\mu$ F electrolytic capacitor should be placed at the array's power supply connection between V<sub>CC</sub> and GND. The bulk capacitor will overcome voltage slumps caused by PC board trace inductances.

### **VPP Trace on Printed Circuit Boards**

Writing flash memories, while they reside in the target system, requires that the printed circuit board designer pay attention to the V<sub>PP</sub> power supply trace. The V<sub>PP</sub> pin supplies the memory cell current for writing and erasing. Use similar trace widths and layout considerations given to the V<sub>CC</sub> power bus. Adequate V<sub>PP</sub> supply traces and decoupling will decrease V<sub>PP</sub> voltage spikes and overshoots.



# V<sub>CC</sub>, V<sub>PP</sub>, RP# Transitions and the Command/Status Registers

Byte write and block erase completion are not guaranteed if Vpp drops below VppH. If the Vpp Status bit of the Status Register (SR.3) is set to "1", a Clear Status Register command MUST be issued before further byte write/block erase attempts are allowed by the WSM. Otherwise, the Byte Write (SR.4) or Erase (SR.5) Status bits of the Status Register will be set to "1"s if error is detected. RP# transitions to V<sub>IL</sub> during byte write and block erase also abort the operations. Data is partially altered in either case, and the command sequence must be repeated after normal operation is restored. Device poweroff, or RP# transitions to V<sub>IL</sub>, clear the Status Register to initial value 10000 for the upper 5 bits.

The Command User Interface latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its state upon powerup, after exit from deep powerdown or after  $V_{CC}$  transitions below  $V_{LKO}$ , is Read Array Mode.

After byte write or block erase is complete, even after  $V_{PP}$  transitions down to  $V_{PPL}$ , the Command User Interface must be reset to Read Array mode via the Read Array command if access to the memory array is desired.

#### **Power Up/Down Protection**

The 28F008SA is designed to offer protection against accidental block erasure or byte writing during power transitions. Upon power-up, the 28F008SA is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers up first. Power supply sequencing is not required. Internal circuitry in the 28F008SA

ensures that the Command User Interface is reset to the Read Array mode on power up.

A system designer must guard against spurious writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either to  $V_{IH}$  will inhibit writes. The Command User Interface architecture provides an added level of protection since alteration of memory contents only occurs after successful completion of the two-step command sequences.

Finally, the device is disabled until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. This provides an additional level of memory protection.

### **Power Dissipation**

When designing portable systems, designers must consider battery power consumption not only during device operation, but also for data retention during system idle time. Flash nonvolatility increases usable battery life, because the 28F008SA does not consume any power to retain code or data when the system is off.

In addition, the 28F008SA's deep powerdown mode ensures extremely low power dissipation even when system power is applied. For example, portable PCs and other power sensitive applications, using an array of 28F008SAs for solid-state storage, can lower RP# to  $V_{\rm IL}$  in standby or sleep modes, producing negligable power consumption. If access to the 28F008SA is again needed, the part can again be read, following the  $t_{\rm PHQV}$  and  $t_{\rm FHWL}$  wakeup cycles required after RP# is first raised back to  $V_{\rm IH}$ . See AC Characteristics—Read-Only and Write Operations and Figures 10 and 11 for more information.



#### **ABSOLUTE MAXIMUM RATINGS\***

 NOTICE: This data sheet contains preliminary information on new products in production. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC} + 0.5$ V which, during transitions, may overshoot to  $V_{CC} + 2.0$ V for periods <20 ns.
- 3. Maximum DC voltage on V<sub>PP</sub> may overshoot to +14.0V for periods <20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. 5% V<sub>CC</sub> specifications reference the 28F008SA-85 in its High Speed configuration. 10% V<sub>CC</sub> specifications reference the 28F008SA-85 in its Standard configuration, and the 28F008SA-120.

#### **OPERATING CONDITIONS**

| Symbol          | Parameter                            | Notes | Min  | Max  | Unit |
|-----------------|--------------------------------------|-------|------|------|------|
| TA              | Operating Temperature                |       | 0    | 70   | ů    |
| Vcc             | V <sub>CC</sub> Supply Voltage (10%) | 5     | 4.50 | 5.50 | ٧    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (5%)  | 5     | 4.75 | 5.25 | ٧    |

#### DC CHARACTERISTICS

| Symbol           | Parameter                                 | Notes | Min | Тур  | Max  | Unit | Test Condition                                                                    |
|------------------|-------------------------------------------|-------|-----|------|------|------|-----------------------------------------------------------------------------------|
| ILI              | Input Load Current                        | 1     |     |      | ±1.0 | μА   | $V_{CC} = V_{CC} Max$ $V_{IN} = V_{CC} or GND$                                    |
| I <sub>LO</sub>  | Output Leakage Current                    | 1     |     |      | ±10  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                |
| Iccs             | V <sub>CC</sub> Standby Current           | 1,3   |     | 1.0  | 2.0  | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = RP# = V <sub>IH</sub>              |
|                  |                                           |       |     | 30   | 100  | μА   | $V_{CC} = V_{CC} Max$ $CE \# = RP \# = V_{CC} \pm 0.2V$                           |
| ICCD             | V <sub>CC</sub> Deep PowerDown<br>Current | 1     |     | 0.20 | 1.2  | μΑ   | $RP\# = GND \pm 0.2V$ $I_{OUT}(RY/BY\#) = 0 \text{ mA}$                           |
| I <sub>CCR</sub> | V <sub>CC</sub> Read Current              | 1     | ı   | 20   | 35   | mA   | $V_{CC} = V_{CC}$ Max, CE# = GND f = 8 MHz, $I_{OUT}$ = 0 mA CMOS Inputs          |
|                  |                                           |       |     | , 25 | 50   | mA - | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$<br>$f=8$ MHz, $I_{OUT}=0$ mA<br>TTL Inputs |



## DC CHARACTERISTICS (Continued)

| Symbol            | Parameter                                        | Notes | Min                   | Тур  | Max                   | Unit | Test Condition                                               |  |
|-------------------|--------------------------------------------------|-------|-----------------------|------|-----------------------|------|--------------------------------------------------------------|--|
| lccw              | V <sub>CC</sub> Byte Write Current               | 1     |                       | 10   | 30                    | mĄ   | Byte Write In Progress                                       |  |
| ICCE              | V <sub>CC</sub> Block Erase Current              | 1     | •                     | 10   | 30                    | mΑ   | Block Erase In Progress                                      |  |
| ICCES             | V <sub>CC</sub> Erase Suspend Current            | 1, 2  |                       | 5    | 10                    | mA   | Block Erase Suspended<br>CE# = V <sub>IH</sub>               |  |
| IPPS              | V <sub>PP</sub> Standby Current                  | 1     | Ź                     | ±1   | ±15                   | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                            |  |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep PowerDown<br>Current        | . 1   |                       | 0.10 | 5.0                   | μΑ   | RP# = GND ±0.2V                                              |  |
| IPPR              | V <sub>PP</sub> Read Current                     |       |                       |      | 200                   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                            |  |
| I <sub>PPW</sub>  | V <sub>PP</sub> Byte Write Current               | 1     |                       | 10   | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress |  |
| IPPE              | V <sub>PP</sub> Block Erase Current              | 1     |                       | 10   | 30                    | mA   | $V_{PP} = V_{PPH}$<br>Block Erase in Progress                |  |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend<br>Current         | 1     |                       | 90   | 200                   | μΑ   | $V_{PP} = V_{PPH}$<br>Block Erase Suspended                  |  |
| V <sub>IL</sub>   | Input Low Voltage                                |       | -0.5                  |      | 0.8                   | >    |                                                              |  |
| V <sub>IH</sub>   | Input High Voltage                               |       | 2.0                   |      | V <sub>CC</sub> + 0.5 | >    |                                                              |  |
| V <sub>OL</sub>   | Output Low Voltage                               | 3     |                       |      | 0.45                  | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                      |  |
| V <sub>OH1</sub>  | Output High Voltage (TTL)                        | 3     | 2.4                   |      |                       | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                     |  |
| V <sub>OH2</sub>  | Output High Voltage<br>(CMOS)                    |       | 0.85 V <sub>CC</sub>  |      |                       | ٧    | $I_{OH} = -2.5 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$     |  |
| Í                 |                                                  |       | V <sub>CC</sub> - 0.4 |      |                       |      | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$     |  |
| V <sub>PPL</sub>  | V <sub>PP</sub> during Normal<br>Operations      | 4     | 0.0                   |      | 6.5                   | ٧    |                                                              |  |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Erase/Write<br>Operations |       | 11.4                  | 12.0 | 12.6                  | ٧.,  |                                                              |  |
| V <sub>LKO</sub>  | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.0                   |      |                       | ٧    |                                                              |  |



## **EXTENDED TEMPERATURE OPERATING CONDITIONS**

| Symbol          | Parameter                            | Notes | Min  | Max  | Unit |
|-----------------|--------------------------------------|-------|------|------|------|
| T <sub>A</sub>  | Operating Temperature                |       | -40  | +85  | ô    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (10%) | 5     | 4.50 | 5.50 | ٧    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (5%)  | 5     | 4.75 | 5.25 | ٧    |

## DC CHARACTERISTICS: EXTENDED TEMPERATURE OPERATION

| Symbol            | Parameter                                 | Notes | Min | Тур  | Max  | Unit | Test Condition                                                                        |
|-------------------|-------------------------------------------|-------|-----|------|------|------|---------------------------------------------------------------------------------------|
| ILI               | Input Load Current                        | 1     |     |      | ±1.0 | μА   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                     |
| lo                | Output Leakage Current                    | 1     |     |      | ± 10 | μА   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                    |
| Iccs              | V <sub>CC</sub> Standby Current           | 1, 3  |     | 1.0  | 2.0  | mA   | $V_{CC} = V_{CC} Max$<br>$CE\# = RP\# = V_{IH}$                                       |
|                   |                                           |       |     | 30   | 100  | μΑ   | $V_{CC} = V_{CC} Max$<br>$CE\# = RP\# = V_{CC} \pm 0.2V$                              |
| ICCD              | V <sub>CC</sub> Deep PowerDown<br>Current | 1     |     | 0.20 | 20   | μΑ   | $RP\# = GND \pm 0.2V$ $I_{OUT}(RY/BY\#) = 0 \text{ mA}$                               |
| ICCR              | V <sub>CC</sub> Read Current              | 1     |     | 20   | 35   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>$f = 8$ MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs   |
|                   |                                           |       |     | 25   | 50   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$<br>$f = 8$ MHz, $I_{OUT} = 0$ mA<br>TTL Inputs |
| Iccw              | V <sub>CC</sub> Byte Write Current        | 1     |     | 10   | 30   | mA   | Byte Write In Progress                                                                |
| ICCE              | V <sub>CC</sub> Block Erase Current       | 1     |     | 10   | 30   | mA   | Block Erase In Progress                                                               |
| ICCES             | V <sub>CC</sub> Erase Suspend Current     | 1, 2  |     | 5    | 10   | mA   | Block Erase Suspended<br>CE# = V <sub>IH</sub>                                        |
| IPPS              | V <sub>PP</sub> Standby Current           | 1     |     | ±1   | ±15  | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                     |
| IPPD              | V <sub>PP</sub> Deep PowerDown<br>Current | 1     |     | 0.10 | 5.0  | μΑ   | RP# = GND ±0.2V                                                                       |
| IPPR              | V <sub>PP</sub> Read Current              |       |     |      | 200  | μΑ   | $V_{PP} > V_{CC}$                                                                     |
| I <sub>PPW</sub>  | V <sub>PP</sub> Byte Write Current        | 1     | -   | 10   | 30   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                          |
| IPPE              | V <sub>PP</sub> Block Erase Current       | 1     |     | 10   | 30   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                         |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend<br>Current  | 1     |     | 90   | 200  | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                           |



## DC CHARACTERISTICS: EXTENDED TEMPERATURE OPERATION (Continued)

| Symbol             | Parameter                                        | Notes | Min                   | Тур  | Max                   | Unit     | Test Condition                                           |
|--------------------|--------------------------------------------------|-------|-----------------------|------|-----------------------|----------|----------------------------------------------------------|
| V <sub>IL</sub>    | Input Low Voltage                                |       | -0.5                  |      | 0.8                   | . V      | ·                                                        |
| V <sub>IH</sub>    | Input High Voltage                               |       | 2.0                   |      | V <sub>CC</sub> + 0.5 | . V      |                                                          |
| V <sub>OL</sub>    | Output Low Voltage                               | 3     | ,                     |      | 0.45                  | >        | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                  |
| V <sub>OH1</sub>   | Output High Voltage<br>(TTL)                     | 3     | 2.4                   |      | /                     | <b>V</b> | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                 |
| V <sub>OH2</sub>   | Output High Voltage<br>(CMOS)                    | -     | 0.85 V <sub>CC</sub>  |      |                       | >        | $I_{OH} = -2.5 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$ |
|                    |                                                  |       | V <sub>CC</sub> - 0.4 |      |                       |          | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$ |
| V <sub>PPL</sub>   | V <sub>PP</sub> during Normal<br>Operations      | 4     | 0.0                   |      | 6.5                   | ٧        |                                                          |
| V <sub>PPH</sub>   | V <sub>PP</sub> during Erase/Write<br>Operations |       | 11.4                  | 12.0 | 12.6                  | <b>V</b> |                                                          |
| V <sub>LKO</sub> . | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.0                   |      |                       | ٧        |                                                          |

## CAPACITANCE(5) T<sub>A</sub> = 25°C, f = 1 MHz

| Symbol          | Parameter          | Тур | Max | Unit | Condition             |
|-----------------|--------------------|-----|-----|------|-----------------------|
| C <sub>IN</sub> | Input Capacitance  | 6   | 8   | pF   | $V_{IN} = 0V$         |
| Cout            | Output Capacitance | 8   | 12  | pF   | V <sub>OUT</sub> = 0V |

#### NOTES:

1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).

2. I<sub>CCES</sub> is specified with the device deselected. If the 28F008SA is read while in Erase Suspend Mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCE</sub>.

3. Includes RY/BY#.

4. Block Erases/Byte Writes are inhibited when Vpp = VppL and not guaranteed in the range between VppH and VppL.

5. Sampled, not 100% tested.



#### AC INPUT/OUTPUT REFERENCE WAVEFORM(1)



### AC TESTING LOAD CIRCUIT(1)



## HIGH SPEED AC INPUT/OUTPUT REFERENCE WAVEFORM(2)



## HIGH SPEED AC TESTING LOAD CIRCUIT(2)



#### NOTES:

- 1. Testing characteristics for 28F008SA-85 in Standard configuration, and 28F008SA-120.
- 2. Testing characteristics for 28F008SA-85 in High Speed configuration.

## AC CHARACTERISTICS—Read-Only Operations(1)

|                   | ,                | /ersions                                                            | Vcc                   | ±5%   | 28F008 | SA-85 <sup>(4)</sup> |                |     |         |                      |      |
|-------------------|------------------|---------------------------------------------------------------------|-----------------------|-------|--------|----------------------|----------------|-----|---------|----------------------|------|
|                   |                  | vereiene                                                            | V <sub>CC</sub> ± 10% |       |        |                      | 28F008SA-85(5) |     | 28F0085 | A-120 <sup>(5)</sup> | Unit |
| Sym               | bol              | Parameter                                                           |                       | Notes | Min    | Max                  | Min            | Max | Min     | Max                  |      |
| tavav             | t <sub>RC</sub>  | Read Cycle Time                                                     |                       |       | 85     |                      | 90             |     | 120     |                      | ns   |
| tAVQV             | tACC             | Address to Output Delay                                             | ,                     |       |        | 85                   |                | 90  |         | 120                  | ns   |
| tELQV             | tCE              | CE# to Output Delay                                                 |                       | 2     |        | 85                   |                | 90  |         | 120                  | ns   |
| t <sub>PHQV</sub> | t <sub>PWH</sub> | RP# High to Output Del                                              | ay                    |       |        | 400                  |                | 400 |         | 400                  | ns   |
| tGLQV             | toE              | OE# to Output Delay                                                 |                       | 2     | -      | 40                   |                | 45  |         | 50                   | ns   |
| tELQX             | t <sub>LZ</sub>  | CE# to Output Low Z                                                 |                       | 3     | 0      |                      | 0              |     | 0       |                      | ns   |
| t <sub>EHQZ</sub> | t <sub>HZ</sub>  | CE# High to Output Hig                                              | hΖ                    | 3     |        | 55                   |                | 55  |         | 55                   | ns   |
| tGLQX             | toLZ             | OE# to Output Low Z                                                 |                       | 3     | 0      |                      | 0              |     | 0       |                      | ns   |
| tGHQZ             | t <sub>DF</sub>  | OE# High to Output Hig                                              | ıh Z                  | 3     |        | 30                   |                | 30  |         | 30                   | ns   |
|                   | · toн            | Output Hold from<br>Addresses, CE# or OE;<br>Change, Whichever is F | - 1                   | 3     | 0      |                      | 0              |     | 0       |                      | ns   |

- See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.
- 4. See High Speed AC Input/Output Reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 5. See AC Input/Output Reference Waveforms and AC Testing Load Circuits for testing characteristics.



## EXTENDED TEMPERATURE OPERATION AC CHARACTERISTICS—Read-Only Operations(1)

|                   |                  | Versions                                                          | Vcc  | ± 10% | 28F008 | SA-100 <sup>(5)</sup> | l l mid |  |
|-------------------|------------------|-------------------------------------------------------------------|------|-------|--------|-----------------------|---------|--|
| Sym               | bol              | Parameter                                                         | Note |       | Min    | Max                   | Unit    |  |
| t <sub>AVAV</sub> | t <sub>RC</sub>  | Read Cycle Time                                                   |      |       | 100    |                       | ns      |  |
| tavqv             | t <sub>ACC</sub> | Address to Output Delay                                           |      |       |        | 100                   | ns      |  |
| tELQV             | t <sub>CE</sub>  | CE# to Output Delay                                               |      | 2     |        | 100                   | ns      |  |
| t <sub>PHQV</sub> | tpWH             | RP# High to Output Delay                                          |      |       |        | 400                   | ns      |  |
| tGLQV             | toE              | OE# to Output Delay                                               |      | 2     |        | 55                    | ns      |  |
| tELQX             | t <sub>LZ</sub>  | CE# to Output Low Z                                               |      | 3     | 0      |                       | ns      |  |
| tEHQZ             | t <sub>HZ</sub>  | CE# High to Output High Z                                         |      | 3     |        | 55                    | ns      |  |
| t <sub>GLQX</sub> | toLz             | OE# to Output Low Z                                               |      | 3     | 0      |                       | ns      |  |
| tGHQZ             | t <sub>DF</sub>  | OE# High to Output High Z                                         | 1    | 3     | 1      | 30                    | ns      |  |
|                   | t <sub>OH</sub>  | Output Hold from Addresses, CE# or OE# Change, Whichever is First |      | 3     | 0      |                       | ns      |  |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to  $t_{CE}-t_{OE}$  after the falling edge of CE# without impact on  $t_{CE}$ .
- 3. Sampled, not 100% tested.
- 4. See High Speed AC Input/Output Reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 5. See AC Input/Output Reference Waveforms and AC Testing Load Circuits for testing characteristics.

3-467





## AC CHARACTERISTICS—Write Operations(1)

|                    | Ve                | ersions                                          | Vc      | C±5%  | 28F008 | SA-85 <sup>(7)</sup> |        |                      |         |                       |      |
|--------------------|-------------------|--------------------------------------------------|---------|-------|--------|----------------------|--------|----------------------|---------|-----------------------|------|
|                    | •                 | 51 310113                                        | Vcc     | ± 10% |        |                      | 28F008 | SA-85 <sup>(8)</sup> | 28F0085 | SA-120 <sup>(8)</sup> | Unit |
| Syml               | ool               | Parameter                                        |         | Notes | Min    | Max                  | Min    | Max                  | Min     | Max                   |      |
| t <sub>AVAV</sub>  | twc               | Write Cycle Time                                 |         | ,     | 85     |                      | 90     |                      | 120     | -                     | ns   |
| t <sub>PHWL</sub>  | t <sub>PS</sub>   | RP# High Recovery to WE# Going Low               | 0 .     | 2     | 1      |                      | 1      |                      | 1       |                       | μS   |
| t <sub>ELWL</sub>  | tcs               | CE# Setup to WE# G                               | oing    |       | 10     |                      | 10     |                      | 10      |                       | ns   |
| t <sub>WLWH</sub>  | t <sub>WP</sub>   | WE# Pulse Width                                  |         |       | 40     |                      | 40     |                      | 40      |                       | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub>  | V <sub>PP</sub> Setup to WE# Go                  | oing    | 2     | 100    |                      | 100    |                      | 100     |                       | ns   |
| t <sub>AVWH</sub>  | t <sub>AS</sub>   | Address Setup to WE<br>Going High                | #       | 3     | 40     |                      | 40     | ,                    | 40      |                       | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>   | Data Setup to WE# G                              | ioing   | 4     | 40     |                      | 40     |                      | 40      |                       | ns   |
| t <sub>WHDX</sub>  | t <sub>DH</sub>   | Data Hold from WE#                               | High    |       | 5      |                      | 5      |                      | 5       |                       | ns   |
| t <sub>WHAX</sub>  | t <sub>AH</sub>   | Address Hold from W                              | E#      |       | 5      |                      | 5      |                      | 5       |                       | ns   |
| twheh              | t <sub>CH</sub> . | CE# Hold from WE#                                | High    |       | 10     |                      | 10     |                      | 10      |                       | ns   |
| twHWL              | twpH              | WE# Pulse Width Hig                              | ıh      |       | 30     |                      | 30     |                      | 30      |                       | ns   |
| t <sub>WHRL</sub>  |                   | WE# High to RY/BY<br>Going Low                   | #       | :     |        | 100                  |        | 100                  |         | 100                   | ns   |
| t <sub>WHQV1</sub> |                   | Duration of Byte Write<br>Operation              | ) · · · | 5, 6  | 6      |                      | 6      |                      | 6       |                       | μs   |
| t <sub>WHQV2</sub> |                   | Duration of Block Eras                           | se      | 5, 6  | 0.3    |                      | 0.3    |                      | 0.3     |                       | sec  |
| t <sub>WHGL</sub>  |                   | Write Recovery before                            | е       |       | 0      |                      | 0      |                      | 0       |                       | μs   |
| t <sub>QVVL</sub>  | t∨PH              | V <sub>PP</sub> Hold from Valid S<br>RY/BY# High | RD,     | 2, 6  | 0      | -                    | 0      |                      | 0       |                       | ns   |

- 1. Read timing characteristics during erase and byte write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid AIN for byte write or block erasure.
- 4. Refer to Table 3 for valid  $D_{\mbox{\scriptsize IN}}$  for byte write or block erasure.
- 5. The on-chip Write State Machine incorporates all byte write and block erase system functions and overhead of standard Intel flash memory, including byte program and verify (byte write) and block precondition, precondition verify, erase and erase verify (block erase).
- 6. Byte write and block erase durations are measured to completion (SR.7 = 1, RY/BY# =  $V_{OH}$ ).  $V_{PP}$  should be held at  $V_{PPH}$  until determination of byte write/block erase success (SR.3/4/5 = 0)
- 7. See High Speed AC Input/Output Reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 8. See AC Input/Output Reference Waveforms and AC Testing Load Circuits for testing characteristics.



### **BLOCK ERASE AND BYTE WRITE PERFORMANCE**

| Parameter        | Notes |     | 28F008S | A-85     | 2   | Unit   |          |      |
|------------------|-------|-----|---------|----------|-----|--------|----------|------|
| Parameter        | Notes | Min | Typ(1)  | Max      | Min | Typ(1) | Max      | Unit |
| Block Erase Time | 2     |     | 1.6     | 10       |     | 1.6    | 10       | sec  |
| Block Write Time | 2     |     | 0.6     | 2.1      |     | 0.6    | 2.1      | sec  |
| Byte Write Time  |       |     | 8       | (Note 3) |     | 8      | (Note 3) | μs   |

#### NOTES:

- 1. 25°C, 12.0 Vpp.
- 2. Excludes System-Level Overhead.
- 3. Contact your Intel representative for information on the maximum byte write specification.

## EXTENDED TEMPERATURE OPERATION AC CHARACTERISTICS—Write Operations(1)

|                    |                  | Versions                                         | Vcc | ± 10% | 28F008 | SA-100 <sup>(8)</sup> | T    |
|--------------------|------------------|--------------------------------------------------|-----|-------|--------|-----------------------|------|
| Sym                | bol              | Parameter                                        |     | Notes | Min    | Max                   | Unit |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                                 |     |       | 100    |                       | ns   |
| t <sub>PHWL</sub>  | t <sub>PS</sub>  | RP# High Recovery to WE# Going Low               |     | 2     | 1      |                       | μs   |
| tELWL              | t <sub>CS</sub>  | CE# Setup to WE# Going Low                       |     |       | 10     |                       | ns   |
| twLwH              | t <sub>WP</sub>  | WE# Pulse Width                                  |     |       | 40     |                       | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE# Going High          |     | 2     | 100    |                       | ns   |
| tavwh              | t <sub>AS</sub>  | Address Setup to WE# Going High                  |     | 3     | 40     |                       | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to WE# Going High                     |     | 4     | 40     |                       | ns   |
| twHDX              | t <sub>DH</sub>  | Data Hold from WE# High                          |     |       | 5      | ,                     | ns   |
| twhax              | t <sub>AH</sub>  | Address Hold from WE# High                       |     |       | 5      |                       | ns   |
| twheh              | t <sub>CH</sub>  | CE# Hold from WE# High                           |     |       | 10     |                       | ns   |
| twhwL              | t <sub>WPH</sub> | WE# Pulse Width High                             |     |       | 30     |                       | ns   |
| twhal              |                  | WE# High to RY/BY# Going Low                     |     |       |        | 100                   | ns   |
| t <sub>WHQV1</sub> |                  | Duration of Byte Write Operation                 |     | 5, 6  | 6      |                       | μs   |
| t <sub>WHQV2</sub> |                  | Duration of Block Erase Operation                |     | 5, 6  | 0.3    |                       | sec  |
| twHGL              |                  | Write Recovery before Read                       |     |       | Ó      |                       | μs   |
| tQVVL              | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD, RY/BY# High |     | 2, 6  | 0      | `                     | ns   |

- 1. Read timing characteristics during erase and byte write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid AIN for byte write or block erasure.
- 4. Refer to Table 3 for valid DIN for byte write or block erasure.
- 5. The on-chip Write State Machine incorporates all byte write and block erase system functions and overhead of standard Intel flash memory, including byte program and verify (byte write) and block precondition, precondition verify, erase and erase verify (block erase).
- 6. Byte write and block erase durations are measured to completion (SR.7 = 1, RY/BY# =  $V_{OH}$ ).  $V_{PP}$  should be held at  $V_{PPH}$  until determination of byte write/block erase success (SR.3/4/5 = 0)
- 7. See High Speed AC Input/Output Reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics
- 8. See AC Input/Output Reference Waveforms and AC Testing Load Circuits for testing characteristics.



# EXTENDED TEMPERATURE OPERATION BLOCK ERASE AND BYTE WRITE PERFORMANCE

| <b>D</b>         | Notes | 2   | 28F008S/ | A-100    |      |
|------------------|-------|-----|----------|----------|------|
| Parameter        | Notes | Min | Typ(1)   | Max      | Unit |
| Block Erase Time | 2     |     | 1.6      | 10       | sec  |
| Block Write Time | 2     |     | 0.6      | 2.1      | sec  |
| Byte Write Time  |       |     | 8        | (Note 3) | μs   |

- NOTES: 1. 25°C, 12.0 Vpp. 2. Excludes System-Level Overhead.
- 3. Contact your Intel representative for information on the maximum byte write specification.





### **ALTERNATIVE CE#-CONTROLLED WRITES**

|                    | v                | /ersions                                          | Vc                                      | C±5%  | 28F008 | SA-85 <sup>(6)</sup> |        |                      |        |                       |      |
|--------------------|------------------|---------------------------------------------------|-----------------------------------------|-------|--------|----------------------|--------|----------------------|--------|-----------------------|------|
|                    |                  | CISIOIIS                                          | Vcc                                     | ± 10% | 100    |                      | 28F008 | SA-85 <sup>(7)</sup> | 28F008 | SA-120 <sup>(7)</sup> | Unit |
| Sym                | bol              | Parameter                                         | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | Notes | Min    | Max                  | Min    | Max                  | Min    | Max                   |      |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                                  |                                         |       | 85     |                      | 90     |                      | 120    |                       | ns   |
| t <sub>PHEL</sub>  | t <sub>PS</sub>  | RP# High Recovery to CE# Going Low                |                                         | 2     | 1      |                      | 1      |                      | 1      |                       | μs   |
| t <sub>WLEL</sub>  | tws              | WE# Setup to CE# Go<br>Low                        | oing                                    |       | 0      |                      | 0      |                      | 0      |                       | ns   |
| t <sub>ELEH</sub>  | t <sub>CP</sub>  | CE# Pulse Width                                   |                                         |       | 50     |                      | 50     |                      | 50     |                       | ns   |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE# Goil<br>High         | ng                                      | 2     | 100    |                      | 100    |                      | 100    |                       | ns   |
| <sup>t</sup> AVEH  | tas              | Address Setup to CE#<br>Going High                |                                         | 3     | 40     |                      | 40     |                      | 40     |                       | ns   |
| <sup>t</sup> DVEH  | t <sub>DS</sub>  | Data Setup to CE# Go<br>High                      | ing                                     | 4     | · 40   |                      | 40     |                      | 40     |                       | ns   |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from CE# H                              | igh                                     |       | 5      |                      | 5      |                      | 5      |                       | ns   |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold from CE<br>High                      | #                                       |       | 5      |                      | 5      |                      | 5      |                       | ns   |
| t <sub>EHWH</sub>  | t <sub>WH</sub>  | WE# Hold from CE# H                               | ligh                                    |       | 0      |                      | 0      |                      | 0      |                       | ns   |
| tEHEL              | t <sub>EPH</sub> | CE# Pulse Width High                              |                                         |       | 25     |                      | 25     |                      | 25     |                       | ns   |
| t <sub>EHRL</sub>  |                  | CE# High to RY/BY#<br>Going Low                   |                                         |       |        | 100                  |        | 100                  |        | 100                   | ns   |
| t <sub>EHQV1</sub> |                  | Duration of Byte Write<br>Operation               |                                         | 5     | 6      |                      | 6      |                      | 6      |                       | μs   |
| t <sub>EHQV2</sub> |                  | Duration of Block Erase<br>Operation              | •                                       | 5     | 0.3    |                      | 0.3    |                      | 0.3    |                       | sec  |
| t <sub>EHGL</sub>  |                  | Write Recovery before<br>Read                     | -                                       |       | 0      |                      | 0      |                      | 0      |                       | μs   |
| tavvl              | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SF<br>RY/BY# High | RD,                                     | 2, 5  | 0      |                      | 0      |                      | 0      |                       | ns   |

- 1. Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE#. In systems where CE# defines the write pulsewidth (within a longer WE# timing waveform), all setup, hold and inactive WE# times should be measured relative to the CE# waveform.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid AIN for byte write or block erasure.
- 4. Refer to Table 3 for valid D<sub>IN</sub> for byte write or block erasure.
- 5. Byte write and block erase durations are measured to completion (SR.7 = 1, RY/BY# =  $V_{OH}$ ).  $V_{PP}$  should be held at  $V_{PPH}$  until determination of byte write/block erase success (SR.3/4/5 = 0)
- 6. See High Speed AC Input/Output Reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 7. See AC Input/Output Reference Waveforms and AC Testing Load Circuits for testing characteristics.



## EXTENDED TEMPERATURE OPERATION ALTERNATIVE CE#-CONTROLLED WRITES

|                    |                  | Versions                                         | V <sub>CC</sub> ±10% | 28F008 | SA-100 <sup>(7)</sup> |      |
|--------------------|------------------|--------------------------------------------------|----------------------|--------|-----------------------|------|
| Sym                | bol              | Parameter                                        | Notes                | Min    | Max                   | Unit |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                                 |                      | 100    |                       | ns   |
| t <sub>PHEL</sub>  | t <sub>PS</sub>  | RP# High Recovery to CE# Going Low               | 2                    | 1      |                       | μs   |
| t <sub>WLEL</sub>  | tws              | WE# Setup to CE# Going Low                       |                      | 0      |                       | ns   |
| tELEH              | t <sub>CP</sub>  | CE# Pulse Width                                  |                      | 50     |                       | ns   |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE# Going High          | 2                    | 100    |                       | ns   |
| tAVEH              | t <sub>AS</sub>  | Address Setup to CE# Going High                  | 3                    | 40     |                       | ns   |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to CE# Going High                     | 4                    | 40     |                       | ns   |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from CE# High                          |                      | 5      |                       | ns   |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold from CE# High                       |                      | 5      |                       | ns   |
| tEHWH              | twH              | WE# Hold from CE# High                           |                      | 0      |                       | ns   |
| tEHEL              | t <sub>EPH</sub> | CE# Pulse Width High                             |                      | 25     |                       | ns   |
| tEHRL              |                  | CE# High to RY/BY# Going Low                     |                      |        | 100                   | ns   |
| t <sub>EHQV1</sub> |                  | Duration of Byte Write Operation                 | 5                    | 6      |                       | μs   |
| t <sub>EHQV2</sub> |                  | Duration of Block Erase Operation                | 5                    | 0.3    |                       | sec  |
| tEHGL              |                  | Write Recovery before Read                       |                      | 0      |                       | μs   |
| tQVVL              | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD, RY/BY# High | 2, 5                 | 0      |                       | ns   |

- 1. Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE#. In systems where CE# defines the write pulsewidth (within a longer WE# timing waveform), all setup, hold and inactive WE# times should be measured relative to the CE# waveform.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid AIN for byte write or block erasure.
- 4. Refer to Table 3 for valid DIN for byte write or block erasure.
- 5. Byte write and block erase durations are measured to completion (SR.7 = 1, RY/BY # =  $V_{OH}$ ).  $V_{PP}$  should be held at  $V_{PPH}$  until determination of byte write/block erase success (SR.3/4/5 = 0)
- 6. See High Speed AC Input/Output Reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 7. See AC Input/Output Reference Waveforms and AC Testing Load Circuits for testing characteristics.

WRITE READ ARRAY

COMMAND

READ STATUS

REGISTER DATA

OR ERASE DELAY

ADDRESSES (A)



t<sub>EHAX</sub>

WRITE
WRITE BYTE WRITE OR VALID ADDRESS & DATA (BYTE WRITE) AUTOMATED BYTE WRITE

OR ERASE CONFIRM COMMAND

ERASE SETUP COMMAND





### **ORDERING INFORMATION**



#### ADDITIONAL INFORMATION

|        | 28F008SA-L Datasheet                 | Order<br>Number<br>290435 |
|--------|--------------------------------------|---------------------------|
| AP-359 | "28F008SA Hardware Interfacing"      | 292094                    |
| AP-360 | "25F008SA Software Drivers"          | 292095                    |
| AP-364 | "28F008SA Automation and Algorithms" | 292099                    |
| ER-27  | "The Intel 28F008SA Flash Memory"    | 294011                    |
| ER-28  | "ETOX III Flash Memory Technology"   | 290412                    |

### **REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 002    | Revised from Advanced Information to Preliminary Modified Erase Suspend Flowchart Removed -90 speed bin Integrated -90 characteristics into -85 speed bin Combined V <sub>PP</sub> Standby current and V <sub>PP</sub> Read current into one V <sub>PP</sub> Standby current spec with two test conditions (DC Characteristics table) Lowered V <sub>LKO</sub> from 2.2V to 2.0V. |
| 004    | $\overline{\text{PWD}}$ renamed to $\overline{\text{RP}}$ # for JEDEC standardization compatibility. Changed lpps Standby current spec from $\pm$ 10 $\mu$ A to $\pm$ 15 $\mu$ A in DC Characteristics table.                                                                                                                                                                     |
| 005    | Added Extended Temperature Specs for 28F008SA Added I <sub>PPR</sub> Spec Corrected I <sub>PPS</sub> Spec Type Added V <sub>OHZ</sub> (Output High Voltage—CMOS) Spec Added Byte Write Time Spec                                                                                                                                                                                  |



## 28F008SA-L 8-MBIT (1 MBIT x 8) FLASHFILETM MEMORY

- High-Density Symmetrically Blocked Architecture
  - Sixteen 64-Kbyte Blocks
- Low-Voltage Operation — -3.3V ±0.3V or 5.0V ±10% V<sub>CC</sub>
- **Extended Cycling Capability** 
  - 10,000 Block Erase Cycles
  - 160,000 Block Erase Cycles per Chip
- Automated Byte Write and Block Erase
  - Command User Interface
  - Status Register
- **■** System Performance Enhancements
  - RY/BY# Status Output
  - Erase Suspend Capability

- High-Performance Read
   200 ns Maximum Access Time
- Deep-Powerdown Mode — 0.20 µA I<sub>CC</sub> Typical
- **SRAM-Compatible Write Interface**
- Hardware Data Protection Feature
   Erase/Write Lockout during Power Transitions
- Industry Standard Packaging — 40-Lead TSOP, 44-Lead PSOP
- ETOX III Nonvolatile Flash Technology — 12V Byte Write/Block Erase

Intel's 28F008SA-L 8 Mbit FlashFile<sup>TM</sup> Memory is the highest density nonvolatile read/write solution for solid state storage. The 28F008SA-L's extended cycling, symmetrically blocked architecture, fast access time, write automation and very low power consumption provide a more reliable, lower power, lighter weight and higher performance alternative to traditional rotating disk technology. The 28F008SA-L brings new capabilities to portable computing. Application and operating system software stored in resident flash memory arrays provide instant-on, rapid execute-in-place and protection from obsolescence through in-system software updates. Resident software also extends system battery life and increases reliability by reducing disk drive accesses.

For high density data acquisition applications, the 28F008SA-L offers a more cost-effective and reliable alternative to SRAM and battery. Traditional high density embedded applications, such as telecommunications, can take advantage of the 28F008SA-L's nonvolatility, blocking and minimal system code requirements for flexible firmware and modular software designs.

The 28F008SA-L is offered in 40-lead TSOP (standard and reverse) and 44-lead PSOP packages. Pin assignments simplify board layout when integrating multiple devices in a flash memory array or subsystem. This device uses an integrated Command User Interface and state machine for simplified block erasure and byte write. The 28F008SA-L memory map consists of 16 separately erasable 64-Kbyte blocks.

Intel's 28F008SA-L employs advanced CMOS circuitry for systems requiring low power consumption and noise immunity. Its 200 ns access time provides superior performance when compared with magnetic storage media. A deep powerdown mode lowers power consumption to 0.66  $\mu$ W typical thru V<sub>CC</sub>, crucial in portable computing, handheld instrumentation and other low-power applications. The RP# power control input also provides absolute data protection during system powerup/down.

Manufactured on Intel's 0.8 micron ETOX process, the 28F008SA-L provides the highest levels of quality, reliability and cost-effectiveness.

<sup>\*</sup>Microsoft is a trademark of Microsoft Corporation.



#### PRODUCT OVERVIEW

The 28F008SA-L is a high-performance 8-Mbit (8,388,608-bit) memory organized as 1 Mbyte (1,048,576 bytes) of 8 bits each. Sixteen 64-Kbyte (65,536-byte) blocks are included on the 28F008SA-L. A memory map is shown in Figure 6 of this specification. A block erase operation erases one of the sixteen blocks of memory in typically 2.0 seconds, independent of the remaining blocks. Each block can be independently erased and written 10,000 cycles. Erase Suspend mode allows system software to suspend block erase to read data or execute code from any other block of the 28F008SA-L.

The 28F008SA-L is available in the **40-lead TSOP** (Thin Small Outline Package, 1.2 mm thick) and **44-lead PSOP** (Plastic Small Outline) packages. Pinouts are shown in Figures 2 and 4 of this specification.

The **Command User Interface** serves as the interface between the microprocessor or microcontroller and the internal operation of the 28F008SA-L.

Byte Write and Block Erase Automation allow byte write and block erase operations to be executed using a two-write command sequence to the Command User Interface. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for byte write and block erase operations, including verifications, thereby unburdening the microprocessor or microcontroller. Writing of memory data is performed in byte increments typically within 11 µs, Ipp byte write and block erase currents are 10 mA typical, 30 mA maximum. Vpp byte write and block erase voltage is 11.4V to 12.6V.

The **Status Register** indicates the status of the WSM and when the WSM successfully completes the desired byte write or block erase operation.

The RY/BY# output gives an additional indicator of WSM activity, providing capability for both hardware signal of status (versus software polling) and status masking (interrupt masking for background erase, for example). Status polling using RY/BY# minimizes both CPU overhead and system power consumption. When low, RY/BY# indicates that the WSM is performing a block erase or byte write operation. RY/BY# high indicates that the WSM is ready for new commands, block erase is suspended or the device is in deep powerdown mode.

Maximum access time is 200 ns ( $t_{ACC}$ ) over the commercial temperature range (0°C to +70°C) and over V<sub>CC</sub> supply voltage range (3.0V to 3.6V and 4.5V to 5.5V). I<sub>CC</sub> active current (CMOS Read) is 5 mA typical, 12 mA maximum at 5 MHz, 3.3V  $\pm$  0.3V.

When the CE# and RP# pins are at  $V_{CC}$ , the  $I_{CC}$  CMOS Standby mode is enabled.

A **Deep Powerdown** mode is enabled when the RP# pin is at GND, minimizing power consumption and providing write protection. **I<sub>CC</sub> current** in deep powerdown is **0.20**  $\mu$ **A typical**. Reset time of 500 ns is required from RP# switching high until outputs are valid to read attempts. Equivalently, the device has a wake time of 1  $\mu$ s from RP# high until writes to the Command User Interface are recognized by the 28F008SA-L. With RP# at GND, the WSM is reset and the Status Register is cleared.





**Table 1. Pin Description** 

| Symbol                           | Туре         | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>19</sub>  | INPUT        | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                                           |
| DQ <sub>0</sub> -DQ <sub>7</sub> | INPUT/OUTPUT | DATA INPUT/OUTPUTS: Inputs data and commands during Command User Interface write cycles; outputs data during memory array, Status Register and Identifier read cycles. The data pins are active high and float to tri-state off when the chip is deselected or the outputs are disabled. Data is internally latched during a write cycle.                                                                             |
| CE#                              | INPUT        | CHIP ENABLE: Activates the device's control logic, input buffers, decoders, and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels.                                                                                                                                                                                                            |
| RP#                              | INPUT        | RESET/ DEEP POWERDOWN: Puts the device in deep powerdown mode. RP# is active low; RP# high gates normal operation. RP# also locks out block erase or byte write operations when active low, providing data protection during power transitions. RP# active resets internal automation. Exit from Deep Powerdown sets device to read-array mode.                                                                       |
| OE#                              | INPUT        | <b>OUTPUT ENABLE:</b> Gates the device's outputs through the data buffers during a read cycle. OE# is active low.                                                                                                                                                                                                                                                                                                     |
| WE#                              | INPUT        | WRITE ENABLE: Controls writes to the Command User Interface and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                  |
| RY/BY#                           | OUTPUT       | READY/BUSY#: Indicates the status of the internal Write State Machine. When low, it indicates that the WSM is performing a block erase or byte write operation. RY/BY# high indicates that the WSM is ready for new commands, block erase is suspended or the device is in deep powerdown mode. RY/BY# is always active and does NOT float to tri-state off when the chip is deselected or data outputs are disabled. |
| V <sub>PP</sub>                  |              | BLOCK ERASE/BYTE WRITE POWER SUPPLY for erasing blocks of the array or writing bytes of each block.  NOTE:                                                                                                                                                                                                                                                                                                            |
|                                  |              | With V <sub>PP</sub> < V <sub>PPLMAX</sub> , memory contents cannot be altered.                                                                                                                                                                                                                                                                                                                                       |
| Vcc                              |              | DEVICE POWER SUPPLY (3.3V $\pm$ 0.3V, 5V $\pm$ 10%)                                                                                                                                                                                                                                                                                                                                                                   |
| GND                              |              | GROUND                                                                                                                                                                                                                                                                                                                                                                                                                |





Figure 2. TSOP Lead Configurations





Figure 3. TSOP Serpentine Layout

#### NOTE

1. Connect all  $V_{CC}$  and GND pins of each device to common power supply outputs. DO NOT leave  $V_{CC}$  or GND inputs disconnected.





Figure 4. PSOP Lead Configuration



Figure 5. 28F008SA-L Array Interface to Intel3.3V 80L186EB Embedded Microprocessor



#### PRINCIPLES OF OPERATION

The 28F008SA-L includes on-chip write automation to manage write and erase functions. The Write State Machine allows for: 100% TTL-level control inputs; fixed power supplies during block erasure and byte write; and minimal processor overhead with RAM-like interface timings.

After initial device powerup, or after return from deep powerdown mode (see Bus Operations), the 28F008SA-L functions as a read-only memory. Manipulation of external memory-control pins allow array read, standby and output disable operations. Both Status Register and intelligent identifiers can also be accessed through the Command User Interface when Vpp = Vppi.

This same subset of operations is also available when high voltage is applied to the V<sub>PP</sub> pin. In addition, high voltage on V<sub>PP</sub> enables successful block erasure and byte writing of the device. All functions associated with altering memory contents—byte write, block erase, status and intelligent identifier—are accessed via the Command User Interface and verified thru the Status Register.

Commands are written using standard microprocessor write timings. Command User Interface contents serve as input to the WSM, which controls the block erase and byte write circuitry. Write cycles also internally latch addresses and data needed for byte write or block erase operations. With the appropriate command written to the register, standard microprocessor read timings output array data, access the Intelligent Identifier codes, or output byte write and block erase status for verification.

Interface software to initiate and poll progress of internal byte write and block erase can be stored in any of the 28F008SA-L blocks. This code is copied to, and executed from, system RAM during actual flash memory update. After successful completion of byte write and/or block erase, code/data reads from the 28F008SA-L are again possible via the Read Array command. Erase suspend/resume capability allows system software to suspend block erase to read data and execute code from any other block.

| _                       |                |
|-------------------------|----------------|
| FFFFF                   | 64-Kbyte Block |
| F0000<br>EFFFF          | 64-Kbyte Block |
| E0000                   | 04-Nbyte Block |
| D0000                   | 64-Kbyte Block |
| CFFFF C0000             | 64-Kbyte Block |
| BFFFF                   | 64-byte Block  |
| AFFFF                   | 64-Kbyte Block |
| A0000<br>9FFFF          | Of horse block |
| 90000                   | 64-Kbyte Block |
| 8FFFF<br>80000          | 64-Kbyte Block |
| 7FFFF<br>70000          | 64-Kbyte Block |
| 6FFFF                   | 64-Kbyte Block |
| 60000<br>5FFFF          |                |
| 50000                   | 64-Kbyte Block |
| 4FFFF 40000             | 64-Kbyte Block |
| 3FFFF<br>30000          | 64-Kbyte Block |
| 2FFFF                   | 64-Kbyte Block |
| 20000<br>1FFFF<br>10000 |                |
|                         | 64-Kbyte Block |
| 00000                   | 64-Kbyte Block |

Figure 6. Memory Map

## Command User Interface and Write Automation

An on-chip state machine controls block erase and byte write, freeing the system processor for other tasks. After receiving the Erase Setup and Erase Confirm commands, the state machine controls block pre-conditioning and erase, returning progress via the Status Register and RY/BY# output. Byte write is similarly controlled, after destination address and expected data are supplied. The program and erase algorithms of past Intel flash memories are now regulated by the state machine, including pulse repetition where required and internal verification and margining of data.



#### **Data Protection**

Depending on the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable (available only when memory byte writes/block erases are required) or hardwired to V<sub>PPH</sub>. When V<sub>PP</sub> = V<sub>PPL</sub>, memory contents cannot be altered. The 28F008SA-L Command User Interface architecture provides protection from unwanted byte write or block erase operations even when high voltage is applied to V<sub>PP</sub>. Additionally, all functions are disabled whenever V<sub>CC</sub> is below the write lockout voltage V<sub>LKO</sub>, or when RP # is at V<sub>IL</sub>. The 28F008SA-L accommodates either design practice and encourages optimization of the processor-memory interface.

The two-step byte write/block erase Command User Interface write sequence provides additional software write protection.

#### **BUS OPERATION**

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles.

#### Read

The 28F008SA-L has three read modes. The memory can be read from any of its blocks, and information can be read from the Intelligent Identifier or Status Register. V<sub>PP</sub> can be at either V<sub>PPL</sub> or V<sub>PPH</sub>.

The first task is to write the appropriate read mode command to the Command User Interface (array, Intelligent Identifier, or Status Register). The 28F008SA-L automatically resets to Read Array mode upon initial device powerup or after exit from deep powerdown. The 28F008SA-L has four control pins, two of which must be logically active to obtain data at the outputs. Chip Enable (CE#) is the device selection control, and when active enables the selected memory device. Output Enable (OE#) is the data input/output (DQ0-DQ7) direction control, and when active drives data from the selected memory onto the I/O bus. RP# and WE# must also be at  $V_{IH}$ . Figure 10 illustrates read bus cycle waveforms.

### **Output Disable**

With OE# at a logic-high level ( $V_{IH}$ ), the device outputs are disabled. Output pins (DQ<sub>0</sub>-DQ<sub>7</sub>) are placed in a high-impedance state.

### Standby

CE# at a logic-high level (V<sub>IH</sub>) places the 28F008SA-L in standby mode. Standby operation disables much of the 28F008SA-L's circuitry and substantially reduces device power consumption. The outputs (DQ0-DQ7) are placed in a high-impedence state independent of the status of OE#. If the 28F008SA-L is deselected during block erase or byte write, the device will continue functioning and consuming normal active power until the operation completes.

**Table 2. Bus Operations** 

| Mode                            | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-7</sub> | RY/BY#          |
|---------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|-----------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | D <sub>OUT</sub>  | Х               |
| Output Disable                  | 3       | $V_{IH}$        | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | · X             | High Z            | Х               |
| Standby                         | 3       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | · X             | High Z            | Х               |
| Deep PowerDown                  |         | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х               | High Z            | V <sub>OH</sub> |
| Intelligent Identifier (Mfr)    |         | $V_{IH}$        | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | 89H               | V <sub>OH</sub> |
| Intelligent Identifier (Device) |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | A1H               | V <sub>OH</sub> |
| Write                           | 3, 4, 5 | $V_{IH}$        | V <sub>IL</sub> | V <sub>IH</sub> | $V_{IL}$        | Х               | X               | D <sub>IN</sub>   | Х               |

- 1. Refer to DC Characteristics. When V<sub>PP</sub> = V<sub>PPL</sub>, memory contents can be read but not written or erased.
- 2. X can be V<sub>IL</sub> or V<sub>IH</sub> for control pins and addresses, and V<sub>PPL</sub> or V<sub>PPH</sub> for V<sub>PP</sub>. See DC Characteristics for V<sub>PPL</sub> and V<sub>PPH</sub> voltages.
- 3. RY/BY# is V<sub>OL</sub> when the Write State Machine is executing internal block erase or byte write algorithms. It is V<sub>OH</sub> when the WSM is not busy, in Erase Suspend mode or deep powerdown mode.
- 4. Command writes involving block erase or byte write are only successfully executed when VPP = VPPH.
- 5. Refer to Table 3 for valid D<sub>IN</sub> during a write operation.



#### **Deep Power-Down**

The 28F008SA-L offers a deep power-down feature, entered when RP# is at  $V_{IL}.$  Current draw thru  $V_{CC}$  is 0.20  $\mu A$  typical in deep powerdown mode, with current draw through  $V_{PP}$  typically 0.1  $\mu A.$  During read modes, RP#-low deselects the memory, places output drivers in a high-impedence state and turns off all internal circuits. The 28F008SA-L requires time  $t_{PHCV}$  (see AC Characteristics-Read-Only Operations) after return from powerdown until initial memory access outputs are valid. After this wakeup interval, normal operation is restored. The Command User Interface is reset to Read Array, and the upper 5 bits of the Status Register are cleared to value 10000, upon return to normal operation.

During block erase or byte write modes, RP# low will abort either operation. Memory contents of the block being altered are no longer valid as the data will be partially written or erased. Time  $t_{PHWL}$  after RP# goes to logic-high ( $V_{IH}$ ) is required before another command can be written.

This use of RP# during system reset is important with automated write/erase devices. When the system come out of reset, it expects to read from the flash memory. Automated flash memories provide

status information when accessed during write/ erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input. In this application RP# is controlled by the same RESET# signal that resets the system CPU.

## **Intelligent Identifier Operation**

The Intelligent Identifier operation outputs the manufacturer code, 89H; and the device code, A1H for the 28F008SA-L. The system CPU can then automatically match the device with its proper block erase and byte write algorithms.

The manufacturer- and device-codes are read via the Command User Interface. Following a write of 90H to the Command User Interface, a read from address location 00000H outputs the manufacturer code (89H). A read from address 00001H outputs the device code (A1H). It is not necessary to have high voltage applied to V<sub>PP</sub> to read the Intelligent Identifiers from the Command User Interface.

**Table 3. Command Definitions** 

| Command                          | Bus<br>Cycles | Notes   | First     | Bus Cycle |      | Second Bus Cycle |         |      |  |  |
|----------------------------------|---------------|---------|-----------|-----------|------|------------------|---------|------|--|--|
|                                  | Req'd         |         | Operation | Address   | Data | Operation        | Address | Data |  |  |
| Read Array/Reset                 | 1             | 1       | Write     | X         | FFH  |                  |         |      |  |  |
| Intelligent Identifier           | 3             | 2, 3, 4 | Write     | Х         | 90H  | Read             | IA      | IID  |  |  |
| Read Status Register             | 2             | 3       | Write     | Х         | 70H  | Read             | Х       | SRD  |  |  |
| Clear Status Register            | 1             |         | Write     | Х         | 50H  |                  |         |      |  |  |
| Erase Setup/Erase Confirm        | 2             | 2       | Write     | ВА        | 20H  | Write            | BA      | DOH  |  |  |
| Erase Suspend/Erase Resume       | 2             |         | Write     | Х         | вон  | Write            | Х       | DOH  |  |  |
| Byte Write Setup/Write           | 2             | 2, 3, 5 | Write     | WA        | 40H  | Write            | WA      | WD   |  |  |
| Alternate Byte Write Setup/Write | 2             | 2, 3, 5 | Write     | WA        | 10H  | Write            | WA      | WD   |  |  |

- 1. Bus operations are defined in Table 2.
- 2. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
  - BA = Address within the block being erased.
  - WA = Address of memory location to be written.
- 3. SRD = Data read from Status Register. See Table 4 for a description of the Status Register bits.
- WD = Data to be written at location WA. Data is latched on the rising edge of WE#.
- IID = Data read from Intelligent Identifiers.
- 4. Following the Intelligent Identifier command, two read operations access manufacture and device codes.
- 5. Either 40H or 10H are recognized by the WSM as the Byte Write Setup command.
- 6. Commands other than those shown above are reserved by Intel for future device implementations and should not be used.



#### Write

Writes to the Command User Interface enable reading of device data and Intelligent Identifiers. They also control inspection and clearing of the Status Register. Additionally, when Vpp = VppH, the Command User Interface controls block erasure and byte write. The contents of the interface register serve as input to the internal state machine.

The Command User Interface itself does not occupy an addressable memory location. The interface register is a latch used to store the command and address and data information needed to execute the command. Erase Setup and Erase Confirm commands require both appropriate command data and an address within the block to be erased. The Byte Write Setup command requires both appropriate command data and the address of the location to be written, while the Byte Write command consists of the data to be written and the address of the location to be written.

The Command User Interface is written by bringing WE# to a logic-low level ( $V_{\rm IL}$ ) while CE# is low. Addresses and data are latched on the rising edge of WE#. Standard microprocessor write timings are used.

Refer to AC Write Characteristics and the AC Waveforms for Write Operations, Figure 11, for specific timing parameters.

#### **COMMAND DEFINITIONS**

When  $V_{PPL}$  is applied to the  $V_{PP}$  pin, read operations from the Status Register, Intelligent Identifiers, or array blocks are enabled. Placing  $V_{PPH}$  on  $V_{PP}$  enables successful byte write and block erase operations as well.

Device operations are selected by writing specific commands into the Command User Interface. Table 3 defines the 28F008SA-L commands.

### **Read Array Command**

Upon initial device powerup and after exit from deep powerdown mode, the 28F008SA-L defaults to Read Array mode. This operation is also initiated by writing FFH into the Command User Interface. Microprocessor read cycles retrieve array data. The device remains enabled for reads until the Command User Interface contents are altered. Once the internal Write State Machine has started a block erase or byte write operation, the device will not recognize the Read Array command, until the WSM has completed its operation. The Read Array command is functional when VPP = VPPL or VPPH.

### **Intelligent Identifier Command**

The 28F008SA-L contains an Intelligent Identifier operation, initiated by writing 90H into the Command

**Table 4. Status Register Definitions** 



SR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

SR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

SR.4 = BYTE WRITE STATUS

1 = Error in Byte Write

0 = Successful Byte Write

SR.3 = Vpp STATUS

1 = V<sub>PP</sub> Low Detect; Operation Abort

 $0 = V_{PP} OK$ 

SR.2-SR.0 = RESERVED FOR FUTURE

**ENHANCEMENTS** 

These bits are reserved for future use and should be masked out when polling the Status Register.

#### NOTES:

RY/BY# or the Write State Machine Status bit must first be checked to determine byte write or block erase completion, before the Byte Write or Erase Status bit are checked for success.

If the Byte Write AND Erase Status bits are set to "1"s during a block erase attempt, an improper command sequence was entered. Attempt the operation again.

If V<sub>PP</sub> low status is detected, the Status Register must be cleared before another byte write or block erase operation is attempted.

The  $V_{PP}$  Status bit, unlike an A/D converter, does not provide continuous indication of  $V_{PP}$  level. The WSM interrogates the  $V_{PP}$  level only after the byte write or block erase command sequences have been entered and informs the system if  $V_{PP}$  has not been switched on. The  $V_{PP}$  Status bit is not guaranteed to report accurate feedback between  $V_{PPL}$  and  $V_{PPH}$ .



User Interface. Following the command write, a read cycle from address 00000H retrieves the manufacturer code of 89H. A read cycle from address 00001H returns the device code of A1H. To terminate the operation, it is necessary to write another valid command into the register. Like the Read Array command, the Intelligent Identifier command is functional when VPP = VPPL or VPPH.

### **Read Status Register Command**

The 28F008SA-L contains a Status Register which may be read to determine when a byte write or block erase operation is complete, and whether that operation completed successfully. The Status Register may be read at any time by writing the Read Status Register command (70H) to the Command User Interface. After writing this command, all subsequent read operations output data from the Status Register, until another valid command is written to the Command User Interface. The contents of the Status Register are latched on the falling edge of OE# or CE#, whichever occurs last in the read cycle. OE# or CE# must be toggled to VIH before further reads to update the Status Register latch. The Read Status Register command functions when  $V_{PP} = V_{PPI}$  or  $V_{PPH}$ .

## **Clear Status Register Command**

The Erase Status and Byte Write Status bits are set to "1"s by the Write State Machine and can only be reset by the Clear Status Register Command. These bits indicate various failure conditions (see Table 4). By allowing system software to control the resetting of these bits, several operations may be performed (such as cumulatively writing several bytes or erasing multiple blocks in sequence). The Status Register may then be polled to determine if an error occurred during that sequence. This adds flexibility to the way the device may be used.

Additionally, the  $V_{PP}$  Status bit (SR.3) MUST be reset by system software before further byte writes or block erases are attempted. To clear the Status Register, the Clear Status Register command (50H) is written to the Command User Interface. The Clear Status Register command is functional when  $V_{PP} = V_{PPL}$  or  $V_{PPH}$ .

## Erase Setup/Erase Confirm Commands

Erase is executed one block at a time, initiated by a two-cycle command sequence. An Erase Setup command (20H) is first written to the Command User Interface, followed by the Erase Confirm command (D0H). These commands require both appropriate sequencing and an address within the block to be erased to FFH. Block preconditioning, erase and verify are all handled internally by the Write State Machine, invisible to the system. After the two-command erase sequence is written to it, the 28F008SA-L automatically outputs Status Register data when read (see Figure 8; Block Erase Flowchart). The CPU can detect the completion of the erase event by analyzing the output of the RY/BY# pin, or the WSM Status bit of the Status Register.

When erase is completed, the Erase Status bit should be checked. If erase error is detected, the Status Register should be cleared. The Command User Interface remains in Read Status Register mode until further commands are issued to it.

This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, reliable block erasure can only occur when  $V_{PP} = V_{PPH}$ . In the absence of this high voltage, memory contents are protected against erasure. If block erase is attempted while  $V_{PP} = V_{PPL}$ , the  $V_{PP}$  Status bit will be set to "1". Erase attempts while  $V_{PPL} < V_{PP} < V_{PPH}$  produce spurious results and should not be attempted.

## Erase Suspend/Erase Resume Commands

The Erase Suspend command allows block erase interruption in order to read data from another block of memory. Once the erase process starts, writing the Erase Suspend command (B0H) to the Command User Interface requests that the WSM suspend the erase sequence at a predetermined point in the erase algorithm. The 28F008SA-L continues to output Status Register data when read, after the Erase Suspend command is written to it. Polling the WSM Status and Erase Suspend Status bits will determine when the erase operation has been suspended (both will be set to "1"). RY/BY# will also transition to VOH.

At this point, a Read Array command can be written to the Command User Interface to read data from blocks other than that which is suspended. The only other valid commands at this time are Read Status Register (70H) and Erase Resume (D0H), at which time the WSM will continue with the erase process. The Erase Suspend Status and WSM Status bits of the Status Register will be automatically cleared and RY/BY# will return to Vol. After the Erase Resume command is written to it, the 28F008SA-L automatically outputs Status Register data when read (see Figure 9; Erase Suspend/Resume Flowchart). Vpp must remain at VppH while the 28F008SA-L is in Erase Suspend.



## Byte Write Setup/Write Commands (40H or 10H)

Byte write is executed by a two-command sequence. The Byte Write Setup command (40H or 10H) is written to the Command User Interface, followed by a second write specifying the address and data (latched on the rising edge of WE#) to be written. The WSM then takes over, controlling the byte write and write verify algorithms internally. After the two-command byte write sequence is written to it, the 28F008SA-L automatically outputs Status Register data when read (see Figure 7; Byte Write Flowchart). The CPU can detect the completion of the byte write event by analyzing the output of the RY/BY# pin, or the WSM Status bit of the Status Register. Only the Read Status Register command is valid while byte write is active.

When byte write is complete, the Byte Write Status bit should be checked. If byte write error is detected, the Status Register should be cleared. The internal WSM verify only detects errors for "1"s that do not successfully write to "0"s. The Command User Interface remains in Read Status Register mode until further commands are issued to it. If byte write is attempted while  $V_{PP} = V_{PPL}$ , the  $V_{PP}$  Status bit will be set to "1". Byte write attempts while  $V_{PPL} < V_{PP} < V_{PPH}$  produce spurious results and should not be attempted.

## EXTENDED BLOCK ERASE/BYTE WRITE CYCLING

Intel has designed extended cycling capability into its ETOX flash memory technologies. The 28F008SA-L is designed for 10,000 byte write/block erase cycles on each of the sixteen 64-Kbyte blocks. Low electric fields, advanced oxides and minimal oxide area per cell subjected to the tunneling electric field combine to greatly reduce oxide stress and the probability of failure. A 20-Mbyte solid-state drive using an array of 28F008SA-Ls has a MTBF (Mean Time Between Failure) of 3.33 million hours(1), over 60 times more reliable than equivalent rotating disk technology.

#### **AUTOMATED BYTE WRITE**

The 28F008SA-L integrates the Quick-Pulse programming algorithm of prior Intel Flash Memory devices on-chip, using the Command User Interface, Status Register and Write State Machine (WSM). On-chip integration dramatically simplifies system software and provides processor interface timings to the Command User Interface and Status Register. WSM operation, internal verify and V<sub>PP</sub> high voltage presence are monitored and reported via the RY/BY# output and appropriate Status Register

bits. Figure 7 shows a system software flowchart for device byte write. The entire sequence is performed with V<sub>PP</sub> at V<sub>PPH</sub>. Byte write abort occurs when RP # transitions to V<sub>IL</sub>, or V<sub>PP</sub> drops to V<sub>PPL</sub>. Although the WSM is halted, byte data is partially written at the location where byte write was aborted. Block erasure, or a repeat of byte write, is required to initialize this data to a known value.

#### **AUTOMATED BLOCK ERASE**

As above, the Quick-Erase algorithm of prior Intel Flash devices is now implemented internally, including all preconditioning of block data. WSM operation, erase success and V<sub>PP</sub> high voltage presence are monitored and reported through RY/BY# and the Status Register. Additionally, if a command other than Erase Confirm is written to the device following Erase Setup, both the Erase Status and Byte Write Status bits will be set to "1"s. When issuing the Erase Setup and Erase Confirm commands, they should be written to an address within the address range of the block to be erased. Figure 8 shows a system software flowchart for block erase.

Erase typically takes 2.0 seconds per block. The Erase Suspend/Erase Resume command sequence allows suspension of this erase operation to read data from a block other than that in which erase is being performed. A system software flowchart is shown in Figure 9.

The entire sequence is performed with V<sub>PP</sub> at V<sub>PPH</sub>. Abort occurs when RP# transitions to V<sub>IL</sub> or V<sub>PP</sub> falls to V<sub>PPL</sub>, while erase is in progress. Block data is partially erased by this operation, and a repeat of erase is required to obtain a fully erased block.

#### **DESIGN CONSIDERATIONS**

### **Three-Line Output Control**

The 28F008SA-L will often be used in large memory arrays. Intel provides three control inputs to accommodate multiple memory connections. Three-line control provides for:

- a) lowest possible memory power dissipation
- b) complete assurance that data bus contention will not occur

To efficiently use these control inputs, an address decoder should enable CE#, while OE# should be connected to all memory devices and the system's READ# control line. This assures that only selected memory devices have active outputs while deselected memory devices are in Standby Mode. RP# should be connected to the system Powergood signal to prevent unintended writes during system power transitions. Powergood should also toggle during system reset.

(1)Assumptions: 10-Kbyte file written every 10 minutes. (20-Mbyte array)/(10-Kbyte file) = 2,000 file writes before erase required. (2000 files writes/erase)  $\times$  (10,000 cycles per 28F008SA-L block) = 20 million file writes. (20  $\times$  10<sup>6</sup> file writes)  $\times$  (10 min/write)  $\times$  (1 hr/60 min) = 3.33  $\times$  10<sup>6</sup> MTBF.



## RY/BY# and Byte Write/Block Erase Polling

RY/BY# is a full CMOS output that provides a hardware method of detecting byte write and block erase completion. It transitions low time t<sub>WHRL</sub> after a write or erase command sequence is written to the

28F008SA-L, and returns to V<sub>OH</sub> when the WSM has finished executing the internal algorithm.

RY/BY# can be connected to the interrupt input of the system CPU or controller. It is active at all times, not tristated if the 28F008SA-L CE# or OE# inputs are brought to  $V_{IH}$ . RY/BY# is also  $V_{OH}$  when the device is in Erase Suspend or deep powerdown modes.



| Bus<br>Operation | Command             | Comments                                                                                                                                   |
|------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Write            | Byte Write<br>Setup | Data = 40H (10H)<br>Address = Byte to be written                                                                                           |
| Write            | Byte Write          | Data to be written<br>Address = Byte to be written                                                                                         |
| Standby/Read     |                     | Check RY/BY#  VOH = Ready, VOL = Busy or  Read Status Register Check SR.7  1 = Ready, 0 = Busy Toggle OE# or CE# to update Status Register |

Repeat for subsequent bytes

Full status check can be done after each byte or after a sequence of bytes

Write FFH after the last byte write operation to reset the device to Ready Array Mode

#### **FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                                                        |
|------------------|---------|---------------------------------------------------------------------------------|
| Optional<br>Read |         | CPU may already have read<br>Status Register data in WSM<br>Ready polling above |
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect                                    |
| Standby          |         | Check SR.4<br>1 = Byte Write Error                                              |

SR.3 MUST be cleared, if set during a byte write attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple bytes are written before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 7. Automated Byte Write Flowchart





| Command        | Comments                                                                                                                                     |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Erase<br>Setup | Data = 20H<br>Address = Within block to be<br>erased                                                                                         |
| Erase          | Data = D0H<br>Address = Within block to be<br>erased                                                                                         |
|                | Check RY/BY#  VOH = Ready, VOL = Busy or  Read Status Register  Check SR.7  1 = Ready, 0 = Busy  Toggle OE# or CE# to update Status Register |
|                | Erase<br>Setup                                                                                                                               |

Repeat for subsequent bytes

Full status check can be done after each block or after a sequence of blocks

Write FFH after the last block erase operation to reset the device to Ready Array Mode

#### **FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                                                        |
|------------------|---------|---------------------------------------------------------------------------------|
| Optional<br>Read |         | CPU may already have read<br>Status Register data in WSM<br>Ready polling above |
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect                                    |
| Standby          |         | Check SR.4,5 Both 1 = Command Sequence Error                                    |
| Standby          |         | Check SR.5<br>1 = Block Erase Error                                             |

SR.3 MUST be cleared, if set during a block erase attempt, before further attempts are allowed by the Write State Machine

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 8. Automated Block Erase Flowchart





Figure 9. Erase Suspend/Resume Flowchart

## **Power Supply Decoupling**

Flash memory power switching characteristics require careful device decoupling. System designers are interested in 3 supply current issues; standby current levels ( $I_{SB}$ ), active current levels ( $I_{CC}$ ) and transient peaks produced by falling and rising edges of CE#. Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress transient voltage peaks. Each device should have a 0.1  $\mu$ F ceramic capacitor connected between each  $V_{CC}$  and GND, and between its  $V_{PP}$  and GND. These high frequency, low inherent-inductance capacitors should be placed as close as possible to package leads. Additionally, for

every 8 devices, a 4.7  $\mu F$  electrolytic capacitor should be placed at the array's power supply connection between  $V_{CC}$  and GND. The bulk capacitor will overcome voltage slumps caused by PC board trace inductances.

## **VPP Trace on Printed Circuit Boards**

Writing flash memories, while they reside in the target system, requires that the printed circuit board designer pay attention to the V<sub>PP</sub> power supply trace. The V<sub>PP</sub> pin supplies the memory cell current for writing and erasing. Use similar trace widths and layout considerations given to the V<sub>CC</sub> power bus. Adequate V<sub>PP</sub> supply traces and decoupling will decrease V<sub>PP</sub> voltage spikes and overshoots.



## V<sub>CC</sub>, V<sub>PP</sub>, RP# Transitions and the Command/Status Registers

Byte write and block erase completion are not guaranteed if  $V_{PP}$  drops below  $V_{PPH}$ . If the  $V_{PP}$  Status bit of the Status Register (SR.3) is set to "1", a Clear Status Register command MUST be issued before further byte write/block erase attempts are allowed by the WSM. Otherwise, the Byte Write (SR.4) or Erase (SR.5) Status bits of the Status Register will be set to "1"s if error is detected. RP# transitions to  $V_{IL}$  during byte write and block erase also abort the operations. Data is partially altered in either case, and the command sequence must be repeated after normal operation is restored. Device poweroff, or RP# transitions to  $V_{IL}$ , clear the Status Register to initial value 10000 for the upper 5 bits.

The Command User Interface latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its state upon powerup, after exit from deep powerdown or after  $V_{CC}$  transitions below  $V_{LKO}$ , is Read Array Mode.

After byte write or block erase is complete, even after  $V_{PP}$  transitions down to  $V_{PPL}$ , the Command User Interface must be reset to Read Array mode via the Read Array command if access to the memory array is desired.

## **Power Up/Down Protection**

The 28F008SA-L is designed to offer protection against accidental block erasure or byte writing during power transitions. Upon power-up, the 28F008SA-L is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers up first. Power supply sequencing is not required. Internal circuitry in the

28F008SA-L ensures that the Command User Interface is reset to the Read Array mode on power up.

A system designer must guard against spurious writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either to  $V_{IH}$  will inhibit writes. The Command User Interface architecture provides an added level of protection since alteration of memory contents only occurs after successful completion of the two-step command sequences.

Finally, the device is disabled until RP# is brought to  $V_{\rm IH}$ , regardless of the state of its control inputs. This provides an additional level of memory protection.

## **Power Dissipation**

When designing portable systems, designers must consider battery power consumption not only during device operation, but also for data retention during system idle time. Flash nonvolatility increases usable battery life, because the 28F008SA-L does not consume any power to retain code or data when the system is off.

In addition, the 28F008SA-L's deep powerdown mode ensures extremely low power dissipation even when system power is applied. For example, portable PCs and other power sensitive applications, using an array of 28F008SA-Ls for solid-state storage, can lower RP# to V<sub>IL</sub> in standby or sleep modes, producing negligable power consumption. If access to the 28F008SA-L is again needed, the part can again be read, following the t<sub>PHQV</sub> and t<sub>PHWL</sub> wakeup cycles required after RP# is first raised back to V<sub>IH</sub>. See AC Characteristics—Read-Only and Write Operations and Figures 10 and 11 for more information.



### **ABSOLUTE MAXIMUM RATINGS\***

| Operating Temperature  During Read20°C to +70°C(1)  During Block Erase/Byte Write0°C to +70°C                 |
|---------------------------------------------------------------------------------------------------------------|
| Temperature Under Bias $-20^{\circ}$ C to $+80^{\circ}$ C                                                     |
| Storage Temperature $\dots -65^{\circ}\text{C}$ to $+125^{\circ}\text{C}$                                     |
| Voltage on Any Pin (except $V_{CC}$ and $V_{PP}$ ) with Respect to GND $-2.0V$ to $+7.0V^{(2)}$               |
| V <sub>PP</sub> Program Voltage with<br>Respect to GND during<br>Block Erase/Byte Write 2.0V to + 14.0V(2, 3) |
| $V_{CC}$ Supply Voltage with Respect to GND2.0V to $+7.0V^{(2)}$                                              |
| Output Short Circuit Current100 mA(4)                                                                         |

NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC}+0.5V$  which, during transitions, may overshoot to  $V_{CC}+2.0V$  for periods <20 ns.
- 3. Maximum DC voltage on V<sub>PP</sub> may overshoot to +14.0V for periods <20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. AC specifications are valid at both voltage ranges. See DC Characteristics for voltage range specific specification.

### **OPERATING CONDITIONS**

| Symbol          | Parameter                                         | Notes | Min  | Max  | Unit |
|-----------------|---------------------------------------------------|-------|------|------|------|
| T <sub>A</sub>  | Operating Temperature                             |       | -20  | 70   | °C   |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (Read)             | 5     | 3.00 | 3.60 | ٧    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage<br>(Program/Erase) | 5     | 3.15 | 3.60 | ٧    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage                    | 5     | 4.50 | 5.50 | ٧    |

## **DC CHARACTERISTICS** $V_{CC} = 3.3V \pm 0.3V$ Read, 3.15–3.6 Program/Erase

| Symbol           | Parameter                                 | Notes | Min | Тур  | Max  | Unit | Test Condition                                                       |
|------------------|-------------------------------------------|-------|-----|------|------|------|----------------------------------------------------------------------|
| l <sub>Llį</sub> | Input Load Current                        | 1     |     |      | ±0.5 | μА   | $V_{CC} = V_{CC} Max$ $V_{IN} = V_{CC} or GND$                       |
| I <sub>LO</sub>  | Output Leakage Current                    | 1     |     |      | ±0.5 | μΑ   | $V_{CC} = V_{CC} Max$ $V_{OUT} = V_{CC} or GND$                      |
| Iccs             | V <sub>CC</sub> Standby Current           | 1,3   |     | 20   | 2.0  | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = RP# = V <sub>IH</sub> |
|                  |                                           |       |     | 30   | 100  | μА   | $V_{CC} = V_{CC} Max$ $CE\# = RP\# = V_{CC} \pm 0.2V$                |
| ICCD             | V <sub>CC</sub> Deep PowerDown<br>Current | 1     |     | 0.20 | 1.0  | μΑ   | $RP\# = GND \pm 0.2V$ $I_{OUT}(RY/BY\#) = 0 \text{ mA}$              |



## DC CHARACTERISTICS (Continued)

| Symbol           | Parameter                                        | Notes | Min                   | Тур  | Max                   | Unit | Test Condition                                                                    |
|------------------|--------------------------------------------------|-------|-----------------------|------|-----------------------|------|-----------------------------------------------------------------------------------|
| ICCR             | V <sub>CC</sub> Read Current                     | 1     |                       | 5    | 12                    | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>f = 5 MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs |
| * .              |                                                  | ·     |                       | 5    | 12                    | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 5 MHz, $I_{OUT} = 0 mA$<br>TTL Inputs |
| Iccw             | V <sub>CC</sub> Byte Write Current               | 1     |                       | 6    | 18                    | mΑ   | Byte Write In Progress                                                            |
| ICCE             | V <sub>CC</sub> Block Erase Current              | 1     |                       | 6    | 18                    | mΑ   | Block Erase In Progress                                                           |
| ICCES            | V <sub>CC</sub> Erase Suspend<br>Current         | 1, 2  |                       | 3    | 6                     | mΑ   | Block Erase Suspended<br>CE# = V <sub>IH</sub>                                    |
| I <sub>PPS</sub> | V <sub>PP</sub> Standby Current                  | 1     |                       | ±1   | ±15                   | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                 |
| I <sub>PPD</sub> | V <sub>PP</sub> Deep PowerDown<br>Current        | 1     |                       | 0.10 | 5.0                   | μΑ   | RP# = GND ±0.2V                                                                   |
| I <sub>PPR</sub> | V <sub>PP</sub> Read Current                     |       |                       |      | 200                   | μΑ   | $V_{PP} > V_{CC}$                                                                 |
| I <sub>PPW</sub> | V <sub>PP</sub> Byte Write Current               | 1     | 1                     | 10   | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                      |
| IPPE             | V <sub>PP</sub> Block Erase Current              | 1     |                       | 10   | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                     |
| IPPES            | V <sub>PP</sub> Erase Suspend<br>Current         | 1     |                       | 90   | 200                   | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                       |
| VIL              | Input Low Voltage                                |       | -0.5                  |      | 0.6                   | ٧    |                                                                                   |
| VIH              | Input High Voltage                               |       | 2.0                   |      | V <sub>CC</sub> + 0.5 | ٧    |                                                                                   |
| VOL              | Output Low Voltage                               | 3     |                       |      | 0.4                   | ٧    | $V_{CC} = V_{CC} Min, I_{OL} = 2 mA$                                              |
| V <sub>OH1</sub> | Output High Voltage (TTL)                        | 3     | 2.4                   |      |                       | ٧    | $V_{CC} = V_{CC} Min, I_{OH} = -2 mA$                                             |
| V <sub>OH2</sub> | Output High Voltage                              |       | 0.85 V <sub>CC</sub>  |      |                       | ٧,   | $I_{OH} = 2.5 \mu A$ , $V_{CC} = V_{CC} Min$                                      |
|                  | (CMOS)                                           |       | V <sub>CC</sub> - 0.4 | 1    |                       |      | $I_{OH} = -100 \mu\text{A}, V_{CC} = V_{CC} \text{Min}$                           |
| V <sub>PPL</sub> | V <sub>PP</sub> during Normal<br>Operations      | 4     | 0.0                   |      | 6.5                   | ٧    |                                                                                   |
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write<br>Operations |       | 11.4                  | 12.0 | 12.6                  | ٧    |                                                                                   |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.0                   |      |                       | ٧    |                                                                                   |

## $\textbf{CAPACITANCE(5)} \ T_{A} = 25^{\circ}\text{C, f} = 1 \ \text{MHz}$

| Symbol           | Symbol Parameter   |   | Max | Unit | Condition             |
|------------------|--------------------|---|-----|------|-----------------------|
| C <sub>IN</sub>  | Input Capacitance  | 6 | 8   | pF   | $V_{IN} = 0V$         |
| C <sub>OUT</sub> | Output Capacitance | 8 | 12  | pF   | V <sub>OUT</sub> = 0V |



#### NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 3.3V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (packages and speeds).
- 2. ICCES is specified with the device deselected. If the 28F008SA-L is read while in Erase Suspend Mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCR</sub>.
  3. Includes RY/BY#.
- 4. Block Erases/Byte Writes are inhibited when Vpp = VppL and not guaranteed in the range between VppH and VppL.
- 5. Sampled, not 100% tested.

## **DC CHARACTERISTICS** $V_{CC} = 5.0V \pm 10\%$

| Symbol           | Parameter                                   | Notes | Min                                           | Тур  | Max            | Unit | Test Condition                                                                                                     |
|------------------|---------------------------------------------|-------|-----------------------------------------------|------|----------------|------|--------------------------------------------------------------------------------------------------------------------|
| ILI              | Input Load Current                          | 1     |                                               |      | ±1.0           | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                  |
| ILO              | Output Leakage Current                      | 1     |                                               |      | ± 10           | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                                                 |
| Iccs             | V <sub>CC</sub> Standby Current             | 1, 3  |                                               | 1.0  | 2.0            | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = RP# = V <sub>IH</sub>                                               |
|                  |                                             |       |                                               | 30   | 100            | μΑ   | $V_{CC} = V_{CC} Max$<br>$CE\# = RP\# = V_{CC} \pm 0.2V$                                                           |
| ICCD             | V <sub>CC</sub> Deep PowerDown<br>Current   | 1     |                                               | 0.20 | 1.2            | μΑ   | $ \begin{array}{l} RP\# = GND \pm 0.2V \\ I_{OUT} \left( RY/BY\# \right) = 0 \ mA \end{array} $                    |
| ICCR             | V <sub>CC</sub> Read Current                | 1     |                                               | 20   | 35             | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>f = 5 MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs                                  |
|                  |                                             |       |                                               | 25   | 50             | mΑ   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$ f = 5 MHz, $I_{OUT} = 0$ mA TTL Inputs                                      |
| Iccw             | V <sub>CC</sub> Byte Write Current          | 1     |                                               | 10   | 30             | mΑ   | Byte Write In Progress                                                                                             |
| ICCE             | V <sub>CC</sub> Block Erase Current         | 1     |                                               | 10   | 30             | mΑ   | Block Erase In Progress                                                                                            |
| ICCES            | V <sub>CC</sub> Erase Suspend<br>Current    | 1, 2  |                                               | 5    | 10             | mΑ   | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                                                    |
| IPPS             | V <sub>PP</sub> Standby Current             | 1     |                                               | ±1   | ±15            | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                                  |
| IPPD             | V <sub>PP</sub> Deep PowerDown<br>Current   | 1     |                                               | 0.10 | 5.0            | μΑ   | $RP\# = GND \pm 0.2V$                                                                                              |
| I <sub>PPR</sub> | V <sub>PP</sub> Read Current                | 1     |                                               | 90   | 200            | μΑ   | $V_{PP} > V_{CC}$                                                                                                  |
| lppW             | V <sub>PP</sub> Byte Write Current          | 1     |                                               | 10   | 30             | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                                                       |
| IPPE             | V <sub>PP</sub> Block Erase Current         | 1     |                                               | 10   | 30             | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                                                      |
| IPPES            | V <sub>PP</sub> Erase Suspend<br>Current    | 1     |                                               | 90   | 200            | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                                                        |
| $V_{IL}$         | Input Low Voltage                           |       | -0.5                                          |      | 0.8            | ٧    |                                                                                                                    |
| V <sub>IH</sub>  | Input High Voltage                          |       | 2.0                                           |      | $V_{CC} + 0.5$ | ٧    |                                                                                                                    |
| V <sub>OL</sub>  | Output Low Voltage                          | 3     |                                               |      | 0.45           | >    | $V_{CC} = V_{CC} Min, I_{OL} = 5.8 mA$                                                                             |
| V <sub>OH1</sub> | Output High Voltage (TTL)                   | 3     | 2.4                                           |      |                | ٧    | $V_{CC} = V_{CC} Min, I_{OH} = -2.5 mA$                                                                            |
| V <sub>OH2</sub> | Output High Voltage<br>(CMOS)               |       | 0.85 V <sub>CC</sub><br>V <sub>CC</sub> - 0.4 |      |                | ٧    | $I_{OH} = -2.5 \mu\text{A}, V_{CC} = V_{CC} \text{Min}$<br>$I_{OH} = -100 \mu\text{A}, V_{CC} = V_{CC} \text{Min}$ |
| V <sub>PPL</sub> | V <sub>PP</sub> during Normal<br>Operations | 4     | 0.0                                           |      | 6.5            | ٧    | , , , , , , , , , , , , , , , , , , , ,                                                                            |



## **DC CHARACTERISTICS** (Continued) $V_{CC} = 5.0V \pm 10\%$

| Symbol           | Parameter                                        | Notes | Min  | Тур  | Max  | Unit | Test Condition |
|------------------|--------------------------------------------------|-------|------|------|------|------|----------------|
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write<br>Operations |       | 11.4 | 12.0 | 12.6 | ٧    |                |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock<br>Voltage      | ,     | 2.0  |      | ,    | ٧    |                |

#### NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).
- 2. I<sub>CCES</sub> is specified with the device deselected. If the 28F008SA-L is read while in Erase Suspend Mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCR</sub>.
- 3. Includes RY/BY#.
- 4. Block Erases/Byte Writes are inhibited when Vpp = VppL and not guaranteed in the range between VppH and VppL.

#### AC INPUT/OUTPUT REFERENCE WAVEFORM



AC test inputs are driven at 3.0V for a Logic "1" and 0.0V for a Logic "0". Input timing begins, and output timing ends, at 1.5V. Input rise and fall times (10% to 90%) < 10 ns.

### AC TESTING LOAD CIRCUIT(2)



## AC CHARACTERISTICS—Read-Only Operations(1) $V_{CC} = 3.3V \pm 0.3V$ , 5.0V $\pm 10\%$

| Versions          |                  |                                                                      | 28F008 | Unit |     |      |
|-------------------|------------------|----------------------------------------------------------------------|--------|------|-----|------|
| Sym               | bol              | Parameter                                                            |        | Min  | Max | Unit |
| t <sub>AVAV</sub> | t <sub>RC</sub>  | Read Cycle Time                                                      |        | 200  |     | ns   |
| t <sub>AVQV</sub> | t <sub>ACC</sub> | Address to Output Delay                                              |        |      | 200 | ns   |
| t <sub>ELQV</sub> | t <sub>CE</sub>  | CE# to Output Delay                                                  | 2      |      | 200 | ns   |
| t <sub>PHQV</sub> | t <sub>PWH</sub> | RP# High to Output Delay 500                                         |        | 500  | ns  |      |
| tGLQV             | toE              | OE# to Output Delay                                                  | 2      |      | 85  | ns   |
| tELQX             | t <sub>LZ</sub>  | CE# to Output Low Z 3 0                                              |        |      | ns  |      |
| tEHQZ             | t <sub>HZ</sub>  | CE# High to Output High Z                                            | 3      |      | 55  | ns   |
| tGLQX             | toLZ             | OE# to Output Low Z                                                  | 3      | 0    |     | ns   |
| tgHQZ             | t <sub>DF</sub>  | OE# High to Output High Z                                            | 3      |      | 30  | ns   |
|                   | toH              | Output Hold from Addresses, CE# or OE#<br>Change, Whichever is First | 3      | 0    |     | ns   |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.

Figure 10. AC Waveform for Read Operations





## AC CHARACTERISTICS—Write Operations(1) $V_{CC} = 3.3V \pm 0.3V$ , 5.0V $\pm 10\%$

|                    |                  | 28F008                                           | Unit  |     |     |      |
|--------------------|------------------|--------------------------------------------------|-------|-----|-----|------|
| Syml               | ymbol Parameter  |                                                  | Notes | Min | Max | Unit |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                                 |       | 200 |     | ns   |
| t <sub>PHWL</sub>  | tps              | RP# High Recovery to WE# Going Low               | 2     | 1   |     | μs   |
| tELWL              | tcs              | CE# Setup to WE# Going Low                       |       | 20  |     | ns   |
| twLwH              | t <sub>WP</sub>  | WE# Pulse Width                                  |       | 60  |     | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE# Going High          | 2     | 100 |     | ns   |
| t <sub>AVWH</sub>  | t <sub>AS</sub>  | Address Setup to WE# Going High                  | 3     | 60  |     | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to WE# Going High                     | 4     | 60  |     | ns   |
| twhox              | t <sub>DH</sub>  | Data Hold from WE# High                          |       | 5   |     | ns   |
| twhax              | t <sub>AH</sub>  | Address Hold from WE# High                       |       | 5   |     | ns   |
| twhEH              | tcH              | CE# Hold from WE# High                           |       | 10  |     | ns   |
| t <sub>WHWL</sub>  | t <sub>WPH</sub> | WE# Pulse Width High                             |       | 30  |     | ns   |
| twhrl              |                  | WE# High to RY/BY# Going Low                     |       |     | 100 | ns   |
| twHQV1             |                  | Duration of Byte Write Operation                 | 5, 6  | 6   |     | μs   |
| t <sub>WHQV2</sub> |                  | Duration of Block Erase Operation                |       | 0.3 |     | sec  |
| twHGL              |                  | Write Recovery before Read                       |       | 0   |     | μs   |
| tQVVL              | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD, RY/BY# High | 2, 6  | 0   |     | ns   |

<sup>1.</sup> Read timing characteristics during erase and byte write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.

<sup>2.</sup> Sampled, not 100% tested.

<sup>3.</sup> Refer to Table 3 for valid AIN for byte write or block erasure.

<sup>4.</sup> Refer to Table 3 for valid D<sub>IN</sub> for byte write or block erasure.

<sup>5.</sup> The on-chip Write State Machine incorporates all byte write and block erase system functions and overhead of standard Intel flash memory, including byte program and verify (byte write) and block precondition, precondition verify, erase and erase verify (block erase).

<sup>6.</sup> Byte write and block erase durations are measured to completion (SR.7 = 1, RY/BY# =  $V_{OH}$ ).  $V_{PP}$  should be held at  $V_{PPH}$  until determination of byte write/block erase success (SR.3/4/5 = 0)



## **BLOCK ERASE AND BYTE WRITE PERFORMANCE** $V_{CC} = 3.3V$ to 0.3V, 5.0V $\pm 10\%$

| Dougnotou        | Natas | 2   |        |          |      |
|------------------|-------|-----|--------|----------|------|
| Parameter        | Notes | Min | Typ(1) | Max      | Unit |
| Block Erase Time | 2     |     | 2.0    | 12.5     | sec  |
| Block Write Time | 2     |     | 0.7    | 2.6      | sec  |
| Byte Write Time  |       |     | 8      | (Note 3) | μs   |

- 1. 25°C, 12.0 V<sub>PP</sub>.
- 2. Excludes System-Level Overhead.
- 3. Contact your Intel representative for information on the maximum byte write specification.





Figure 11. AC Waveform for Write Operations



#### ALTERNATIVE CE#-CONTROLLED WRITES $V_{CC} = 3.3V \pm 0.3V, 5.0V \pm 10\%$

| Versions           |                  |                                                  | 28F008SA-L200 |     | Unit |       |  |
|--------------------|------------------|--------------------------------------------------|---------------|-----|------|-------|--|
| Symi               | bol              | Parameter                                        | Notes         | Min | Max  | Offic |  |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                                 |               | 200 |      | ns    |  |
| t <sub>PHEL</sub>  | tps              | RP# High Recovery to CE# Going Low               | 2             | 1   |      | μs    |  |
| twlel              | t <sub>WS</sub>  | WE# Setup to CE# Going Low                       |               | 0   |      | ns    |  |
| t <sub>ELEH</sub>  | t <sub>CP</sub>  | CE# Pulse Width                                  |               | 70  |      | ns    |  |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE# Going High          | 2             | 100 |      | ns    |  |
| t <sub>AVEH</sub>  | t <sub>AS</sub>  | Address Setup to CE# Going High                  | 3             | 60  |      | ns    |  |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to CE# Going High                     | 4             | 60  |      | ns    |  |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from CE# High                          |               | 5   |      | ns    |  |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold from CE# High                       |               | 5   |      | ns    |  |
| tEHWH              | t <sub>WH</sub>  | WE# Hold from CE# High                           |               | 0   |      | ns    |  |
| tEHEL              | t <sub>EPH</sub> | CE# Pulse Width High                             |               | 25  |      | ns    |  |
| t <sub>EHRL</sub>  |                  | CE# High to RY/BY# Going Low                     |               |     | 100  | ns    |  |
| t <sub>EHQV1</sub> |                  | Duration of Byte Write Operation                 | 5             | 6   |      | μs    |  |
| t <sub>EHQV2</sub> |                  | Duration of Block Erase Operation                | 5             | 0.3 |      | sec   |  |
| t <sub>EHGL</sub>  |                  | Write Recovery before Read                       |               | 0   |      | μs    |  |
| tavvl              | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD, RY/BY# High | 2, 5          | 0   |      | ns    |  |

#### NOTES:

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE#. In systems where CE# defines the write pulsewidth (within a longer WE# timing waveform), all setup, hold and inactive WE# times should be measured relative to the CE# waveform.

<sup>2.</sup> Sampled, not 100% tested.

Refer to Table 3 for valid A<sub>IN</sub> for byte write or block erasure.
 Refer to Table 3 for valid D<sub>IN</sub> for byte write or block erasure.
 Byte write and block erase durations are measured to completion (SR.7 = 1, RY/BY# = V<sub>OH</sub>). V<sub>PP</sub> should be held at V<sub>PPH</sub> until determination of byte write/block erase success (SR.3/4/5 = 0)







#### ORDERING INFORMATION



#### **ADDITIONAL INFORMATION**

|        | 28F008SA Datasheet                   | Order<br>Number<br>290429 |
|--------|--------------------------------------|---------------------------|
| AP-359 | "28F008SA Hardware Interfacing"      | 292094                    |
| AP-360 | "25F008SA Software Drivers"          | 292095                    |
| AP-364 | "28F008SA Automation and Algorithms" | 292099                    |
| ER-27  | "The Intel 28F008SA Flash Memory"    | 294011                    |
| ER-28  | "ETOX III Flash Memory Technology"   | 290412                    |

#### **REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                                   |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 002    | Modified Erase Suspend Flowchart Lowered V <sub>LKO</sub> from <b>2.2V</b> to <b>2.0V</b> Combined V <sub>PP</sub> Standby Current and V <sub>PP</sub> Read Current into One V <sub>PP</sub> Standby Current Spec. with Two Test Conditions (DC Characteristics Table) Removed —250 Speed Bin |  |
| 003    | $\overline{PWD}$ renamed to RP# for JEDEC standardization compatibility. Changed I <sub>PPS</sub> standby current specifications from $\pm$ 10 $\mu$ A to $\pm$ 15 $\mu$ A in DC Characteristics tables.                                                                                      |  |
| 004    | Changed $I_{CCR}$ test condition from $f=8$ MHz to $f=5$ MHz Changed $I_{CCS}$ Max spec. from 50 $\mu$ A to 2.0 mA Added $I_{PPR}$ spec. Corrected $I_{PPS}$ spec. typo                                                                                                                       |  |
|        | Added $V_{OHZ}$ (Output High Voltage—CMOS) spec. Changed Operating Temp range (read) from 0°C–70°C to $-20$ °C–70°C. Changed $V_{CC}$ range from 3.3V $\pm$ 0.3V to 3.15V–3.6V for Program/Erase. Added Byte Write Time spec.                                                                 |  |

intel<sub>®</sub>

**AP-607** 

# APPLICATION NOTE

# Multi-Site Layout Planning with Intel's FlashFile<sup>TM</sup> Components, Including ROM Compatibility

BILAL QURESHI
APPLICATIONS ENGINEER
SALIM B. FEDEL
SENIOR APPLICATIONS ENGINEER

November 1994

# MULTI-SITE LAYOUT PLANNING WITH INTEL'S FlashFile™ COMPONENTS, INCLUDING ROM COMPATIBILITY

| CONTENTS                                                                                             | PAGE          | CONTENTS                                                                            | PAGE         |
|------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------|--------------|
| <b>1.0 INTRODUCTION</b>                                                                              | 3-506         | 4.7 Compatible Layout for L from Two 8-Mbit (TSOP F to One 16-Mbit (SSOP Packaging) | Packaging)   |
| Compatibility                                                                                        | 3-506         | 4.8 Serpentine Layout for 8<br>FlashFile Component Us                               | -Mbit<br>ing |
| 3.0 AVAILABLE PACKAGES                                                                               |               | Standard and Reverse 40 TSOP Pinout                                                 |              |
| 4.1 Compatible Layout for Upgrac<br>from Two 8-Mbit to One 16-Mbi                                    | ling          | 4.9 Compatible Layout for United Fight 8-Mbit to Two FlashFile Components .         | 32-Mbit      |
| FlashFile Component 4.2 Compatible Layout for Intel's 16-Mbit FlashFile Component t 16-Mbit ROM Chip |               | 4.10 Compatible Layout for from 16-Mbit (TSOP) to 1 (SSOP)                          | 6-Mbit       |
| 4.3 Compact Layout for Intel's 16 FlashFile Component Using Standard 56-Lead TSOP Pinou              | -Mbit         | 5.0 DECOUPLING  6.0 GENERAL GUIDELINES A METHODOLOGY FOR DES                        | AND          |
| 4.4 Compatible Layout for Upgrac<br>from Four 8-Mbit to Two 16-Mb<br>FlashFile Components            | it -          | COMPATIBLE/COMPACT                                                                  |              |
| 4.5 Compatible Layout for Upgrad                                                                     | ding          | 7.0 AVAILABILITY OF FILES                                                           | 3-511        |
| FlashFile Component                                                                                  |               | 8.0 SUMMARY                                                                         | 3-516        |
| 4.6 Compatible Layout for Upgrace from Two 8-Mbit (PSOP Package)                                     | ding<br>ging) | 9.0 ADDITIONAL INFORMAT                                                             | 'ION 3-516   |
| to One 16-Mbit (SSOP<br>Packaging)                                                                   | ,             | APPENDIX A. FIGURES                                                                 | 3-517        |



#### 1.0 INTRODUCTION

With the availability of the 28F016SA/SV and the DD28F032SA, Intel offers a complete FlashFile<sup>TM</sup> memory family of components. Available in 8-, 16- and 32-Mbit capacities, these components offer flash solutions for applications ranging from mobile computing and communications to embedded code/data storage flash memory systems.

This application note covers the area of designing compatible and/or compact PCB layouts for FlashFile components (see Figure 1 for example). In addition to flexible layouts, flash-to-ROM compatible solutions are provided.

#### 2.0 PINOUT OPTIONS

28F008SA is Whereas the 8-bit wide, the 28F016SA/SV and DD28F032SA are high-performance, 16-bit wide FlashFile components, offering a user-configurable bus width. Hence, an additional eight I/O pins are on the 28F016SA/SV and DD28F032SA. Furthermore, the implementation of additional features such as write protect, block locking and user-selectable 3.3V and 5.0V operation require control pins for these functions. Additionally, the DD28F032SA has three chip enable pins, compared to two on the 28F016SA/SV, and one on the 28F008SA. In summary, the optimization of the 28F016SA/SV and the DD28F032SA architecture, which achieves high write performance, results in a different pinout configuration from the 28F008SA.



Figure 1. Two Layer Solution for Upgrading from Two 28F008SA to One 28F016SA/SV, FlashFile Component (x8 Mode)

### 2.1 28F016SA to 28F016SV Pinout Compatibility

The SmartVoltage 16-Mbit 28F016SV is fully pinout-compatible with the 28F016SA. Both SmartVoltage 16-Mbit FlashFile Memory devices use a 56-Lead TSOP and SSOP packages.

The 28F016SA uses the 3/5 # pin (pin 1) to configure the flash memory for operation at 3.3V or 5.0V V<sub>CC</sub>. The 28F016SV uses an internal detector connected to the V<sub>CC</sub> pin to accomplish this same function. The 3/5 # pin is no longer needed and pin 1 has been renamed NC (No Connect), therefore preserving compatibility between the two products. All layouts derived for 28F016SA are 100% compatible with 28F016SV, and can be used with no further modifications.

#### 3.0 AVAILABLE PACKAGES

The 28F008SA is offered in two packages—the 40-Lead Thin Small Outline Packaging (TSOP), both Standard and Reverse pinout (Figure 2), and the 44-Lead Plastic Small Outline Package (PSOP) (Figure 3). The use of Standard and Reverse TSOP packages arranged in a serpentine layout results in an optimum array density for the 28F008SA (see Section 4.8). The 28F016SA/SV and DD28F032SA are available in Standard 56-Lead TSOP package (see Figure 4). As shown in the examples, the same high density compared to a serpentine layout is achievable with the use of Standard 56-Lead TSOPs arranged in an upright position. The 28F016SA/SV are also available in 56-Lead Shrink Small Outline Package (SSOP) packaging (refer to Figure 5). The 16-Mbit ROM chip used, comes in Standard 44-Lead PSOP and 44-Lead TSOP packages, as shown in Figures 6 and 7, respectively.

#### 4.0 PCB LAYOUTS

Very high-density layouts have been made possible by using Intel's advanced PCMCIA layout specifications. All layouts considered use from two to three layers. Since power and ground are generally connected to their respective planes, V<sub>CC</sub> and GND pins have been left unconnected.

Solutions are designed using the "PADS" software by Viewlogic Systems, Inc. Of course, the Gerber files generated are industry-standard and can be used on any major PCB layout tool.



Table 1 provides a list of layouts derived along with diagrams and relevant information. For the schematics of these cases, see Section 6.0.

### 4.1 Compatible Layout for Upgrading from Two 8-Mbit to One 16-Mbit FlashFile Component

This layout deals with two 28F008SAs upgraded to one 28F016SA/SV in 8-bit and 16-bit modes. Two layers are used, with both the 28F008SAs and the 28F016SA/SV residing on layer 1. Figures 8-10 show x16 mode layout diagrams (for x8 mode, see Section 6.0)

Pins CE<sub>0</sub>#, BYTE#, 3/5# (28F016SA only) and WP# have been left unconnected. CE<sub>0</sub># and BYTE# should be connected to the ground plane. In x8 mode, BYTE# pin is grounded, while in x16 mode, it is connected to V<sub>CC</sub>. Connection of 3/5# (28F016SA only) and WP# is dependent on system configuration. Consult Intel's 28F016SA/SV datasheets for complete description of these pins (order numbers 290489 and 290528, respectively).

In x8 mode layout, A<sub>20</sub> connects to CE# of the upper 8 Mbit. This is a savings of an extra address line.

The enabling of the 28F016SA/SV can either be done directly from the system bus through a decoder or by ANDing the 8-Mbit CE#s and connecting output to CE<sub>1</sub># (for schematics see file 2t8xt10h.sch (x16 mode) and 2t8t16oh.sch (x8 mode) in Section 6.0). Of course, the final implementation is dependent on the system designer's preference.

Important dimensions are given below (for both x8 and x16 modes):

| Feature                | Dimension                               |  |
|------------------------|-----------------------------------------|--|
| Total Layout Area      | 0.709" sq.<br>(457.28 mm <sup>2</sup> ) |  |
| X, Y                   | 0.836" , 0.848"<br>(21.23 mm, 21.54 mm) |  |
| Trace Width            | 0.005" (0.127 mm)                       |  |
| Via Size               | 0.025" (0.635 mm)                       |  |
| Trace to Trace Spacing | 0.005" (0.127 mm)                       |  |

Table 1. PCB Layout Diagrams and Reference Information

| Case                                                                                                                                  | Section |
|---------------------------------------------------------------------------------------------------------------------------------------|---------|
| Compatible Layout for Upgrading from Two 8-Mbit (TSOP) to One 16-Mbit (TSOP) FlashFile Component (Both x8 and x16 Cases Considered)   | 4.1     |
| Compatible Layout for Intel's 16-Mbit (TSOP) FlashFile Component to 16-Mbit ROM Chip (PSOP, TSOP)                                     | 4.2     |
| Compact Layout for Intel's 16-Mbit FlashFile Component Using Standard 56-Lead TSOP Pinout                                             | 4.3     |
| Compatible Layout for Upgrading from Four 8-Mbit (TSOP) to Two 16-Mbit (TSOP) FlashFile Components (Both x8 and x16 Cases Considered) | 4.4     |
| Compatible Layout for Upgrading from Four 8-Mbit (TSOP) to One 32-Mbit (TSOP) FlashFile Component (Both x8 and x16 Cases Considered)  | 4.5     |
| Compatible Layout for Upgrading from Two 8-Mbit (PSOP) to One 16-Mbit (SSOP) (Both x8 and x16 Cases Considered)                       | 4.6     |
| Compatible Layout for Upgrading from Two 8-Mbit (TSOP) to One 16-Mbit (SSOP) (Both x8 and x16 Cases Considered)                       | 4.7     |
| Serpentine Layout for 8-Mbit FlashFile Component using Standard and Reverse 40-Lead TSOP Pinout                                       | 4.8     |
| Compatible Layout for Upgrading from Eight 8-Mbit (TSOP) to Two 32-Mbit (TSOP) FlashFile Components                                   | 4.9     |
| Compatible Layout for Upgrading from 16-Mbit (TSOP) to 16-Mbit (SSOP)                                                                 | 4.10    |



#### 4.2 Compatible Layout for Intel's 16-Mbit FlashFile Component to 16-Mbit ROM Chip

Three cases of layout are considered:

- 1. 28F016SA (56-Lead TSOP Package) to 16-Mbit ROM (44-Lead TSOP Package) on the same side of the board (see Figures 11-13).
- Layout with components (56-Lead TSOP 28F016SA to 44-Lead PSOP 16-Mbit ROM) on same side of the board (see Figures 14-16).
- Chips (56-Lead TSOP 28F016SA to 44-Lead PSOP 16-Mbit ROM) on opposite sides of the board (see Section 6.0 for layout files).

All three cases use two layers.

Pins  $CE_0\#$ , WE#, 3/5#, RP#, WP# are left unconnected. With the exception of  $CE_0\#$  (which needs to be grounded), connection of pins depends on the system design parameters.

Since pin  $D_{15}/A_{-1}$  acts as the 16th line of data bus during x16 operations, and the lowest address bit during x8 operations, it is connected to both  $A_0$  and  $D_{15}$  pins on the 16-Mbit component.

Pins 29 and 30 (both NC) of 28F016SA overlap with the pin 37 (A<sub>13</sub>) of 16-Mbit ROM in the same side of board layout (see Figures 14-16). From a manufacturing point of view, solder paste stencil has to be optimized for appropriate volume of solder. This ensures proper spacing between adjacent pins.

Important dimensions are given below:

28F016SA (56-Lead TSOP) to 16-Mbit ROM (44-Lead TSOP) same side:

| Feature                | Dimension                            |  |
|------------------------|--------------------------------------|--|
| Total Layout Area      | 0.63" sq. (405.8 mm <sup>2</sup> )   |  |
| X, Y                   | 0.84" , 0.75"<br>(21.3 mm, 19.05 mm) |  |
| Trace Width            | 0.005" (0.127 mm)                    |  |
| Via Size               | 0.025" (0.635 mm)                    |  |
| Trace to Trace Spacing | 0.005" (0.127 mm)                    |  |

28F016SA (56-Lead TSOP) to 16-Mbit ROM (44-Lead PSOP) same side:

For same side of the board:

| Feature                | Dimension                             |  |
|------------------------|---------------------------------------|--|
| Total Layout Area      | 0.587" sq. (379.3 mm <sup>2</sup> )   |  |
| X, Y                   | 0.524" , 1.12"<br>(13.31 mm, 28.5 mm) |  |
| Trace Width            | 0.005" (0.127 mm)                     |  |
| Via Size               | 0.025" (0.635 mm)                     |  |
| Trace to Trace Spacing | 0.005" (0.127 mm)                     |  |

28F016SA (56-Lead TSOP) to 16-Mbit ROM (44-Lead PSOP) opposite side:

| Feature                | Dimension                               |
|------------------------|-----------------------------------------|
| Total Layout Area      | 0.582" sq.<br>(375.34 mm <sup>2</sup> ) |
| X, Y                   | 0.524", 1.11"<br>(13.31 mm, 28.20 mm)   |
| Trace Width            | 0.006" (0.1524 mm)                      |
| Via Size               | 0.04" (1.016 mm)                        |
| Trace to Trace Spacing | 0.006" (0.1524 mm)                      |

### 4.3 Compact Layout for Intel's 16-Mbit FlashFile Component Using Standard 56-Lead TSOP Pinout

Highly-dense flash chip array as compact as the serpentine layout of the 28F008SA is achievable with Standard 56-Lead TSOP package using three layers (see Figures 17-20). Additionally, power and ground can be routed on layer 1.

Important dimensions are given below:

| Feature                | Dimension                              |  |
|------------------------|----------------------------------------|--|
| Total Layout Area      | 2.015" sq. (1300 mm <sup>2</sup> )     |  |
| X, Y                   | 1.736" , 1.161"<br>(44.1 mm, 29.49 mm) |  |
| Trace Width            | 0.003" 0.0762 mm)                      |  |
| Via Size               | 0.025" (0.635)                         |  |
| Trace to Trace Spacing | 0.003" (0.0762 mm)                     |  |
| Minimum Annular Ring   | 0.01" (0.254 mm)                       |  |



### 4.4 Compatible Layout for Upgrading from Four 8-Mbit to Two 16-Mbit FlashFile Components

This section describes the layout solution for four 28F008SA to two 28F016SA/SV FlashFile components in x8 and x16 modes. Two layers are used to achieve the desired compactness. Solution is obtained using layout discussed in Section 4.1 twice (see Section 6.0 for layout files).

Important dimensions are given below (for both x8 and x16 modes):

| Feature                | Dimension                             |
|------------------------|---------------------------------------|
| Total Layout Area      | 1.547" sq. (998 mm <sup>2</sup> )     |
| X, Y                   | 1.75", 0.884"<br>(44.45 mm, 22.45 mm) |
| Trace Width            | 0.005" (0.127 mm)                     |
| Via Size               | 0.025" (0.635 mm)                     |
| Trace to Trace Spacing | 0.005" (0.127 mm)                     |

### 4.5 Compatible Layout for Upgrading from Four 8-Mbit to One 32-Mbit FlashFile Component

Compact layout for upgrading from four 28F008SA to one DD28F032SA FlashFile component in x8 and x16 modes is considered in this section (see Section 6.0 for layout files). Two layers are used.

Important dimensions are given below (for both x8 and x16 modes):

| Feature                | Dimension                            |
|------------------------|--------------------------------------|
| Total Layout Area      | 1.48" sq. (956 mm <sup>2</sup> )     |
| X, Y                   | 1.75", 0.847"<br>(44.45 mm, 21.5 mm) |
| Trace Width            | 0.005" (0.127 mm)                    |
| Via Size               | 0.025" (0.635 mm)                    |
| Trace to Trace Spacing | 0.005" (0.127 mm)                    |

### 4.6 Compatible Layout for Upgrading from Two 8-Mbit (PSOP Packaging) to One 16-Mbit (SSOP Packaging)

This layout deals with two 28F008SA (in PSOP packaging) upgraded to one 28F016SA/SV (in SSOP packaging) in 8-bit and 16-bit modes. Two layers are used, with the 28F008SAs on layer 1 and the 28F016SA/SV residing on layer 2 (see Section 6.0 for layout files).

For unconnected pin information and details concerning enabling of the chips, consult Section 4.1 (also see schematic file 2t8t16h.sch listed in Section 6.0).

Important dimensions are given below (for both x8 and x16 modes):

| Feature                | Dimension                             |
|------------------------|---------------------------------------|
| Total Layout Area      | 1.5" sq. (969 mm²)                    |
| X, Y                   | 1.341", 1.12"<br>(34.06 mm, 28.45 mm) |
| Trace Width            | 0.005" (0.127 mm)                     |
| Via Size               | 0.025" (0.635 mm)                     |
| Trace to Trace Spacing | 0.005" (0.127 mm)                     |

### 4.7 Compatible Layout for Upgrading from Two 8-Mbit (TSOP Packaging) to One 16-Mbit (SSOP Packaging)

This layout deals with two 28F008SA (TSOP packaging) to one 28F016SA/SV (SSOP package) in 8-bit and 16-bit modes. Two layers are used, with the 28F008SAs and the 28F016SA on opposite sides of the board (see Section 6.0 for layout files).

For unconnected pin information and details concerning enabling of the chip, consult Section 4.1.



Important dimensions are given below (for both x8 and x16 modes):

| Feature                | Dimension                            |
|------------------------|--------------------------------------|
| Total Layout Area      | 0.786" sq. (507 mm <sup>2</sup> )    |
| X, Y                   | 0.836", 0.94"<br>(21.23 mm, 23.9 mm) |
| Trace Width            | 0.005" (0.127 mm)                    |
| Via Size               | 0.025" (0.635 mm)                    |
| Trace to Trace Spacing | 0.005" (0.127 mm)                    |

# 4.8 Serpentine Layout for 8-Mbit FlashFile Component Using Standard and Reverse 40-Lead TSOP Pinout

This section describes an 8-Mbyte flash memory array using TSOP packaged 28F008SAs in Standard and Reverse configurations (see section 6.0 for layout files). A layout like this is used in Intel's Series 2 flash memory cards and provides optimum array density for available board space. Additionally, two layers are used.

Component RY/BY#s and CE#s are left unconnected.

Important dimensions are given below:

| Feature                | Dimension                           |
|------------------------|-------------------------------------|
| Total Layout Area      | 3.06" sq. (1974 mm <sup>2</sup> )   |
| X, Y                   | 1.7" , 1.8"<br>(43.18 mm, 45.72 mm) |
| Trace Width            | 0.005" (0.127 mm)                   |
| Via Size               | 0.025" (0.635 mm)                   |
| Trace to Trace Spacing | 0.005" (0.127 mm)                   |

### 4.9 Compatible Layout for Upgrading from Eight 8-Mbit to Two 32-Mbit FlashFile Components

The serpentine layout described in Section 4.8, is used in this solution with slight modifications. Besides performance increase, saving of more than twice the PCB area are achievable when upgrading from 28F008SA to DD28F032SA (see Section 6.0 for layout files). The layout uses two layers.

Important dimensions are given below:

| Feature                | Dimension                         |
|------------------------|-----------------------------------|
| Total Layout Area      | 3.47" sq. (2240 mm²)              |
| X, Y                   | 1.93" , 1.8"<br>(49 mm, 45.72 mm) |
| Trace Width            | 0.005" (0.127 mm)                 |
| Via Size               | 0.025" (0.635 mm)                 |
| Trace to Trace Spacing | 0.005" (0.127 mm)                 |

### 4.10 Compatible Layout for Upgrading from 16-Mbit (TSOP to 16-Mbit (SSOP)

This layout enables easy upgrade from 56-TSOP package to 56-SSOP package. With the exception of NC pins, all pins are connected between the two packages. The layout uses two layers.

Important dimensions are given below:

| Feature                | Dimension                            |
|------------------------|--------------------------------------|
| Total Layout Area      | 0.953" sq. (615 mm <sup>2</sup> )    |
| X, Y                   | 1.49", 0.64"<br>(37.85 mm, 16.25 mm) |
| Trace Width            | 0.005" (0.127 mm)                    |
| Via Size               | 0.025" (0.635 mm)                    |
| Trace to Trace Spacing | 0.005" (0.127 mm)                    |

#### 5.0 DECOUPLING

To eliminate voltage variations, and thus insuring optimum performance in a high speed environment, use of DECOUPLING capacitors is recommended for FlashFile components. Both main and erase/write power supplies need to be decoupled against DC drifts and switching transients "noise."

For FlashFile components, a  $0.1~\mu\text{F}$ , or greater, multilayer ceramic capacitor per device is recommended. Additional suggestions to obtain good decoupling performance include:

 The lead length and bond lines (device to capacitor to ground) must be kept to a minimum, since they are a major source of inductance.



To increase path numbers (gridding) for reduced inductance and more effective surge-current availability, use one capacitor per chip. This also helps in reducing the lead length and bond lines.

### 6.0 GENERAL GUIDELINES AND METHODOLOGY FOR DESIGNING COMPATIBLE/COMPACT LAYOUT

Much effort has been made to incorporate most of the common layout combinations. However, for cases not considered here, a set of general guidelines follow to assist in developing solutions. Some of the key points are:

- 1. Select packages to use.
- Develop part decals based on dimensions provided by respective vendors. Leave enough pads room to allow for manufacturing tolerances.
- Select the optimum placement of part decals after trying different combinations.
- 4. To minimize manufacturing cost, use thick tracks (0.005 inches minimum).
- 5. Keep via count to a minimum.
- Use largest vias permitted by the area constraints and process.
- To reduce signal attenuation and noise, avoid 90° bends in the track routing (instead, use two 45° bends).
- 8. Use separate planes for ground and power. If limited by number of layers, use thick tracks, two to three times wider than signals track width.

#### 7.0 AVAILABILITY OF FILES

Due to space constraints, the layout diagrams and accompanying schematics for all the cases *are not* included in this application note. However, they are available through Intel's Bulletin Board Service (BBS) under the FlashFile technology area. The number to dial is:

North America and Japan<sup>(1)</sup> 916-356-3600 Europe +44-793-496340 As mentioned before, Gerber files are generated using "PADS" software by Viewlogic Systems, Inc. However, OrCAD® package is used for schematic entry.

Each layout case considered consists of a minimum of four Gerber files (Layer 1, Layer 2, Soldermask 1 and Silkscreen 1) and one schematic file. Additional layers or schematic files might be present in some cases (see Table 2 for filename conventions used).

**Table 2. Filename Conventions** 

| Filename            | Convention                 |
|---------------------|----------------------------|
| Filenamea.*         | Layer 1 (Gerber File)      |
| Filenameb.*         | Layer 2 (Gerber File)      |
| Filenamec.*         | Layer 3 (Gerber File)      |
| Filenames.*         | Silkscreen 1 (Gerber File) |
| Filenamet.*         | Silkscreen 2 (Gerber File) |
| <i>Filename</i> m.* | Soldermask 1 (Gerber File) |
| <i>Filename</i> n.* | Soldermask 2 (Gerber File) |
| Filename?h.*        | Page 1 (Schematic File)    |
| Filenamei.*         | Page 2 (Schematic File)    |



<sup>&</sup>lt;sup>1</sup> When calling from Japan, add "01" before the number listed above.



The following is a complete list of files present on the BBS:

#### **Index of Layouts/Schematics**

| File Name    | Description                      | Relevant Section |
|--------------|----------------------------------|------------------|
| 2t8xt16a.pho | Layout and schematic files for   | 4.1              |
| 2t8xt16b.pho | "two 8-Mbit (TSOP) to one        | 4.1              |
| 2t8xt16m.pho | 16-Mbit (TSOP) FlashFile         | 4.1              |
| 2t8xt16s.pho | component" in x16 mode.          | `4.1             |
| 2t8xt16h.sch |                                  | 4.1              |
| 2t8xt1oh.sch |                                  | 4.1              |
| 2t8t16a.pho  | Layout and schematic files for   | 4.1              |
| 2t8t16b.pho  | "two 8-Mbit (TSOP) to one        | 4.1              |
| 2t8t16m.pho  | 16-Mbit (TSOP) FlashFile         | 4.1              |
| 2t8t16s.pho  | component" in x8 mode.           | 4.1              |
| 2t8t16h.sch  | 4                                | 4.1              |
| 2t8t16oh.sch |                                  | 4.1              |
| t16t16sa.pho | Layout and schematic files for   | 4.2              |
| t16t16sb.pho | "16-Mbit (TSOP) FlashFile        | 4.2              |
| t16t16sm.pho | component to 16-Mbit ROM         | 4.2              |
| t16t16ss.pho | (TSOP)" on the same side of the  | 4.2              |
| t16t16sh.sch | board.                           | 4.2              |
| t16r16sa.pho | Layout and schematic files for   | 4.2              |
| t16r16sb.pho | "16-Mbit (TSOP) FlashFile        | 4.2              |
| t16r16sm.pho | component to 16-Mbit ROM         | 4.2              |
| t16r16ss.pho | (PSOP)" on the same side of the  | 4.2              |
| t16r16sh.sch | board.                           | 4.2              |
| t16r16oa.pho | Layout and schematic files for   | 4.2              |
| t16r16ob.pho | "16-Mbit (TSOP) FlashFile        | 4.2              |
| t16r16om.pho | component to 16-Mbit ROM         | 4.2              |
| t16r16os.pho | (PSOP)" on the opposite sides of | 4.2              |
| t16r16on.pho | the board.                       | 4.2              |
| t16r16ot.pho | . *                              | 4.2              |
| t16r16oh.sch |                                  | 4.2              |

#### NOTE:

Other examples may be added over time.



#### Index of Layouts/Schematics, Contd.

| File Name    | Description                    | Relevant Section |
|--------------|--------------------------------|------------------|
| 4t16a.pho    | Layout and schematic files for | 4.3              |
| 4t16b.pho    | "compact 16-Mbit (TSOP)        | 4.3              |
| 4t16c.pho    | FlashFile component layout"    | 4.3              |
| 4t16m.pho    |                                | 4.3              |
| 4t16s.pho    | ·                              | 4.3              |
| 4t16h.sch    | ·                              | 4.3              |
| 4t8xt16a.pho | Layout and schematic files for | 4.4              |
| 4t8xt16b.pho | "four 8-Mbit (TSOP) to two     | 4.4              |
| 4t8xt16m.pho | 16-Mbit (TSOP) FlashFile       | 4.4              |
| 4t8xt16s.pho | components" in x16 mode.       | 4.4              |
| 4t8xt16h.sch |                                | 4.4              |
| 4t8xt16i.sch |                                | 4.4              |
| 4t82t16a.pho | Layout and schematic files for | 4.4              |
| 4t82t16b.pho | "four 8-Mbit (TSOP) to two     | 4.4              |
| 4t82t16m.pho | 16-Mbit (TSOP) FlashFile       | 4.4              |
| 4t82t16s.pho | components'' in x8 mode.       | 4.4              |
| 4t82t16h.sch | ·                              | 4.4              |
| 4t82t16i.sch |                                | 4.4              |
| 4t8xt32a.pho | Layout and schematic files for | 4.5              |
| 4t8xt32b.pho | "four 8-Mbit (TSOP) to one     | 4.5              |
| 4t8xt32m.pho | 32-Mbit (TSOP) FlashFile       | 4.5              |
| 4t8xt32s.pho | component" in x16 mode.        | 4.5              |
| 4t8xt32h.sch |                                | 4.5              |
| 4t8xt32i.sch |                                | 4.5              |
| 4t8t32a.pho  | Layout and schematic files for | 4.5              |
| 4t8t32b.pho  | "four 8-Mbit (TSOP) to one     | 4.5              |
| 4t8t32m.pho  | 32-Mbit (TSOP) FlashFile       | 4.5              |
| 4t8t32s.pho  | component" in x8 mode.         | 4.5              |
| 4t8t32h.sch  |                                | 4.5              |
| 4t8t32i.sch  |                                | 4.5              |

#### NOTE:

Other examples may be added over time.



#### Index of Layouts/Schematics, Contd.

| File Name    | Description                    | Relevant Section |
|--------------|--------------------------------|------------------|
| 2p8xs16a.pho | Layout and schematic files for | 4.6              |
| 2p8xs16b.pho | "two 8-Mbit (PSOP) to one      | 4.6              |
| 2p8xs16m.pho | 16-Mbit (SSOP) FlashFile       | 4.6              |
| 2p8xs16s.pho | component" in x16 mode.        | 4.6              |
| 2p8xs16n.pho |                                | 4.6              |
| 2p8xs16t.pho |                                | 4.6              |
| 2p8xs16h.sch |                                | 4.6              |
| 2p8s16a.pho  | Layout and schematic files for | 4.6              |
| 2p8s16b.pho  | "two 8-Mbit (PSOP) to one      | 4.6              |
| 2p8s16m.pho  | 16-Mbit (SSOP) FlashFile       | 4.6              |
| 2p8s16s.pho  | component" in x8 mode.         | 4.6              |
| 2p8s16n.pho  |                                | 4.6              |
| 2p8s16t.pho  |                                | 4.6              |
| 2p8s16h.sch  |                                | 4.6              |
| 2t8xs16a.pho | Layout and schematic files for | 4.7              |
| 2t8xs16b.pho | "two 8-Mbit (TSOP) to one      | 4.7              |
| 2t8xs16m.pho | 16-Mbit (SSOP) FlashFile       | 4.7              |
| 2t8xs16s.pho | component" in x16 mode.        | 4.7              |
| 2t8xs16n.pho |                                | 4.7              |
| 2t8xs16t.pho |                                | 4.7              |
| 2t8xs16h.sch |                                | 4.7              |
| 2t8s16a.pho  | Layout and schematic files for | 4.7              |
| 2t8s16b.pho  | "two 8-Mbit (TSOP) to one      | 4.7              |
| 2t8s16m.pho  | 16-Mbit (SSOP) FlashFile       | 4.7              |
| 2t8s16n.pho  | component" in x8 mode.         | 4.7              |
| 2t8s16s.pho  |                                | 4.7              |
| 2t8s16t.pho  |                                | 4.7              |
| 2t8s16h.sch  | ,                              | 4.7              |

#### NOTE:

Other examples may be added over time.



#### Index of Layouts/Schematics, Contd.

| File Name    | Description                    | Relevant Section |
|--------------|--------------------------------|------------------|
| 8t8a.pho     | Layout and schematic files for | 4.8              |
| 8t8b.pho     | "serpentine layout for 8-Mbit  | 4.8              |
| 8t8m.pho     | (TSOP) FlashFile component."   | 4.8              |
| 8t8s.pho     |                                | 4.8              |
| 8t8h.sch     |                                | 4.8              |
| 8t82t32a.pho | Layout and schematic files for | 4.9              |
| 8t82t32b.pho | "eight 8-Mbit (TSOP) to two    | 4.9              |
| 8t82t32m.pho | 32-Mbit (TSOP) FlashFile       | 4.9              |
| 8t82t32s.pho | components" in x8 mode.        | 4.9              |
| 8t82t32h.sch |                                | 4.9              |
| 8t82t32i.sch |                                | 4.9              |
| t16s16a.pho  | Layout and schematic files for | 4.10             |
| t16s16b.pho  | "one 16-Mbit (TSOP) to one     | 4.10             |
| t16s16m.pho  | 16-Mbit (SSOP) FlashFile       | 4.10             |
| t16s16s.pho  | component."                    | 4.10             |
| t16s16h.sch  |                                | 4.10             |

**NOTE:** Other examples may be added over time.



#### 8.0 SUMMARY

This application note summarizes highly-dense layout solutions, based on the design constraints such as compatibility and compactness. Different permutations of FlashFile components and 16-Mbit ROM are provided. Furthermore, compact layouts for 16-Mbit array are designed and found to be comparable in PCB layout area to the serpentine layout. This application note, however, *does not* deal with software changes associated with compatibility issues. See AP-375, "Upgrade Considerations from the 28F008SA to the 28F016SA" and AP-393, "28F016SV Compatibility with 28F016SA" for more information on the subject.

#### 9.0 ADDITIONAL INFORMATION

For software upgrade and additional design information, consult the referenced documents listed below:

| Order Number | Document                                                                                           |
|--------------|----------------------------------------------------------------------------------------------------|
| 297372       | "28F016SA 16-Mbit FlashFile™ User's Manual"                                                        |
| 290490       | DD28F032SA Datasheet                                                                               |
| 290489       | 28F016SA Datasheet                                                                                 |
| 290528       | 28F016SV Datasheet                                                                                 |
| 290429       | 28F008SA 8-MB (1 MB x 8) FlashFile™ Memory Datasheet                                               |
| 292095       | AP-360, "28F008SA Software Drivers"                                                                |
| 292097       | AP-362, "Implementing Mobile PC Designs using High-Density FlashFile™ Components"                  |
| 292124       | AP-375, "Upgrade Considerations from the 28F008SA to the 28F016SA"                                 |
| 292126       | AP-377, "The 28F016SA Software Drivers"                                                            |
| 292127       | AP-378, "System Optimization using Enhanced Features of the 28F016SA"                              |
| 292144       | AP-393, "28F016SV Compatibility with 28F016SA"                                                     |
| 294011       | ER-27, "The Intel 28F008SA Flash Memory"                                                           |
| 294016       | ER-33, "ETOX™ IV Flash Memory Technology: Insight to Intel's Fourth Generation Process Innovation" |



### APPENDIX A FIGURES



Figure 2. 28F008SA Standard and Reverse 40-Lead TSOP Pinout Configuration





Figure 3. 28F008SA 44-Lead PSOP Pinout Configuration



Figure 4. 28F016SA, 28F016SV and DD28F032SA 56-Lead TSOP Pinout Configurations





Figure 5. 28F016SA/SV 56-Lead SSOP Pin Configuration





Figure 6. 16-Mbit ROM Chip 44-Lead PSOP Pinout Configuration



Figure 7. 16-Mbit ROM Chip 44-Lead TSOP Pinout Configuration





Figure 8. 4x Scale Topside Outline View of Two 28F008SAs to One 28F016SA/SV (x16 Mode)





Figure 9. 4x Scale Topside Trace View of Two 28F008SAs to One 28F016SA/SV (x16 Mode)





Figure 10. 4x Scale Bottom Side Trace View of Two 28F008SAs to One 28F016SA/SV (x16 Mode)





Figure 11. 3x Scale Top Side Outline View of One 28F016SA/SV (56-Lead TSOP) to One 16-Mbit ROM (44-Lead TSOP)



Figure 12. 3x Scale Top Side Trace View of *One 28F016SA/SV (56-Lead TSOP)*to One 16-Mbit ROM (44-Lead TSOP)





Figure 13. 3x Scale Bottom Side Trace View of One 28F016SA/SV (56-Lead TSOP) to One 16-Mbit ROM (44-Lead TSOP)





Figure 14. 3x Scale Top Side Outline View of One 28F016SA/SV (56-Lead TSOP) to One 16-Mbit ROM (44-Lead PSOP)





Figure 15. 3x Scale Top Side Trace View of *One 28F016SA/SV (56-Lead TSOP)* to *One 16-Mbit ROM (44-Lead PSOP)* 





Figure 16. 3x Scale Bottom Side Trace View of One 28F016SA/SV (56-Lead TSOP) to One 16-Mbit ROM (44-Lead PSOP)





Figure 17. 3x Scale Top Side Outline View of Four 28F016SA/SVs





Figure 18. 3x Scale Top Side Trace View of Four 28F016SA/SVs





Figure 19. 3x Scale Internal Layer View of Four 28F016SA/SVs



Figure 20. 3x Scale Bottom Side Trace View of Four 28F016SA/SVs

## APPLICATION NOTE

### 28F016SV Compatibility with 28F016SA

BRIAN DIPERT SENIOR TECHNICAL MARKETING ENGINEER

KEN MCKEE TECHNICAL MARKETING ENGINEER SUJAN KAMRAN TECHNICAL MARKETING ENGINEER

November 1994

3



#### 1.0 INTRODUCTION

This application note discusses compatibility between the 28F016SV and 28F016SA FlashFile<sup>TM</sup> memory components. It also offers recommendations for designing systems using the 28F016SA today, when future conversion to the 28F016SV is planned.

The 28F016SV is a member of Intel's second-generation 16-Mbit FlashFile component product family. It improves upon the 28F016SA in the following areas:

- SmartVoltage technology
  - Selectable 5.0V or 12.0V Vpp
- Faster read performance
- Higher Page Buffer write performance at 12.0V VPP
- Enhanced device feedback after writing the Upload Device Information command
- Enhanced 3.3V or 5.0V V<sub>CC</sub> detection
- Additional RY/BY# Configuration
  - Pulse-On-Write/Erase

#### 2.0 COMPATIBILITY

The 28F016SV and 28F016SA are both manufactured on Intel's fourth-generation 0.6 micron ETOXTM-IV process technology. This technology enables random access flash memory products with the highest read/write performance and lowest power consumption. ETOX flash memory technology also achieves very high quality and reliability.

The following sections discuss specific areas of compatibility between the 28F016SV and the 28F016SA. Please reference the documentation listed in the Additional Information section of this application note for a full description of these flash memory components.

#### 2.1 Pinout and Package

The 28F016SV is fully pinout backwards-compatible with the 28F016SA (see Figures 1 and 2). Both devices will be available in 56-lead TSOP and SSOP packages.



Figure 1. 28F016SV 56-Lead TSOP Pinout Compared to the 28F016SA and 28F032SA





Figure 2. 28F016SV 56-Lead SSOP Pinout Compared to the 28F016SA

The 28F016SA uses the 3/5# pin to configure the flash memory for operation at 3.3V or 5.0V  $V_{\rm CC}$ . The 28F016SV uses an internal detector connected to the  $V_{\rm CC}$  pin to accomplish this same function. The 3/5# pin is no longer needed on the 28F016SV and has been

renamed NC ("no connect"). This pin may be left driven to  $V_{IL}$  or  $V_{IH}$ , or may be left unconnected. Therefore, a design that uses the 28F016SA today can later convert to the 28F016SV and continue to drive the former 3/5# pin, eliminating costly system board redesigns.



#### 2.2 Bus Operations

The 28F016SV shares the same bus operations as the 28F016SA, and both flash memories operate identically in these operating modes.

#### 2.3 Command Definitions

The 28F016SV shares the same command set as the 28F016SA. All commands produce compatible internal operations for both flash memories.

The 28F016SV includes an additional RY/BY# mode, RY/BY# Pulse on Write/Erase, enabled as part of the RY/BY# Configuration (96H) command sequence. This mode was Reserved for Future Use on the 28F016SA.

The 28F016SV also enhances the device feedback after writing the Upload Device Information (99H) command sequence. It outputs not only the Device Revision Number (compatible with the 28F016SA), but the Device Proliferation Code and Device Configuration Code. See Section 2.5 for more information on these topics.

#### 2.4 Status Registers

The 28F016SV and 28F016SA both have a Compatible Status Register (CSR), Global Status Register (GSR) and 32 Block Status Registers (BSRs). Register address maps for both flash memories are identical.

#### **Compatible Status Register**

CSR bits 4\_7 have identical functions for both the 28F016SV and the 28F016SA. CSR bits 0\_2 are marked "reserved for future use" for both the 28F016SV and 28F016SA.

CSR bit 3 (Vpp Status) has been functionally enhanced on the 28F016SV, reflective of the ability to Data Write and Erase with  $V_{PP} = 5.0V \pm 10\% (V_{PPH1})$  or  $V_{PP} =$ 12.0V ±5% (VPPH2). See Section 2.7 for more information on 28F016SV Data Write and Erase. CSR.3 = "1" is defined as "Vpp Error" on the 28F016SV, versus "Vpp Low" on the 28F016SA. If Data Write or Erase is initiated with  $V_{PP} = V_{PPH2}$ , subsequent  $V_{PP}$  transitions above VPPH2(max) or below VPPH2(min) will, if detected, terminate the operation in progress and set CSR.3 to "1" (this functionality matches the 28F016SA). Additionally, if Data Write or Erase is initiated with  $V_{PP} = V_{PPH1}$ , subsequent  $V_{PP}$  transitions above V<sub>PPH1</sub>(max) or below V<sub>PPH1</sub>(min) will, if detected, also terminate the operation in progress and set CSR.3 to "1." See Table 1 for the 28F016SV's Compatibile Status Register.

#### Global Status Register

All GSR bits have identical functions for both the 28F016SV and the 28F016SA.

#### **Block Status Registers**

BSR bits 3-7 have identical functions for both the 28F016SV and the 28F016SA. BSR bit 0 is marked "reserved for future use" for both the 28F016SV and the 28F016SA.

BSR bit 2 ( $V_{\rm PP}$  Status) has been functionally enhanced on the 28F016SV compared to the 28F016SA. See the earlier description of CSR.3 for more information.

BSR bit 1, marked "reserved for future use" on the 28F016SA, is the  $V_{PP}$  Level bit on the 28F016SV. BSR.1 reflects the  $V_{PP}$  level applied to the 28F016SV ( $V_{PPH1} =$  "1,"  $V_{PPH2} =$  "0"). See Table 2 for the 28F016SV's Block Status Register.



#### Table 1. 28F016SV Compatible Status Register

| WSMS | ESS | ES | DWS | VPPS · | R | R | R |
|------|-----|----|-----|--------|---|---|---|
| 7    | 6   | 5  | 4   | 3      | 2 | 1 | 0 |

#### NOTES:

CSR.7 = WRITE STATE MACHINE STATUS

1 = Ready 0 = Busv The RY/BY# output or WSMS bit must be checked to determine completion of an operation (erase suspend, erase or data write) before the appropriate Status bit (ESS, ES or DWS) is checked for success.

CSR.6 = ERASE-SUSPEND STATUS

1 = Erase Suspended

0 = Erase In Progress/Completed

CSR.5 = ERASE STATUS

1 = Error In Block Erasure

0 = Successful Block Erase

CSR.4 = DATA-WRITE STATUS

1 = Error in Data Write

0 = Data Write Successful

 $CSR.3 = V_{PP} STATUS$ 

1 = V<sub>PP</sub> Error Detect, Operation Abort

 $0 = V_{PP} OK$ 

If DWS and ES are set to "1" during an erase attempt, an improper command sequence was entered. Clear the CSR and attempt the operation again.

The VPPS bit, unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM periodically interrogates V<sub>PP</sub>'s level only after the data-write or erase command sequences have been entered, and informs the system if it detects an invalid voltage. VPPS is not guaranteed to report accurate feedback between V<sub>PPLK</sub>(max) and V<sub>PPH1</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min) and above V<sub>PPH2</sub>(max).

CSR.2 - CSR.0 = RESERVED FOR FUTURE ENHANCEMENTS.

These bits are reserved for future use; mask them out when polling the CSR.



#### Table 2. 28F016SV Block Status Register

| BS | BLS | BOS | BOAS | QS | VPPS | VPPL | R |
|----|-----|-----|------|----|------|------|---|
| 7  | 6   | 5   | 4    | 3  | 2    | 1    | 0 |

#### BSR.7 = BLOCK STATUS

1 = Ready

0 = Busv

#### NOTES:

The RY/BY# output or BS bit must be checked to determine completion of an operation (block lock, suspend, erase or data write) before the appropriate Status bits (BOS or BLS) is checked for success.

#### BSR.6 = BLOCK-LOCK STATUS

1 = Block Unlocked for Write/Erase

0 = Block Locked for Write/Erase

#### BSR.5 = BLOCK OPERATION STATUS

1 = Operation Unsuccessful

0 = Operation Successful or Currently Running

#### BSR.4 = BLOCK OPERATION ABORT STATUS

1 = Operation Aborted

0 = Operation Not Aborted

#### MATRIX 5/4

0 0 = Operation Successful or Currently Running

The BOAS bit will not be set until GSR.7 = 1.

0 1 = Not a valid combination1 0 = Operation Unsuccessful

1 1 = Operation Aborted

Operation halted via abort command.

#### BSR.3 = QUEUE STATUS

1 = Queue Full

0 = Queue Available

#### $BSR.2 = V_{PP} STATUS$

1 = V<sub>PP</sub> Error Detect, Operation Abort

 $0 = V_{PP} OK$ 

#### $BSR.1 = V_{PP} LEVEL$

 $1 = V_{PP}$  detected at 5.0V  $\pm 10\%$  (4.5V - 5.5V)

 $0 = V_{PP}$  detected at 12.0V  $\pm 5\%$  (11.4V - 12.6V)

BSR.1 is not guaranteed to report accurate feedback between the V<sub>PPH1</sub> and V<sub>PPH2</sub> voltage ranges. Writes and erases with V<sub>PP</sub> between V<sub>PPLK</sub>(max) and V<sub>PPH2</sub>(min), between V<sub>PPH1</sub>(max) and V<sub>PPH2</sub>(min), and above V<sub>PPH2</sub>(max) produce spurious results and should not be attempted.

BSR.1 was a RESERVED bit on the 28F016SA.

#### BSR.0 = RESERVED FOR FUTURE ENHANCEMENTS

This bit is reserved for future use; mask it out when polling the BSR.



#### Table 3, 28F016SV Device Configuration Code

| R | R | R | R | R | RB2 | RB1 | RB0 |
|---|---|---|---|---|-----|-----|-----|
| 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |

NOTES:
DCC.2-DCC.0 = RY/BY# CONFIGURATION Undocumented combinations of F

(RB2-RB0)

001 = Level Mode (Default)

010 = Pulse-On-Write

011 = Pulse-On-Erase

100 = RY/BY# Disabled

101 = RY/BY# Pulse-on-Write/Erase

DCC.7-DCC.3 = RESERVED FOR FUTURE

**ENHANCEMENTS** 

Undocumented combinations of RB2-RB0 are reserved by Intel Corporation for future implementations and should not be used.

These bits are reserved for future use; mask them out when reading the Device Configuration Code. Set these bits to 0 when writing the desired RY/BY# configuration to the device.

#### 2.5 Device/Manufacturer IDs and Device Configuration Code

The 28F016SV shares the identical manufacturer and device identifiers as the 28F016SA, for full backwards-compatibility.

The 28F016SV retains the Device Revision Number of the 28F016SA, accessed via the Page Buffer after writing the Upload Device Information (99H) command sequence. The 28F016SV adds a Device Configuration Code, located at address 1EH in byte mode and address 0FH in word mode (lower 8 bits of 16-bit word), which allows system software to read the currently-configured 28F016SV RY/BY# mode. These data bits correspond to the bits written to the 28F016SV when configuring RY/BY# via the RY/BY Configuration (96H) command sequence. Unused bits of the Device Configuration Code are marked "reserved for future use" and should be masked out. See Table 3 for the 28F016SV's Device Configuration Code.

The 28F016SV also adds the Device Proliferation Code (01H), located at address 1FH in byte mode and address 0FH in word mode (upper 8 bits of 16-bit word). This code allows software identification of the 28F016SV versus the 28F016SA (described in Section 4.0).

#### 2.6 Flowcharts

All 28F016SV and 28F016SA flowcharts are identical.

#### 2.7 Vpp Voltage

The 28F016SV's  $V_{PP}$  Write/Erase voltage specifications offer the choice of either 5.0V  $\pm 10\%$  (4.5V-5.5V) or 12.0V  $\pm 5\%$  (11.4V-12.6V) operation during flash memory update.  $V_{PP} = 5.0V$  ( $V_{PPH1}$ ) minimizes required chip count in designs where a suitable 12.0V supply is not already required for other system circuitry.  $V_{PP} = 12.0V$  ( $V_{PPH2}$ ), on the other hand, provides significantly faster write and erase performance for applications that frequently alter flash memory contents, such as solid-state mass storage designs.

Tables 4-7 give write and erase specifications for the 28F016SV at  $V_{\rm CC}=3.3V/5.0V$  and at  $V_{\rm PP}=5.0V/12.0V$ . Performance numbers for erase and standard writes at 3.3V  $V_{\rm CC}/12.0V$   $V_{\rm PP}$  (Table 5) and 5.0V  $V_{\rm CC}/12.0V$   $V_{\rm PP}$  (Table 7) match those of the 28F016SA. Page Buffer writes are higher performance on the 28F016SV compared to the 28F016SA.



Table 4. Write/Erase Performance(3,4)  $V_{CC}=3.3V~\pm0.3V,~V_{PP}=5.0V~\pm0.5V,~T_{A}=0^{\circ}C~to~+70^{\circ}C$ 

| Parameter                   | Notes | Min | Typ(1) | Max | Unit | Test Conditions |
|-----------------------------|-------|-----|--------|-----|------|-----------------|
| Page Buffer Byte Write Time | 2     | TBD | 6.0    | TBD | μs   |                 |
| Page Buffer Word Write Time | 2     | TBD | 12.1   | TBD | μs   |                 |
| Byte Write Time             | 2     | TBD | 16.5   | TBD | μs   |                 |
| Word Write Time             | 2     | TBD | 24.0   | TBD | μs   |                 |
| Block Write Time            | 2     | TBD | - 1.1  | TBD | sec  | Byte Write Mode |
| Block Write Time            | 2     | TBD | 0.8    | TBD | sec  | Word Write Mode |
| Block Erase Time            | 2     | TBD | 1.4    | TBD | sec  |                 |
| Full Chip Erase Time        | 2     | TBD | 44.8   | TBD | sec  |                 |

Table 5. Write/Erase Performance(3,4)  $V_{CC}=3.3V~\pm0.3V,\,V_{PP}=12.0V~\pm0.6V,\,T_{A}=0^{\circ}C~to~+70^{\circ}C$ 

| Parameter                   | Notes | Min | Typ(1) | Max | Unit | Test Conditions |
|-----------------------------|-------|-----|--------|-----|------|-----------------|
| Page Buffer Byte Write Time | 2     | TBD | 2.2    | TBD | μs   |                 |
| Page Buffer Word Write Time | 2     | TBD | 4.4    | TBD | μs   | 1               |
| Word/Byte Write Time        | 2     | 5   | 9      | TBD | μs   |                 |
| Block Write Time            | 2     | TBD | 0.6    | 2.1 | sec  | Byte Write Mode |
| Block Write Time            | 2     | TBD | 0.3    | 1.0 | sec  | Word Write Mode |
| Block Erase Time            | 2     | 0.3 | 0.8    | 10  | sec  |                 |
| Full Chip Erase Time        | 2     | TBD | 25.6   | TBD | sec  |                 |



#### Table 6. Write/Erase Performance(3,4)

 $V_{CC}$  = 5.0V ±0.5V, 5.0V ±0.25V,  $V_{PP}$  = 5.0V ± 0.5V,  $T_{A}$  = 0°C to +70°C

| Parameter                   | Notes | Min | Typ(1) | Max | Unit | Test Conditions |
|-----------------------------|-------|-----|--------|-----|------|-----------------|
| Page Buffer Byte Write Time | 2     | TBD | 6.0    | TBD | μs   |                 |
| Page Buffer Word Write Time | 2     | TBD | 12.1   | TBD | μs   |                 |
| Byte Write Time             | 2     | TBD | 11     | TBD | μs   |                 |
| Word Write Time             | 2     | TBD | 16     | TBD | μs   |                 |
| Block Write Time            | 2     | TBD | 0.8    | TBD | sec  | Byte Write Mode |
| Block Write Time            | 2     | TBD | 0.6    | TBD | sec  | Word Write Mode |
| Block Erase Time            | 2     | TBD | 1.0    | TBD | sec  |                 |
| Full Chip Erase Time        | 2     | TBD | 32.0   | TBD | sec  |                 |

#### Table 7. Write/Erase Performance(3,4)

 $V_{CC} = 5.0V \pm 0.5V$ , 5.0V  $\pm 0.25V$ ,  $V_{PP} = 12.0V \pm 0.6V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Parameter                   | Notes | Min | Typ <sup>(1)</sup> | Max | Unit | Test Conditions |
|-----------------------------|-------|-----|--------------------|-----|------|-----------------|
| Page Buffer Byte Write Time | 2     | TBD | 2.1                | TBD | μs   |                 |
| Page Buffer Word Write Time | 2     | TBD | 4.1                | TBD | μs   |                 |
| Word Byte/Write Time        | 2     | 4.5 | 6                  | TBD | μs   |                 |
| Block Write Time            | 2     | TBD | 0.4                | 2.1 | sec  | Byte Write Mode |
| Block Write Time            | 2     | TBD | 0.2                | 1.0 | sec  | Word Write Mode |
| Block Erase Time            | 2     | 0.3 | 0.6                | 10  | sec  |                 |
| Full Chip Erase Time        | 2     | TBD | 19.2               | TBD | sec  |                 |

#### NOTES:

- 1. 25°C and nominal voltages.
- 2. Excludes system-level overhead.
- 3. These performance numbers are valid for all speed versions.
- 4. Sampled, not 100% tested. Guaranteed by design.

## 2.8 Other Voltage and Current Specifications

The 28F016SV's typical and maximum  $V_{CC}$  read and  $V_{CC}$  standby (CMOS levels) currents are both higher than those of the 28F016SA.

The 28F016SV's typical  $V_{CC}$  Deep Power-Down current is higher than that of the 28F016SA. The 28F016SV will also exhibit higher  $V_{CC}$  current "peaks" in deep power-down mode at 3.3V  $V_{CC}$ , compared to the 28F016SA.

The 28F016SV adds the  $V_{PPH1}$  ( $V_{PP}=5.0V$ ) write/erase voltage specification and  $V_{CC}$  and  $V_{PP}$  write and erase current specifications at  $V_{PP}=V_{PPH1}$ . Write/erase current specifications at  $V_{PP}=V_{PPH2}$  (12.0V) match those of the 28F016SA. The 28F016SV also lowers the  $V_{PPL}$  specification from 6.5V to 1.5V (to allow SmartVoltage operation) and renames this specification as  $V_{PPLK}$ , to signify the change. The 28F016SV's  $V_{CC}/V_{PP}$  erase suspend currents and  $V_{PP}$  read current ( $V_{PP}>V_{CC}$ ) are lower than those of the 28F016SA.

Tables 8 and 9 show added and revised (as compared to the 28F016SA) 28F016SV DC specifications.



# Table 8. 28F016SV Added/Revised DC Characteristics for 3.3V Operations $V_{CC}=3.3V~\pm0.3V,~T_A=0^{o}C~to~+70^{o}C$

| Symbol            | Parameter                                        | Min | Тур | Max | Unit | Test Condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------|--------------------------------------------------|-----|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Iccs              | V <sub>CC</sub> Standby Current                  |     | 70  | 130 | μΑ   | $\begin{array}{l} \text{V}_{CC} = \text{V}_{CC}\text{Max}, \\ \text{CE}_0\#, \text{CE}_1\#, \text{RP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{BYTE}\#, \text{WP}\# = \text{V}_{CC} \pm 0.2\text{V} \\ \text{or GND} \pm 0.2\text{V} \end{array}$                                                                                                                                                                                                                                                                                                                                                                            |
| ICCD              | V <sub>CC</sub> Deep Power-Down<br>Current       |     | 2   | 5   | μΑ   | RP# = GND ±0.2V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ICCR1             | V <sub>CC</sub> Read Current                     |     | 40  | 50  | mA   | $\begin{array}{c} V_{CC} = V_{CC} \text{ Max} \\ \text{CMOS: } \text{CE}_0 \#, \text{CE}_1 \# = \text{GND } \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND } \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND } \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{TTL: } \text{CE}_0 \#, \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ \text{BYTE} \# = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{INPUTS} = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{f} = 8 \text{ MHz, } I_{\text{OUT}} = 0 \text{ mA} \end{array}$                                     |
| I <sub>CCR2</sub> | V <sub>CC</sub> Read Current                     |     | 20  | 30  | mA   | $\begin{array}{c} V_{CC} = V_{CC} \text{ Max} \\ \text{CMOS: } \text{CE}_0 \# \text{, } \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V or } \text{V}_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V or } \text{V}_{CC} \pm 0.2 \text{V} \\ \text{TTL: } \text{CE}_0 \# \text{, } \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ \text{BYTE} \# = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{INPUTS} = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{f} = 4 \text{ MHz, } \text{I}_{\text{OUT}} = 0 \text{ mA} \end{array}$ |
| Iccw              | V <sub>CC</sub> Write Current                    |     | 8   | 17  | mA   | Word/Byte Write in Progress V <sub>PP</sub> = 5.0V ±10%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ICCE              | V <sub>CC</sub> Block Erase Current              |     | 9   | 17  | mA   | Block Erase in Progress V <sub>PP</sub> = 5.0V ±10%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ICCES             | V <sub>CC</sub> Erase Suspend<br>Current         |     | 1   | 4   | mA   | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| I <sub>PPR</sub>  | V <sub>PP</sub> Read Current                     |     | 30  | 50  | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                    |     | 15  | 25  | mA   | V <sub>PP</sub> = 5.0V ±10%<br>Word/Byte Write in Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| IPPE              | V <sub>PP</sub> Erase Current                    |     | 14  | 20  | mA   | V <sub>PP</sub> = 5.0V ±10%<br>Block Erase in Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend Current            |     | 30  | 50  | μΑ   | V <sub>PP</sub> = V <sub>PPH1</sub> or V <sub>PPH2</sub> ,<br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| V <sub>PPLK</sub> | V <sub>PP</sub> Erase/Write Lock Voltage         | 0.0 |     | 1.5 | V    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| V <sub>PPH1</sub> | V <sub>PP</sub> during Write/Erase<br>Operations | 4.5 | 5.0 | 5.5 | ٧    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



Table 9. 28F016SV Added/Revised DC Characteristics for 5.0V Operations  $V_{CC}=5.0V~\pm0.5V,~5.0V~\pm0.25V,~T_A=0^{\circ}C~to~+70^{\circ}C$ 

| Symbol            | Parameter                                        | Min | Тур | Max | Unit | Test Condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|--------------------------------------------------|-----|-----|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Iccs              | V <sub>CC</sub> Standby Current                  |     | 70  | 130 | μΑ   | $\label{eq:VCC} \begin{aligned} &V_{CC} = V_{CC}\text{Max} \\ &CE_0\#, CE_1\#, RP\# = V_{CC} \pm 0.2V \\ &BYTE\#, WP\# = V_{CC} \pm 0.2V \\ &\text{or GND} \pm 0.2V \end{aligned}$                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ICCD              | V <sub>CC</sub> Deep Power-Down<br>Current       |     | 2   | 5   | μА   | RP# = GND ±0.2V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Iccr1             | V <sub>CC</sub> Read Current                     |     | 75  | 95  | mA   | $\begin{array}{l} V_{CC} = V_{CC} \text{ Max,} \\ \text{CMOS: CE}_0 \#, \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{TTL: CE}_0 \#, \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ \text{BYTE} \# = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{Inputs} = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{f} = 10 \text{ MHz, } I_{\text{OUT}} = 0 \text{ mA} \end{array}$                                         |
| ICCR2             | V <sub>CC</sub> Read Current                     |     | 45  | 55  | mA   | $\begin{array}{l} V_{CC} = V_{CC} \text{ Max,} \\ \text{CMOS: } \text{CE}_0 \# \text{, } \text{CE}_1 \# = \text{GND} \pm 0.2 \text{V} \\ \text{BYTE} \# = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{Inputs} = \text{GND} \pm 0.2 \text{V or } V_{CC} \pm 0.2 \text{V} \\ \text{TTL: } \text{CE}_0 \# \text{, } \text{CE}_1 \# = \text{V}_{\text{IL}}, \\ \text{BYTE} \# = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{Inputs} = \text{V}_{\text{IL}} \text{ or } \text{V}_{\text{IH}}, \\ \text{f} = 5 \text{ MHz, } \text{I}_{\text{OUT}} = 0 \text{ mA} \end{array}$ |
| Iccw              | V <sub>CC</sub> Write Current                    |     | 25  | 40  | mA   | Word/Byte in Progress $V_{PP} = 5.0V \pm 10\%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ICCE              | V <sub>CC</sub> Erase Suspend Current            |     | 20  | 30  | mA   | Block Erase in Progress<br>V <sub>PP</sub> = 5.0V ±10%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ICCES             | V <sub>CC</sub> Block Erase Current              |     | 2   | 4   | mA   | CE <sub>0</sub> #, CE <sub>1</sub> # = V <sub>IH</sub><br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| IPPR              | V <sub>PP</sub> Read Current                     |     | 30  | 50  | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write Current                    |     | 17  | 22  | mA   | $V_{PP} = 5.0V \pm 10\%$<br>Word/Byte Write in Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| IPPE              | V <sub>PP</sub> Block Erase Current              |     | 16  | 20  | mA   | V <sub>PP</sub> = 5.0V ±10%<br>Block Erase in Progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| IPPES             | V <sub>PP</sub> Erase Suspend Current            |     | 30  | 50  | μΑ   | V <sub>PP</sub> = V <sub>PPH1</sub> or V <sub>PPH2</sub><br>Block Erase Suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| V <sub>PPLK</sub> | V <sub>PP</sub> Write/Erase Lock Voltage         | 0.0 |     | 1.5 | ٧    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| V <sub>PPH1</sub> | V <sub>PP</sub> during Write/Erase<br>Operations | 4.5 | 5.0 | 5.5 | V    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



#### 2.9 Read Timing Specifications

The 28F016SV "bin 1" significantly improves many read specifications compared to the 28F016SA. At 3.3V  $V_{\rm CC}$ , read performance is almost 2x that of "bin 2". Tables 10 and 11 show these improved specifications.

Table 10. Improved AC Read Timing Characteristics for 3.3V Operations

 $V_{CC} = 3.3V \pm 0.3V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

|                   | Version                    | 28F016 | SV-075 | Units |  |
|-------------------|----------------------------|--------|--------|-------|--|
| Symbol            | Parameter                  | Min    | Max    | Units |  |
| t <sub>AVAV</sub> | Read Cycle Time            | 75     |        | ns    |  |
| t <sub>AVQV</sub> | Address to Output Delay    |        | 75     | ns    |  |
| t <sub>ELQV</sub> | CE# to Output Delay        |        | 75     | ns    |  |
| t <sub>PHQV</sub> | RP# High to Output Delay   |        | 480    | ns    |  |
| tGLQV             | OE# to Output Delay        |        | 40     | ns    |  |
| t <sub>EHQZ</sub> | CE# to Output in High Z    |        | 30     | ns    |  |
| t <sub>FHQV</sub> | BYTE# High to Output Delay | ,      | 75     | ns    |  |

Table 11. Improved AC Read Timing Characteristics for 5.0V Operations

 $V_{CC} = 5.0V \pm 0.5V$ , 5.0V  $\pm 0.25V$ ,  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ 

| Versions          |                          | V <sub>CC</sub> ±5% 28F016SV-06 |     | 6SV-065 |        |        | - 1   |
|-------------------|--------------------------|---------------------------------|-----|---------|--------|--------|-------|
|                   | ·                        | V <sub>CC</sub> ± 10%           |     |         | 28F016 | SV-070 | Units |
| Symbol            | Parameter                |                                 | Min | Max     | Min    | Max    |       |
| t <sub>AVAV</sub> | Read Cycle Time          |                                 | 65  |         | 70     |        | ns    |
| t <sub>AVQV</sub> | Address to Output Delay  |                                 |     | 65      |        | 70     | ns    |
| t <sub>ELQV</sub> | CE# to Output Delay      |                                 |     | 65      |        | 70     | ns    |
| t <sub>PHQV</sub> | RP# High to Output Delay |                                 |     | 300     |        | 300    | ns    |
| tGLQV             | OE# to Output Delay      |                                 |     | 30      |        | 35     | ns    |
| t <sub>FHQV</sub> | BYTE# High to Output Del | ay                              |     | 65      |        | 70     | ns    |



#### 2.10 Write Timing Specifications

The 28F016SV write timing specifications have also been improved to keep read and write cycle times equivalent and to simplify system interface to the flash memory. Tables 12 through 15 show these improved specifications. Both WE#- and CE#-controlled write specifications are shown, for both commands and writes to the page buffer, and at  $V_{\rm CC}=3.3 V$  and 5.0V.

Table 12. Improved AC WE #-Controlled Write Characteristics for 3.3V Operations  $V_{CC}=~3.3V~\pm0.3V,~T_A=~0^{\circ}C~to~+70^{\circ}C$ 

|                   | Version                            | 28F01 | 6SV-075 | Unito |
|-------------------|------------------------------------|-------|---------|-------|
| Symbol            | Parameter                          | Min   | Max     | Units |
| t <sub>AVAV</sub> | Write Cycle Time                   | 75    |         | ns    |
| t <sub>ELWL</sub> | CE# Setup to WE# Going Low         | 0     |         | ns    |
| t <sub>WLWH</sub> | WE# Pulse Width                    | 60    |         | ns    |
| tavwh             | Address Setup to WE# Going High    | 60    |         | ns    |
| t <sub>DVWH</sub> | Data Setup to WE# Going High       | 60    |         | ns    |
| t <sub>WHDX</sub> | Data Hold from WE# High            | 5     |         | ns    |
| t <sub>WHAX</sub> | Address Hold from WE# High         | 5     |         | ns    |
| twhEH             | CE# Hold from WE# High             | 5     |         | ns    |
| t <sub>WHWL</sub> | WE # Pulse Width High              |       |         | ns    |
| t <sub>PHWL</sub> | RP# High Recovery to WE# Going Low | 480   |         | ns    |
| twhgl             | Write Recovery before Read         | 55    |         | ns    |

Table 13. Improved AC WE#-Controlled Write Characteristics for 5.0V Operations  $V_{CC}=5.0V~\pm0.5V,~5.0V~\pm0.25V,~T_A=0^{\circ}C~to~+70^{\circ}C$ 

| $\begin{tabular}{c c} Versions & \hline $V_{CC} \pm 5\% \\ \hline $V_{CC} \pm 10\% \\ \hline \\ Symbol & Parameter \\ \hline \end{tabular}$ |                                    | V <sub>CC</sub> ±5%   | 28F016SV-065 |         |              |  |       |
|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-----------------------|--------------|---------|--------------|--|-------|
|                                                                                                                                             |                                    | V <sub>CC</sub> ± 10% |              |         | 28F016SV-070 |  | Units |
|                                                                                                                                             |                                    | Min                   | Max          | Min Max |              |  |       |
| t <sub>AVAV</sub>                                                                                                                           | Write Cycle Time                   |                       | 65           |         | 70           |  | ns    |
| t <sub>PHEL</sub>                                                                                                                           | RP# Setup to CE# Going             | Low                   | 300          |         | 300          |  | ns    |
| t <sub>AVWH</sub>                                                                                                                           | Address Setup to WE# Going High    |                       | 40           |         | 40           |  | ns    |
| tovwh                                                                                                                                       | Data Setup to WE# Going High       |                       | 40           |         | 40           |  | ns    |
| t <sub>WLWH</sub>                                                                                                                           | WE# Pulse Width                    |                       | 40           |         | 45           |  | ns    |
| twhax                                                                                                                                       | Address Hold from WE# High         |                       | 5            |         | 10           |  | ns    |
| twheh                                                                                                                                       | CE# Hold from WE# High             |                       | 5            |         | 5            |  | ns    |
| t <sub>WHWL</sub>                                                                                                                           | WE# Pulse Width High               |                       | 15           |         | 15           |  | ns    |
| t <sub>PHWL</sub>                                                                                                                           | RP# High Recovery to WE# Going Low |                       | 300          |         | 300          |  | ns    |
| twHGL                                                                                                                                       | Write Recovery before Read         |                       | 55           |         | 60           |  | ns    |



# Table 14. Improved AC CE#-Controlled Write Characteristics for 3.3V Operations $V_{CC}=3.3V~\pm0.3V,\,T_A=0^{o}C~to~+70^{o}C$

| Version           |                                    | 28F016 | 28F016SV-075 |       |
|-------------------|------------------------------------|--------|--------------|-------|
| Symbol            | Parameter                          | Min    | Max          | Units |
| t <sub>AVAV</sub> | Write Cycle Time                   | 75     |              | ns    |
| t <sub>ELEH</sub> | CE# Pulse Width                    | 60     | -            | ns    |
| t <sub>AVEH</sub> | Address Setup to CE# Going High    | 60     |              | ns    |
| t <sub>DVEH</sub> | Data Setup to CE# Going High       | 60     |              | ns    |
| t <sub>EHWH</sub> | WE# Hold from CE# High             | - 5    |              | ns    |
| t <sub>EHEL</sub> | CE# Pulse Width High               | 15     |              | ns    |
| t <sub>PHEL</sub> | RP# High Recovery to CE# Going Low | 480    |              | ns    |
| tEHGL             | Write Recovery before Read         | 55     |              | ns    |

# Table 15. Improved AC CE#-Controlled Write Characteristics for 5.0V Operations $V_{CC}=~5.0V~\pm0.5V,~5.0V~\pm0.25V,~T_A=~0^{\circ}C~to~+70^{\circ}C$

| Versions          |                                    | V <sub>CC</sub> ±5%   | 28F016SV-065 |     |        |              |    |
|-------------------|------------------------------------|-----------------------|--------------|-----|--------|--------------|----|
|                   |                                    | V <sub>CC</sub> ± 10% |              |     | 28F016 | 28F016SV-070 |    |
| Symbol            | Parameter                          |                       | Min          | Max | Min    | Max          |    |
| t <sub>AVAV</sub> | Write Cycle Time                   |                       | 65           |     | 70     |              | ns |
| t <sub>PHWL</sub> | RP# Setup to WE# Going Low         |                       | 300          |     | 300    |              | ns |
| taveh             | Address Setup to CE# Going High    |                       | 40           |     | 45     |              | ns |
| t <sub>DVEH</sub> | Data Setup to CE# Going High       |                       | 40           |     | 45     |              | ns |
| tELEH             | CE# Pulse Width                    |                       | 40           |     | 45     |              | ns |
| tEHWH             | WE# Hold from CE# High             |                       | 5 .          |     | 5      |              | ns |
| tEHEL             | CE# Pulse Width High               |                       | 15           |     | 15     |              | ns |
| t <sub>PHEL</sub> | RP# High Recovery to CE# Going Low |                       | 300          |     | 300    |              | ns |
| t <sub>EHGL</sub> | Write Recovery before Read         |                       | 55           |     | 60     |              | ns |



### 3.0 HARDWARE DESIGN FOR FORWARDS-COMPATIBILITY

Manufacturers that wish to use the 28F016SA now, and move to the 28F016SV for write performance, integration or other reasons, should keep the following focus areas in mind when completing designs:

#### 3.1 V<sub>CC</sub> Voltage

As noted in Section 2.8, the 28F016SV's typical and maximum read/standby currents and typical deep power-down current are higher than those of the 28F016SA.  $V_{CC}$  power supply selection should factor in these higher currents, as should system power consumption calculations. Decoupling and bypass capacitors can supply current for any of the 28F016SV  $V_{CC}$  deep power-down mode current "spikes" ( $V_{CC}=3.3V$ ) with no added burden on the power supply.

If conversion to the 28F016SV will also include changing the write/erase voltage to 5.0V from 12.0V, 5.0V power supply current calculations should include both the future additional write/erase current drawn by the 28F016SV's  $V_{CC}$  input (if  $V_{CC}=5.0V$ ) and the future current drawn by the 28F016SV's  $V_{PP}$  input (connected to 5.0V).

#### 3.2 Vpp Voltage

Conversion to the 28F016SV may be driven by the desire to write/erase at 5.0V (thereby eliminating the need for a separate 12.0V regulator). Keep in mind that write/erase at 5.0V is lower performance than at 12.0V. Some flash memory applications (but not all) can tolerate this additional write/erase time. For these applications, a jumper on the system board that enables Vpp pin connection either to the output of a 12.0V converter (for the 28F016SA) or to the system 5.0V supply (for the 28F016SV) should be added. With the jumper connected to 5.0V, the 12.0V converter and associated circuitry can be removed to lower system component count. See Figure 3 for an example.



Figure 3. Jumper Selection of 12.0V Converter or 5.0V Power Supply Output for Vpp

#### Write Protection Via VPPLK

Switching V<sub>PP</sub> off during normal operation is one of several methods commonly used to prevent unwanted alteration (data write or erase) of flash memory data. Designs that use this technique should ensure that the V<sub>PP</sub> voltage transitions to GND when "off." Some 12.0V converters drop V<sub>PP</sub> to a diode drop below V<sub>CC</sub> when they are placed in shutdown. This will block unwanted data write and erase on the 28F016SA but not on the 28F016SV, which has a 5.0V V<sub>PP</sub> option. An external pulldown resistor will pull the converter output to GND, preventing data alteration on either the 28F016SA or the 28F016SV. Other write protection techniques (i.e., RP# and WP# control) should also be used for full flash memory data protection.

### 3.3 Read/Write Performance and Wait-State Configuration

Conversion to the 28F016SV may also be driven by its higher read performance. Component identification in communicating whether the 28F016SA or the high speed 28F016SV is in system can either be accomplished via hardware or software methods (see Sections 3.4 and 4.1). Depending which component resides in the system, the state machine within the interface logic and/or system software can modify the wait-state profile of the flash memory space to take advantage of the 28F016SV's higher read performance capability.



#### 3.4 Hardware Identification of 28F016SA or 28F016SV

Jumpers can be used to communicate whether the 28F016SA or 28F016SV device is in the system, as shown in Figure 4. As the device identifiers for the 28F016SA and the 28F016SV are identical (see Section 4.1), software identification of one or the other flash memory via reading the device ID is not feasible. See Section 4.1 for a software method of identifying the 28F016SA or 28F016SV via the Device Proliferation Code. Jumper identification can also be used to enable system software usage of the 28F016SV's Status Register enhancements, Device Configuration Code and perblock cycle count. See Section 4 for more information.

### 4.0 SOFTWARE DESIGN FOR FORWARDS-COMPATIBILITY

The 28F016SV is fully software backwards-compatible with the 28F016SA. This section discusses several 28F016SV enhancements that system software can access if desired. Keep in mind that these features are not available on the 28F016SA and their access and/or implementation should not be attempted when using the 28F016SA.



Figure 4. Jumper Identification of 28F016SA or 28F016SV Presence



### 4.1 Software Identification of 28F016SA or 28F016SV

The 28F016SV's device identifier is identical to that for the 28F016SA. This enables all software written for the 28F016SA to be run on the 28F016SV unchanged. Methods of identifying the 28F016SV in the system, such as the jumper identification of Section 3.3 and Figure 3, can be used in designs that can accept both the 28F016SV and the 28F016SA. An alternative software method uses the Device Proliferation Code, supported on the 28F016SV (01H), but not on the 28F016SA. By initializing the Page Buffer location corresponding to this code to a known value and then executing an Upload Device Information command sequence, subsequent reads of the Page Buffer will identify the specific FlashFile memory in the system. The Device Proliferation Code address in the Page Buffer is 1FH in x8 mode and 0FH (upper 8 bits) in x16 mode. A pseudocode flow for this technique is shown below:

Initialize Device Proliferation Code address in Page Buffer to 00H.

Execute Upload Device Information command sequence Swap Page Buffer
Read from Device Proliferation Code address
If data = 00H, 28F016SA is present
If data = 01H, 28F016SV is present
End

### 4.2 Block Status Register V<sub>PP</sub> Level Bit

Bit 1 of the Block Status Registers, a "reserved" bit on the 28F016SA, is the "Vpp Level" bit on the 28F016SV (see Section 2.4 and Table 2). System software interfacing to the 28F016SV can examine this bit and, by determining what Vpp voltage is in the system, gain an indication of the level of data write and erase performance to be expected. This capability is particularly valuable when creating software that could run either in a 12.0V Vpp or 5.0V Vpp system (such as a low-level PCMCIA driver). Knowledge of write/erase performance allows software to adjust the frequency and duration of events, such as background media cleanup, to optimize system performance.

#### 4.3 Enhanced V<sub>PP</sub> Status Bit

Bit 2 of the Block Status Registers, functionally identical to bit 3 of the Compatible Status Register, is enhanced on the 28F016SV to reflect both 5.0V and 12.0V VPP capability (see Section 2.4 and Tables 1 and 2). With  $V_{PP} = 12.0V$  at the beginning of data write/ erase, Vpp transitions below 11.4V will, if detected, terminate data write/erase and return error indication via CSR.3 = BSR.2 = "1" (this is 100% compatible with the 28F016SA function). With  $V_{PP} = 5.0V$  at the beginning of data write/erase, Vpp transitions above 5.5V or below 4.5V will, if detected, also terminate data write/erase and return error indication via CSR.3 = BSR.2 = "1" (this is new to the 28F016SV). Accordingly, the CSR.3 = BSR.2 = "1" condition has been renamed from "VPP Low" (the 28F016SA definition) to "VPP Error."

#### 4.4 RY/BY# Configuration

The 28F016SV adds the Device Configuration Code, accessible via the Page Buffer after first writing the Upload Device Information command sequence (see Section 2.5 and Table 3). This code enables system software to read the currently-configured 28F016SV RY/BY # mode. The Device Configuration Code is located at Page Buffer address 1EH in x8 mode, 0FH (lower 8 bits in x16 mode).

As discussed earlier in section 2.3, the 28F016SV includes an additional RY/BY# mode, RY/BY# Pulse on Write/Erase, enabled as part of the RY/BY# Configuration (96H) command sequence. This mode was Reserved for Future Use on the 28F016SA.

#### 5.0 CONCLUSION

This application note has summarized upgrade considerations and compatibility areas between the 28F016SA and the 28F016SV. Consult reference documentation for a more complete understanding of compatibility and device capabilities. Please contact your local Intel or distribution sales office for more information on Intel's flash memory products.



#### **6.0 ADDITIONAL INFORMATION**

| Order Number                               | Document/Tool                                                                                  |  |  |  |  |
|--------------------------------------------|------------------------------------------------------------------------------------------------|--|--|--|--|
| 290528                                     | 28F016SV Datasheet                                                                             |  |  |  |  |
| 290489                                     | 28F016SA Datasheet                                                                             |  |  |  |  |
| 297372                                     | "16-Mbit Flash Product Family User's Manual,<br>28F016SA/28F016SV/28F016XS/28F016XD"           |  |  |  |  |
| 292126                                     | AP-377 "16-Mbit Flash Product Family Software Drivers,<br>28F016SA/28F016SV/28F016XS/28F016XD" |  |  |  |  |
| 292127                                     | AP-378 "System Optimization Using the Enhanced Features of the 28F016SA"                       |  |  |  |  |
| 297508                                     | FlashBuilder Utility                                                                           |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016SV iBIS Models                                                                           |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016SV VHDL/Verilog Models                                                                   |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016SV Timing Designer Library Files                                                         |  |  |  |  |
| Contact Intel/Distribution<br>Sales Office | 28F016SV Orcad and ViewLogic Schematic Symbols                                                 |  |  |  |  |

#### 7.0 REVISION HISTORY

| Number | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -001   | Original Version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| -002   | Added new RY/BY # mode of 28F016SV (Pulse-On-Write/Erase).  Added/Revised DC/AC Characteristics based on 28F016SV Datasheet (Rev. 002)  Increased I <sub>CCR</sub> Added to Tables 8 and 9.  Decreased I <sub>CCES</sub> , I <sub>PPR</sub> , I <sub>PPES</sub> Added to Tables 8 and 9.  t <sub>PHQV</sub> Added to Table 10.  t <sub>PHQV</sub> and t <sub>GLQV</sub> Added to Table 11.  t <sub>PHWL</sub> Added to Table 12.  t <sub>PHEL</sub> , t <sub>AVWH</sub> , t <sub>DVWH</sub> , t <sub>WLWH</sub> and t <sub>PHWL</sub> Added to Table 13.  t <sub>PHEL</sub> Added to Table 14.  t <sub>PHWL</sub> , t <sub>AVEH</sub> , t <sub>DVEH</sub> , t <sub>ELEH</sub> and t <sub>PHEL</sub> Added to Table 15.  Tables 16 and 17 Consolidated into Tables 12 and 13.  Added "Swap Page Buffer" to Pseudocode Example in Section 4.1. |

# APPLICATION NOTE

# 28F008SA Hardware Interfacing

BRIAN DIPERT
MCD MARKETING APPLICATIONS

September 1993

3

## 28F008SA Hardware Interfacing

| <b>CONTENTS</b> P                                                         | AGE   | <b>CONTENTS</b> PAGE                              |
|---------------------------------------------------------------------------|-------|---------------------------------------------------|
| 1.0 INTRODUCTION                                                          | 3-553 | <b>ADDITIONAL INFORMATION</b> 3-559               |
| 2.0 HARDWARE INTERFACING 3<br>2.1 V <sub>PP</sub> (Byte Write/Block Erase | 3-554 | APPENDIX A: Intel386™ SL PI Bus Interface         |
| Voltage)                                                                  |       | APPENDIX B: Intel486TM SX Local CPU Bus Interface |
| Controlling V <sub>PP</sub> to 28F008SA<br>Component(s)                   |       |                                                   |
| 2.2 RY/BY# (Ready/Busy) Output: 2.3 RP# (Reset/Powerdown) Input:          |       |                                                   |
| Deep Powerdown Mode                                                       |       |                                                   |
| Reset Control                                                             | 3-557 |                                                   |
| 2.4 WE# (Write Enable) Input                                              |       |                                                   |
| 2.6 Power Supply Decoupling                                               |       |                                                   |
| 2.8 Example Bus Interfaces                                                |       |                                                   |



#### 1.0 INTRODUCTION

The 28F008SA FlashFile<sup>TM</sup> Memory is a very high performance 8 Mbit (8,388,608 bit) memory, organized as 1 Mbyte (1,048,576 bytes) of 8 bits each. The 28F008SA contains sixteen 64 Kbyte (65,536 byte) blocks, each block separately eraseable and capable of 100,000 byte write-block erase cycles. On-chip automation dramatically simplifies software algorithms, and frees the system microprocessor to service higher priority tasks during component data update. An enhanced system interface allows switching the 28F008SA into a deep powerdown mode during periods of inactivity, and gives a hardware indication of the status of the internal Write State Machine. High-speed access time allows minimal wait-state interfacing to microprocessor buses, and advanced packaging provides optimum density/ in<sup>2</sup>.

#### Features of the 28F008SA include:

- High-Density Symmetrically Blocked Architecture:
  - Sixteen 64 Kbyte Blocks
- Extended Cycling Capability
  - 100,000 Block Erase Cycles
  - 1.6 Million Block Erase Cycles per Chip

- Automated Byte Write and Block Erase
  - Command User Interface
  - Status Register
- System Performance Enhancements
  - RY/BY# Status Output
  - Erase Suspend Capability
- Deep Powerdown Mode
  - 0.20 μA I<sub>CC</sub> Typical
- Very High Performance Read
- 85 ns Maximum Access Time
- SRAM-Compatible Write Interface
- Hardware Data Protection Features
  - Erase/Write Lockout during Power Transitions
- Industry Standard Packaging
  - 40 Lead TSOP, 44 Lead PSOP
- ETOX III Nonvolatile Flash Memory Technology
  - 12V Byte Write/Block Erase



Figure 1. The 28F008SA Revolutionizes the Architecture of Computing





Figure 2. 28F008SA Block Diagram

Traditional system architectures combine slow, high density nonvolatile mass storage (such as a disk drive) and fast, volatile memory (such as DRAM) to fully address system requirements. As Figure 1 illustrates, flash memory combines the best features of both the above memory technologies, making a "disk/DRAM" approach to system architecture unnecessary and ultimately wasteful. Flash memory is rapidly approaching DRAM in both cost and performance (especially in cached systems), while adding capabilities (such as nonvolatility), that DRAM cannot claim. The 28F008SA will be the building block memory of choice for emerging computing markets, whether integrated in a memory card or disk drive form factor, or resident on the system motherboard.

This application note discusses hardware interfacing of the 28F008SA flash memory to system designs. The 28F008SA datasheet (order number 290429) is a valuable reference document, providing in-depth device technical specifications, package pinouts and timing waveforms. Additionally, companion application note AP-360, "28F008SA Software Drivers" (order number 292095) provides example ASM-86 and "C" routines for controlling the 28F008SA. AP-364 "28F008SA Automation and Algorithms" discusses in-depth operation of the 28F008SA Write State Machine and internal algorithms, emphasizing how they interface to system software and hardware. AP-360 and AP-364 should be reviewed in conjunction with this application note and the 28F008SA datasheet for a complete understanding of this device.

#### 2.0 HARDWARE INTERFACING

Figure 2 shows a block diagram of the 28F008SA and its internal contents. The CE# (chip enable) and OE# (output enable) inputs have comparable enable and read functions to those of other memory technologies such as SRAM. Similarly,  $V_{\rm CC}$  is the component power supply (5V  $\pm$ 10%), while GND should be connected to system ground. Address inputs allow the system to select a specific byte for reading or writing/erasing, and the 8-bit data bus transfers information to and from the 28F008SA. The other control lines (WE#, RP#, RY/BY# and VPP) are discussed below.

## 2.1 V<sub>PP</sub> (Byte Write/Block Erase Voltage)

The  $V_{PP}$  input supplies high voltage to the 28F008SA to enable byte write and block erase.  $V_{PP}$  is specified at  $12V \pm 5\%$  (11.4V–12.6V). Attempting to byte write or block erase the 28F008SA beyond the 5% 12V tolerance is not recommended.  $V_{PP}$  above 12.6V can potentially result in device damage, and  $V_{PP}$  below 11.4V dramatically lengthens write/erase time and compromises data reliability. The 28F008SA is guaranteed to prevent byte write and block erase attempts with  $V_{PP}$  below 6.5V, and in this situation it reports a "low  $V_{PP}$  error" through the component Status Register (see AP-360, AP-364 or the 28F008SA datasheet).



#### **VPP Generation Circuits**

12V is often already present in systems, used to power the hard drive, display, RS-232 circuitry, flash BIOS update, etc. If it meets the tolerance and current capability requirements of the 28F008SA, such a power supply could be used directly as the 28F008SA update voltage source. However, 12V is sometimes not present or otherwise required, and in such cases, the 28F008SA Vpp must be derived from existing voltages and supplies.

Fortunately, flash memory's rapidly increasing popularity has driven ever-improving 12V converter availability in the market. These solutions derive a regulated 12V from a wide range of input voltages, and offer varied levels of integration and current delivery capability. In general, the input for 12V converters should come from the unregulated system power source, particularly in battery-powered systems.

Table 1 lists and briefly describes several 12V generation solutions available at the time this document was published. This is by no means an exhaustive list, and does not reflect any specific recommendation by Intel Corporation. For in-depth information on power supply solutions for flash memory, reference Intel application note AP-357 (order number 292092), available through your local Intel sales office or distributor.

#### Controlling Vpp to 28F008SA Component(s)

Once 12V is available in the system, how is it controlled? One approach is to hard-wire 12V from the supply directly to the Vpp inputs of each 28F008SA in the system. The advantage here is in design simplicity and board space savings. The 28F008SA Command User Interface architecture and two-step byte write/block erase command sequences provide protection from unwanted data alteration even with high voltage present on Vpp. All 28F008SA functions are disabled with  $V_{\rm CC}$  below lockout voltage  $V_{\rm LKO}$  (2.2V), or when

RP# is at V<sub>IL</sub> (see section 2.3). This provides data protection during system powerup, when the minimally-loaded V<sub>PP</sub> supply often ramps to 12V before V<sub>CC</sub> (and therefore control inputs to the device) are stable.

For additional data protection, the system designer can choose to make the VPP supply switchable via a GPIO (General Purpose Input/Output) line, enabling 12V to the 28F008SA only during byte write or block erase attempts. A switchable VPP also minimizes power consumption by both the flash memory components and the 12V supply or converter (due to efficiency losses). Many 12V converters integrate an ENABLE input, eliminating external circuitry. If such an input is not available, a low drain-source resistance MOSFET switch such as the Motorola MTD4P05 can be used at the 12V supply output. An example schematic for this switch is shown in Figure 3. The calculations below show that the low drain-source resistance of the MTD4P05 will keep a 12V input within the 5% tolerance required by the 28F008SA.

$$R_{DS} = 0.6\Omega$$
  
 $I_{PP} = 60 \text{ mA}$ 

(worst case, two components being byte written or block erased)

 $\Delta V_{SWITCH}$  DROP = (60 mA  $\times$  0.6 $\Omega$ ) = 0.04V



Figure 3. Vpp Switch Schematic

Table 1. 12V Conversion Solutions for Vpp

| Manufacturer           | Part<br>Number | Input<br>(V) | Package | Current<br>Output | Total<br>Components<br>Needed | Est.<br>Cost<br>(10K) |
|------------------------|----------------|--------------|---------|-------------------|-------------------------------|-----------------------|
| Maxim                  | MAX732         | 4 to 7.5     | 16 SOIC | 120 mA            | 9                             | \$3.93                |
| Linear Technology      | LT1110-12      | 4.5 to 5.5   | SO8     | 120 mA            | 11                            | \$4.58                |
| Linear Technology      | LT1109-12      | 4.5 to 5.5   | SO8     | 60 mA             | 8                             | \$3.61                |
| Motorola               | MC34063A       | 4.5 to 5.5   | SO8     | 120 mA            | 15                            | \$2.25                |
| Maxim                  | MAX667         | 12.1 to 16.5 | SO8     | 120 mA            | 4                             | \$2.63                |
| Linear Technology      | LT1111-12      | 16 to 30     | SO8     | 120 mA            | 7                             | \$3.95                |
| National Semiconductor | LM2940CT-12    | 13 to 26     | TO-220  | 1A                | 3                             | \$1.30                |



#### 2.2 RY/BY# (Ready/Busy) Output

The 28F008SA offers similar automated byte write/ block erase capabilities to those first seen in the 28F001BX Bootblock flash memory family, introduced by Intel in May of 1991. It enhances these capabilities via the RY/BY# output, which provides hardware indication of internal Write State Machine (WSM) operation. RY/BY# is a full CMOS output, constantly driven by the 28F008SA and not tristated if the device CE# or OE# inputs are brought to VIH. RY/BY#'s default state after device powerup is V<sub>OH</sub>. It transitions low to VOL when a byte write or block erase sequence is initiated by system software, and RY/BY#'s rising edge (return to VOH) alerts the system to byte write or block erase completion. RY/BY# also goes to VOH after the 28F008SA is put in Erase Suspend or Deep Powerdown modes.

RY/BY# is intended to interface the 28F008SA to a system microprocessor rising-edge-triggered interrupt input. In a multiple-chip memory array, external EPLD logic or an interrupt controller can be used to combine and prioritize RY/BY#s into one system interrupt (see Figure 4). The system can then, using a flash memory "activity table" set up in RAM, poll the individual 28F008SA Status Registers to determine which device has returned "ready", or read the RY/BY# inputs directly at the EPLD, as shown.

Figure 5 provides an alternative method for connecting multiple RY/BY#s to one interrupt input. The diode/resistor combination converts the 28F008SA full CMOS output into an open-drain "wired-OR" equivalent. Any RY/BY# at VOL will drive the interrupt input low, and this input is pulled high by the resistors when all RY/BY#s are at VOH. It is important in a design like this to use diodes with low forward voltage drops, so that the 28F008SA VOL (0.45V) plus the diode voltage drop is still less than or equal to the destination input VIH (0.8V). For the schematic shown in Figure 5, the equation is:

$$V_{OL} + V_{DIODE} = 0.45 V_{MAX} + 0.3V = 0.75V \le 0.8V$$

Note that should the system connect RY/BY# to an interrupt, disable that interrupt prior to suspending erase, as RY/BY# will transition to  $V_{OH}$  when the device is suspended.



Figure 4. EPLD-Based RY/BY # Implementation



Figure 5. "Wired-OR" RY/BY # Implementation

#### 2.3 RP# (Reset/Powerdown) Input

#### **Deep Powerdown Mode**

The RP# input, when driven to VIL by the system, switches the 28F008SA into a deep powerdown mode with negligable power consumption. This feature integrates the V<sub>CC</sub> power FET often used with low power designs. Power consumption thru V<sub>CC</sub> is typically 1 μW in deep powerdown mode. RP#-low deselects the memory, places output drivers for  $D_{0-7}$  in a highimpedence state and turns off a majority of internal circuits. RY/BY# is driven to VOH while in deep powerdown mode. Depending on the flexibility desired, system designers can choose to put either the entire flash device array into deep powerdown mode, or any individual components via selective input control. The 28F008SA requires a "wakeup" time after RP# returns to VIH before it can be successfully written (tpHWL) or outputs are valid to read attempts (tpHOV).



#### Write Protection

Since RP# =  $V_{IL}$  deselects the 28F008SA, this input can be used not only as a means of entering deep powerdown mode but also as an active-high "chip enable" to block spurious writes during system power transitions. Figure 6 shows one possible RP# implementation, controlled by a GPIO line for power management and by a system POWER GOOD for power sequencing protection. In this design, the 5V monitoring circuit begins functioning at  $V_{CC} = 1V$ , and will enable the device only after  $V_{CC}$  transitions above 4.6V (and system control signals are therefore stable). As  $V_{CC}$  drops below 4.6V during system powerdown, RP# protection is again activated.



Figure 6. RP# Gating

#### **Reset Control**

RP# at V<sub>IL</sub> resets all internal automation within the 28F008SA as part of the deep powerdown process. Upon exit from deep powerdown, the 28F008SA is reset to Read Array mode. This functionality is ideal when the 28F008SA is the boot memory for the system. RP# active transitions reset the Write Status Machine if system reset occurs during flash memory program or erase, and allow successful CPU reboot.

#### 2.4 WE# (Write Enable) Input

When flash memory is written, the result can range from a 28F008SA that is placed in "read intelligent identifier" or "read Status Register" modes to alteration of nonvolatile flash memory contents. System hardware can prevent spurious writes to flash memory by application software or an operating system by gating the system WE# to flash memory components to enable writes only when desired.

Figure 7 shows a simple design that gates WE# with a GPIO line, enabling writes to the 28F008SA only when the GPIO is a "0". The GPIO is initialized to "1" on system powerup and the BIOS, a dedicated update software routine, a special keyboard sequence, switch on the back of the system or jumper on the system motherboard can then control the GPIO. This circuit ensures that flash memory contents are as permanent as "ROM" unless alteration is specifically desired.



Figure 7. WE # Gating

#### 2.5 High Density/In<sup>2</sup> Layout

Figure 8 shows an 8 Mbyte flash memory array using TSOP (Thin Small Outline)-packaged 28F008SAs in standard (E) and reverse (F) configurations. A layout like this is used in Intel's Series 2 flash memory cards (in densities to 20 Mbytes) and provides optimum array density for available board space.

Address and data lines are connected to all components in parallel. OE# and WE# are similarly connected. Section 2.7 of this document discusses alternate methods of implementing these signals for highest speed reads and writes in large memory arrays.

Component RY/BY#s are shown as not connected in Figure 8. They can be left unused, in which case the system software will substitute polling of component Status Registers for hardware interrupt, or RY/BY#s can be implemented as described in section 2.2.

CE#s are also not connected, intended to be individually driven by system chip enable decoding logic. This provides capability to read from and write to the array on a byte-by-byte basis. In a x16-only system, upper and lower byte 28F008SAs can have their CE#s bused together if desired.

Finally,  $V_{CC}$ ,  $V_{PP}$  and RP# are connected in parallel to all components. Section 2.6 discusses bypass capacitor filtering of supply voltage inputs, while section 2.3 provides uses for RP#. If desired, individual component, component pair, etc. selective powerdown control can be substituted for the global control shown in Figure 8.

In space-constrained designs, a multiple-layer partial "serpentine" trace layout at the edges of the 28F008SA array may be implemented, with a full serpentine layout within the array as in Figure 8.





Figure 8. TSOP Serpentine Layout

#### 2.6 Power Supply Decoupling

Both the V<sub>CC</sub> and V<sub>PP</sub> inputs to each 28F008SA should be decoupled at the package leads to provide noise immunity and supply current for transient current spikes during read, byte write and block erase. Additional bulk capacitance for groups of flash memories overcomes voltage slump caused by PC board trace inductances. Calculations for individual component and bulk capacitors (one per 8 devices) are shown below.

Basic Equation:

I = C dv/dt

#### Assumptions:

I = 35 mA per device (V<sub>CC</sub>), therefore

 $I = 17.5 \text{ mA per device input (V}_{CC})$ 

I = 30 mA per device (V<sub>PP</sub>)

dv = 0.1V (0.2V peak-peak)

dt = 20 ns

Per-Component-Input Decoupling Capacitor (V<sub>CC</sub>):

$$C = I dt/dv = (17.5 mA \times 20 ns)/0.1V = 3.5 nF$$

 $4x \text{ margin} = 4 \times 3.5 \text{ nF} = 14 \text{ nF}$ 

Standard Equivalent =  $0.01 \mu F$ 



#### NOTE:

Calculations above assume that each 28F008SA is driving CMOS inputs (with corresponding high impedance and negligible input current requirements). If 28F008SA outputs are driving non-CMOS inputs, larger per-component capacitance may be needed to supply current while outputs are switching.

Bulk Capacitor (V<sub>CC</sub>):

 $C = 10 \times \text{(Total of Decoupling Capacitors)}$ 

Bulk Capacitor (4 Mbyte array) = 10  $\times$  (8  $\times$  0.01  $\mu$ F) = 0.8  $\mu$ F

Standard Equivalent =  $1 \mu F$ 

Per-Component Decoupling Capacitor (VPP):

$$C = I dt/dv = (30 mA \times 20 ns)/0.1V = 6 nF$$

 $4x \text{ margin} = 4 \times 6 \text{ nF} = 24 \text{ nF}$ 

Standard Equivalent =  $0.033 \mu F$ 

#### 2.7 High Speed Design Techniques

The 28F008SA's fast read access and command write specifications make it a natural choice for high performance memory arrays. The following tips will optimize the memory interface for optimum read/write speed. The common recommendation in all instances centers around minimizing fanout and capacitive bus loading to allow highest switching speed, lowest rise and fall times, and therefore greatest performance.

- Minimize address bus loading from the microprocessor to the memory array. Multiple address latches feeding subsets of the array speed address input to each 28F008SA and CE# decoding by external logic.
- Similarly, drive the memory array with multiple OE#s and WE#s. Most EPLD and discrete logic timing is specified at a 30 pF load, which equates to driving 4 28F008SA inputs at maximum input capacitance. Anything more than this may severely impact the logic's propagation delay.
- Finally, remember that each 28F008SA, when read, drives not only the system microprocessor or transceiver but also any other flash memory components connected to the common data bus. Each 28F008SA data output is specified at 12 pF, and the 28F008SA read timings are tested at either 30 pF or 100 pF of loading, depending on the chosen speed bin.

For large flash arrays where sequential data can be distributed on many devices, hardware interleaving provides additional performance.

#### 2.8 Example Bus Interfaces

**Order Number** 

Appendix A shows hardware interface to the Intel386<sup>TM</sup>SL PI bus, and Appendix B shows interface to the Intel486<sup>TM</sup>SX local CPU bus. Both interfaces incorporate techniques described in sections 2.1–2.7 of this document. These designs are intended to be examples which can be modified to suit requirements of the end system.

#### ADDITIONAL INFORMATION

|        |                                           | • · • · · · · · · · · · |
|--------|-------------------------------------------|-------------------------|
|        | 28F008SA Datasheet                        | 290429                  |
|        | 28F008SA-L Datasheet                      | 290435                  |
| AP-357 | "Power Supply Solutions for Flash Memory" | 292092                  |
| AP-360 | "28F008SA Software Drivers"               | 292095                  |
| AP-364 | "28F008SA Automation and Algorithms"      | 292099                  |
| ER-27  | "The Intel 28F008SA Flash Memory"         | 294011                  |
| ER-28  | "ETOX-III Flash Memory Technology"        | 294012                  |
|        |                                           |                         |



### APPENDIX A

### Intel386™SL PI BUS INTERFACE



#### NOTE:

The DRAM interface is not shown, for graphic simplicity.

0



# APPENDIX B Intel486™ SX LOCAL CPU BUS INTERFACE



NOTE

The DRAM interface is not shown, for graphic simplicity.

#### **REVISION HISTORY**

| Number | Description                                                                                                                      |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------|--|--|
| -003   | Renamed PWD# as RP# to match JEDEC conventions. Updated Figure 6 Added Reset Control discussion for RP# (Reset/Powerdown) Input. |  |  |

intel<sub>®</sub>

**AP-360** 

# APPLICATION NOTE

# 28F008SA Software Drivers

BRIAN DIPERT
MCD MARKETING APPLICATIONS

September 1993

### 3

### 28F008SA Software Drivers

| CONTENTS                     | PAGE  | CONTENTS               | PAGE  |
|------------------------------|-------|------------------------|-------|
| 1.0 INTRODUCTION             | 3-564 | ADDITIONAL INFORMATION | 3-583 |
| 2.0 ASM86 ASSEMBLY DRIVERS . | 3-565 |                        |       |
| 3.0 "C" DRIVERS              | 3-569 |                        |       |



#### 1.0 INTRODUCTION

This application note provides example software code for byte writing, block erasing and otherwise controlling Intel's 28F008SA 8 Mbit symmetrically blocked FlashFile<sup>TM</sup> Memory family. Two programming languages are provided; high-level "C" for multi-platform support, and ASM-86 assembly. In many cases, the driver routines can be inserted "as is" into the main body of code being developed by the system software engineer. The text accompanying each routine describes the existing code and suggests area for possible alteration to fit specific applications. These explanations, along with in-line commenting, minimize driver modification efforts.

Companion product datasheets for the 28F008SA and 28F008SA-L are valuable reference documents. Datasheets should be reviewed in conjunction with this application note for a complete understanding of the devices. AP-359, "28F008SA Hardware Interfacing" is the hardware-oriented application note equivalent for these devices and can also be referenced. AP-364 "28F008SA Automation and Algorithms", another useful reference, discusses the details of Write State machine automation.

The internal automation of the 28F008SA makes software timing loops unnecessary and results in platform-independent code. This software is designed to be executed in any type of memory and with all processor clock rates. "C" code can be used with many micro-processors and microcontrollers, while ASM-86 assembly code provides the smallest code "kernal" for Intel microprocessors and embedded processors.



#### 2.0 ASM-86 DRIVERS

```
Copyright Intel Corporation, 1992
          Brian Dipert, Intel Corporation, February 8, 1992, Revision 1.0
          Revision History: Rev 1.0
          The following code controls byte write of data to a single 28F008SA (x8 write)
          DS:[SI] points to the data to be written, ES:[DI] is the location to be written
          In protected mode operation, DS and ES reference a descriptor
          Register AX is modified by this procedure
WRITE_SETUP
                    EQU
                              40H
READ_ID
                    EQU
                              901
INTEL_ID
                    EQU
                              89H
DEVICE_ID
                    EQU
                              OA2H
DEVICE_IDS
                    EQU
                              OATH
                    EQU
READY
                              HOR
W_ERR_FLAG
                    EQU
                              10H
                    EQU
VPP FLAG
                              OSH
          Insert code here to ramp Vpp and disable component RP# input. If a string of bytes is
                    to be written at one time, Vpp ramp to 12V and ID check need only occur once,
                    before the first byte is written
          MOV
                              "Address 0 for target 28F008SA-segment"
                                                     : Initialize pointer to 28F0008SA address 0
          MOV
                    ES.
                    DI,
          MOV
                              "Address 0 for target 28F008SA-offset"
          MOV
                    BYTE PTR ES:[DI].
                                         READ_ID
                                                     ; Write Inteligent Identifier command
          CMP
                    BYTE PTR ES:[DI],
                                         INTEL_ID
                                                     ; Does manufacturer ID read correctly?
          JNZ
                    W_BYT_ID_ERR
          MOV
                               "Address 1 for target 28F008SA-offset"
                    DI.
                                                     ; Initialize pointer to 28F008SA address 1
          CMP
                    BYTE PTR ES:[DI],
                                         DEVICE_ID
                                                     ; Does device ID read correctly?
          JΖ
                    W_BYT_ID_PASS
          CMP
                    BYTE PTR ES:[DI],
                                         DEVICE_ID2
          TN7.
                    W_BYT_ID_ERR
W_BYT_ID_PASS:
                               "Byte write destination address-segment"
                    AX.
          MOV
                                                     ; Initialize pointer to byte write dest. address
          MOV
                    ES.
                              AX
          MOV
                               "Byte write destination address-offset"
          MOV
                    BYTE PTR ES:[DI].
                                         WRITE_SETUP : Write byte write setup command
                                                      : Load AL with data to write
          MOV
                    AT.
                              DS:[SI]
          MOV
                    ES:[DI],
                              ΑL
                                                      ; Write to device
W_BYT_LOOP:
          TEST
                    BYTE PTR ES:[DI],
                                         READY
                                                     ; Read 28F008SA Status Register
          JZ
                    W_BYT_LOOP
                                                     : Loop until bit 7 = 1
          TEST
                    BYTE PTR ES:[DI],
                                         (W_ERR_FLAG OR VPP_FLAG)
                    W_BYT_CONT
                                                     : Success!
          TEST
                                                     ; Check Status Register bit 4
                    BYTE PTR ES:[DI],
                                         W_ERR_FLAG
          JNZ
                    W_BYT_ERR
                                                      ; Jump if = 1, Byte Write Error
          TEST
                    ES:[DI], VPP_FLAG
                                                     ; Check Status Register bit 3
                                                     ; Jump if = 1, Vpp Low Error
          JNZ
                    W_BYT_VPP
W_BYT_ID_ERR:
                    Insert code to service improper device ID read error here.
                    Is 28F008SA RP# input disabled? Is Vcc applied to the 28F008SA?
W BYT ERR:
                    Insert code to service byte write error here
W_BYT_VPP:
                    Insert code to service byte write Vpp low error here
W_BYT_CONT:
                    Code continues from this point....
```

This routine writes a byte of data to a single 28F008SA. Note the use of BYTE PTR notation to force x8 accesses. If a string of bytes is to be written at one time, the V<sub>PP</sub> ramp up, RP# disable and device ID checks need only be done before the first byte write attempt. Additionally, when writing multiple bytes at once, examination of bits other than bit 7 (WSM Status) need only occur after the last byte write has completed. The Status Register retains any error bits until the Clear Status Register command is written.



```
The following code controls byte write of data to a pair of 28F008SAs (x16 write)
          DS:[SI] points to the data to be written, ES:[DI] is the location to be written
          In protected mode operation, DS and ES reference a descriptor
          Register AX is modified by this procedure
WRITE_SETUP
                    EQU
                               40H
                    EQU
READ_ID
                               90H
INTEL_ID
                    EQU
                               89H
DEVICE_ID
                    EQU
                               OASH
DEVICE_ID2
                    EQU
                               OAlH
READY
                    EQU
                               80H
W_ERR_FLAG
                    EQU
                               10H
VPP_FLAG
                    EQU
                               OSH
          Insert code here to ramp Vpp and disable component RP# inputs. If a string of words is
                    to be written at one time, Vpp ramp to 12V and ID check need only occur once,
                    before the first word is written
                               "Address 0 for target 28F008SA-segment"
          MOV
                                                     ; Initialize pointer to 28F008SA address 0
          MOV
                    ES,
          MOV
                    DI.
                               "Address 0 for target 28F008SA-offset"
                               ((READ_ID SHL 8) OR READ_ID)
                    ES:[DI].
          MOV
                                                     ; Write Inteligent Identifier command
          CMP
                     ES:[DI].
                               ((INTEL_ID SHL 8) OR INTEL_ID)
                                                     ; Does manufacturer ID read correctly?
          JNZ
                     W_WRD_ID_ERR
                               "Address 1 for target 28F008SA-offset"
          MOV
                    DI.
                                                     ; Initialize pointer to 28F008SA address 1
          CMP
                     ES:[DI], ((DEVICE_ID SHL 8) OR DEVICE_ID)
                                                     : Does device ID read correctly?
          JZ
                     W_WRD_ID_PASS
          CMP
                    ES:[DI], ((DEVICE_ID2 SHL 8) OR DEVICE_ID2)
          JNZ
                     W_WRD_ID_ERR
W_WRD_ID_PASS:
                     AX.
                               "Byte write destination address-segment"
          MOV
                                                     ; Initialize pointer to byte write dest. address
          MOV
                     ES.
          MOV
                     DI,
                               "Byte write destination address-offset
          MOV
                               ((WRITE_SETUP SHL 8) OR WRITE_SETUP)
                     ES:[DI],
                                                                          : Write byte write setup command
          MOV
                     AX.
                               DS:[SI]
                                                     : Load AX with data to write
          MOV
                     ES:[DI],
                                                     ; Write to devices
W_WRD_LOOP:
                               ((READY SHL 8) OR READY) ; Read 28F008SA Status Registers
          TEST
                    ES:[DI].
                    W_WRD_LOOP
          JZ
                                                     : Loop until bit 7 = 1
          TEST
                     ES:[DI].
                               (((W_ERR_FLAG OR VPP_FLAG) SHL 8) OR (W_ERR_FLAG OR VPP_FLAG))
          JZ
                     W_WRD_CONT
                                                     : Success!
          MOV
                    AX,
                               ES: [DI]
                                                     ; Load Status Register data into AX
          TEST
                     AL,
                               W_ERR_FLAG
                                                     ; Check Status Register bit 4 (low byte)
                     W_WRD_ERR
                                                     : Jump if = 1
          JNZ
          TEST
                     AH,
                               W_ERR_FLAG
                                                       Check Status Register bit 4 (high byte)
                    W_WRD_ERR
          JNZ
                                                     ; Jump if = 1
          TEST
                               VPP_FLAG
                                                       Check Status Register bit 3 (low byte)
                     W_WRD_VPP
          JNZ
                                                     ; Jump if = 1
          TEST
                     AH.
                               VPP_FLAG
                                                       Check Status Register bit 3 (high byte)
                    W_WRD_VPP
          JNZ
                                                     : Jump if = 1
W_WRD_ID_ERR:
          Insert code to service improper device ID read error here.
          Are 28F008SA RP# inputs disabled? Is Vcc applied to the 28F008SAS?
W_WRD_ERR:
          Insert code to service byte write error here
W_WRD_VPP:
          Insert code to service byte write Vpp low error here
W_WRD_CONT:
          Code continues from this point .....
```

This routine writes a word of data to a pair of 28F008SAs. Note that all constants have been "OR'd" for parallel read/write of two devices at once. If a string of words is to be written at one time, the V<sub>PP</sub> ramp up, RP# disable and device ID checks need only be done before the first word write attempt. Additionally, when writing multiple words at once, examination of bits other than bit 7 (WSM Status) need only occur after the last word write has completed. The Status Register retains any error bits until the Clear Status Register command is written.



```
The following code controls block erase of a single 28F008SA (x8 block erase)
          ES:[DI] points to the block to be erased
          In protected mode operation, ES references a descriptor
          Register AX is modified by this procedure
ERASE_SETUP
                    EQU
                               20H
ERASE_CONFIRM
                    EQU
                               ODOH
                    EQU
READ_ID
                               HOP
INTEL_ID
                    EQU
                               89H
DEVICE_ID
                     EQU
                               OAZH
DEVICE_ID2
                    EQU
                               OAlH
                    EQU
READY
                               ROH
E_ERR_FLAG
                    EQU
                               20H
E_CMD_FLAG
                     EQU
                               30H
VPP_FLAG
                    EQU
                               08H
          Insert code here to ramp Vpp and disable component RP# input. If a string of blocks is
                    to be erased at one time, Vpp ramp to 12V and ID check need only occur once,
                     before the first block is erased
          MOV
                               "Address O for target 28F008SA-segment"
                                                     ; Initialize pointer to 28F008SA address 0
          MOV
                    ES.
                               ΔX
          MOV
                    DI,
                               "Address 0 for target 28F008SA-offset"
          MOV
                     BYTE PTR ES:[DI],
                                         READ_ID
                                                     ; Write Inteligent Identifier command
          CMP
                     BYTE PTR ES:[DI],
                                         INTEL_ID
                                                     ; Does manufacturer ID read correctly?
          JNZ
                     E_BYT_ID_ERR
                               "Address 1 for target 28F008SA-offset"
          MOV
                     DI.
                                                     ; Initialize pointer to 28F008SA address 1
          CMP
                     BYTE PTR ES:[DI].
                                         DEVICE_ID
                                                     : Does device ID read correctly?
                     E_BYT_ID_PASS
          JZ
          CMP
                     BYTE PTR ES:[DI]
                                         DEVICE_ID2
          JNZ
                     E_BYT_ID_ERR
E_BYT_ID_PASS:
                     AX.
                               "Block erase destination address-segment"
          MOV
                                                     ; Initialize pointer to block erase dest.address
                    ES,
          MOV
          MOV
                     DI,
                               "Block erase destination address-offset"
          MOV
                     BYTE PTR ES:[DI],
                                         ERASE_SETUP
                                                         ; Write block erase setup command
                                         ERASE_CONFIRM
          MOV
                     BYTE PTR ES:[DI],
                                                         ; Write block erase confirm command
E_BYT_LOOP:
          TEST
                     BYTE PTR ES:[DI].
                                                     : Read 28F0008SA Status Register
                                         READY
                     E_BYT_LOOP
                                                     : Loop until bit 7 = 1
          JZ
          TEST
                     BYTE PTR ES:[DI],
                                          (E_CMD_FLAG OR VPP_FLAG)
                     E_BYT_CONT
          JZ
                                                     : Success!
          TEST
                     BYTE PTR ES:[DI],
                                         E_CMD_FLAG ; Check Status Register bits 4 and 5
          JNZ
                     E_BYT_CMD_ERR
                                                     ; Jump if = 1
          TEST
                     BYTE PTR ES:[DI].
                                          E_ERR_FLAG : Check Status Register bit 5
          JNZ
                     E BYT ERR
                                                     : Jump if = 1
          TEST
                     BYTE PTR ES:[DI].
                                         VPP_FLAG
                                                     ; Check Status Register bit 3
                     E_BYT_VPP
                                                     ; Jump if = 1
E_BYT_ID_ERR:
          Insert code to service improper device ID read error here.
          Is 28F008SA RP# input disabled? Is Vcc applied to the 28F008SA?
E_BYT_CMD_ERR:
          Insert code to service block erase command sequence error here
          (setup followed by a command other than confirm)
E_BYT_ERR:
          Insert code to service block erase error here
E_BYT_VPP:
          Insert code to service block erase Vpp low error here
E_BYT_CONT:
          Code continues from this point....
```

This routine erases a block of a single 28F00SA. Note the use of BYTE PTR notation to force x8 accesses. If a string of blocks is to be erased at one time, the Vpp ramp up, RP# disable and device ID checks need only be down before the first block erase attempt. Additionally, when erasing multiple blocks at once, examination of bits other than bit 7 (WSM Status) need only occur after the last block erase has completed. The Status Register retains any error bits until the Clear Status Register command is written.



```
The following code controls block erase of a pair of 28F008SAs (x16 block erase)
          ES:[DI] points to the blocks to be erased
          In protected mode operation, ES references a descriptor
          Register AX is modified by this procedure
ERASE_SETUP
                    EQU
                              20H
ERASE_CONFIRM
                    EQU
                              HOGO
READ_ID
                    EQU
                              90H
INTEL_ID
                    EQU
                             ₹89H
DEVICE_ID
                    EQU
                              OASH
DEVICE_IDS
                    EQU
                              OAIH
READY
                    EQU
                              80H
E_ERR_FLAG
                    EQU
                              20H
E_CMD_FLAG
                              30H
                    EΩU
VPP_FLAG
                    EQU
                              08H
          Insert code here to ramp Vpp and disable component RP# inputs. If a string of blocks is
                    to be erased at one time. Vpp ramp to 12V and ID check need only occur once,
                    before the first block pair is erased
          MOV
                              "Address 0 for target 28F008SA-segment"
                    AX.
                                                   : Initialize pointer to 28F008SA address 0
          MOV
          MOV
                              "Address 0 for target 28F008SA-offset"
                    DI.
          MOV
                    ES:[DI],
                              ((READ_ID SHL 8) OR READ_ID)
                                                    ; Write Inteligent Identifier command
          CMP
                    ES:[DI].
                              ((INTEL_ID SHL 8) OR INTEL_ID)
                                                   ; Does manufacturer ID read correctly?
          JNZ
                    E_WRD_ID_ERR
          MOV
                              "Address 1 for target 28F008SA-offset"
                                                   ; Initialize pointer to 28F008SA address 1
                    ES:[DI]. ((DEVICE_ID SHL 8) OR DEVICE_ID)
          CMP
                                                   ; Does device ID read correctly?
          JZ
                    E_WRD_ID_PASS
          CMP
                    ES:[DI], ((DEVICE_ID2 SHL 8) OR DEVICE_ID2)
          JNZ
                    E_WRD_ID_ERR
E_WRD_ID_PASS:
          MOV
                    AX.
                              "Block erase destination address-segment"
                                                   ; Initialize pointer to block erase dest. address
          MOV
                    ES.
          MOV
                              "Block erase destination address-offset"
                    DI.
                              ((ERASE_SETUP SHL 8) OR ERASE_SETUP)
          MOV
                    ES: [DI].
                                                   ; Write block erase setup command
                              ((ERASE_CONFIRM SHL 8) OR ERASE_CONFIRM)
          MOV
                    ES:[DI],
                                                   : Write block erase confirm command
E_WRD_LOOP:
          TEST
                    ES:[DI],
                             ((READY SHL 8) OR READY) ; Read 28F008SA Status Registers
          JΖ
                    E_WRD_LOOP
                                                   ; Loop until bit 7 = 1
                    TEST
          17.
          MOV
                    AX.
                              ES:[DI]
                                                    : Load Status Register data into AX
          TEST
                    AL,
                              E_CMD_FLAG
                                                     Check Status Reg bits 4 and 5 (low byte)
                    E_WRD_CMD_ERR
          JNZ
                                                     Jump if = 1
          TEST
                    AH,
                              E_CMD_FLAG
                                                     Check Status Register bits 4 and 5 (high byte)
          JNZ
                    E_WRD_CMD_ERR
                                                    : Jump if = 1
          TEST
                              E_ERR_FLAG
                                                    ; Check Status Register bit 5 (low byte)
                    AL.
          JNZ
                    E_WRD_ERR
                                                    : Jump if = 1
          TEST
                    AH,
                              E_ERR_FLAG
                                                     Check Status Register bit 5 (high byte)
          JNZ
                    E_WRD_ERR
                                                    ; Jump if = 1
          TEST
                    AL,
                              VPP_FLAG
                                                    ; Check Status Register bit 3 (low byte)
                    E_WRD_VPP
          TN7.
                                                    ; Jump if = 1
                                                    ; Check Status Register bit 3 (high byte)
          TEST
                    AH,
                              VPP_FLAG
          JNZ
                    E_WRD_VPP
                                                   ; Jump if = 1
E_WRD_ID_ERR:
          Insert code to service improper device ID read error here.
          Are 28F008SA RP# inputs disabled? Is Vcc applied to the 28F008SAs?
E_WRD_CMD_ERR:
          Insert code to service block erase command sequence error here
          (setup followed by a command other than confirm)
E_WRD_ERR:
          Insert code to service block erase error here
E WRD VPP:
          Insert code to service block erase Vpp low error here
E_WRD_CONT:
          Code continues from this point....
```



This routine erases a block pair of two 28F008SAs. Note that all constants have been "OR'd" for parallel read/write of two devices at once. If a string of block pairs is to be erased at one time, the V<sub>PP</sub> ramp up, RP# disable and device ID checks need only be done before the first block pair erase attempt. Additionally, when erasing multiple block pairs at once, examination of bits other than bit 7 (WSM Status) need only occur after the last block pair erase has completed. The Status Register retains any error bits until the Clear Status Register command is written.

#### 3.0 'C' DRIVERS

typedef

unsigned char byte;

```
Copyright Intel Corporation, 1992
          Brian Dipert, Intel Corporation, May 7, 1992, Revision 2.1
          The following drivers control the Command and Status Registers of the 28F008SA Flash
                     Memory to drive byte write, block erase, Status Register read and clear and array read algorithms. Sample Vpp and RP# control blocks are also included,
                     as are example programs combining drivers into full algorithms
          The functions listed below are included:
                                                                                                         *******************
                     erasbgn(): Begins block erasure
                     erassusp(): Suspends block erase to allow reading data from a block of the
                                  28F008SA other than that being erased
                     erasres(): Resumes block erase if suspended
                     end(): Polls the Write State Machine to determine if block erase or byte write
                                  have completed
                     eraschk(): Executes full status check after block erase completion
                     writebgn(): Begins byte write
                     writechk(): Executes full status check after byte write completion
                     idread(): Reads and returns the manufacturer and device IDs of the target
                                  28F008SA
                     statrd(): Reads and returns the contents of the Status Register
                     statclr(): Clears the Status Register
                     rdmode (): Puts the 28F008SA in Read Array mode
                     rdbyte (): Reads and returns a specified byte from the target 28F008SA
                     vppup(): Enables high voltage Vpph
                     vppdown(): Disables Vpph
                     pwden(): Enables active low signal RP#
                     pwddis(): Disables active low signal RP#
          Addresses are transferred to functions as pointers to far bytes (ie long integers). An
                     alternate approach is to create a global array the size of the 28F008SA and
                     located "over" the 28F008SA in the system memory map. Accessing specific
                     locations of the 28F008SA is then accomplished by passing the chosen function
                     an offset from the array base versus a specific address. Different
                     microprocessor architectures will require different array definitions; ie for
                     the Intel architecture, define it as "byte eightmeg[16][10000]" and pass each
                     function TWO offsets to access a specific location. MCS-96 architectures are
                     limited to "byte eightmeg[10000]"; alternate approaches such as using port pins
                     for paging will be required to access the full flash array
          To create a far pointer, a function such as MK_FP() can be used, given a segment and
                    offset in the Intel architecture. I use Turbo-C; see your compiler reference
                    manual for additional information.
          Revision History: Rev 2.1
          Changes From Revision 1.0 to Revision 2.0:
                    Added alternate 28F008SA device ID to routine idread()
          Changes from 2.0 to 2.1: Revised the Erase Suspend algorithm to remove potential
                     "infinite loop" caused by the WSM going "ready" after the system reads the
                     Status Register, and before the system issues the Erase Suspend command
```



```
Function: Main
           Description: The following code shows examples of byte write and block
/*
                      erase algorithms that can be modified to fit the specific application and
                      hardware design
main()
           byte far *address:
           byte data, status;
           The following code gives an example of a possible byte write algorithm.
           Note that Vpp does not need to be cycled between byte writes when a string of byte writes occurs. Ramp Vpp to 12V before the first byte write and leave at 12V until after
           completion of the last byte write. Doing so minimizes Vpp ramp up-down delay and
           maximizes byte write throughput
           vppup();
           "INSERT SOFTWARE DELAY FOR VPP RAMP IF REQUIRED"
           pwddis();
           address
                      = 0XxxxxxL;
           data
                      = 0Xyy;
           if (writebgn(data,address) == 1)
                      "RECOVERY CODE-POWER NOT APPLIED (ID CHECK FAIL)"
                      while (end(&status) )
                      switch (writechk(status))
                                     case 0:
                                                break :
                                     case 1:
                                                "RECOVERY CODE-VPP LOW DETECT ERROR"
                                     case 2:
                                                "RECOVERY CODE-BYTE WRITE ERROR"
                                                break;
                      statclr();
           vppdown();
```

This "C" routine gives an example of combining lower-level functions (found in following pages) to complete a byte write. Routines vppup() and pwddis() enable the 28F008SA for byte write. Function writebgn() issues a byte write sequence to the device, end() detects byte write completion via Status Register bit 7, and writechk() analyzes Status Register bits 3-6 to determine byte write success. If a string of bytes is to be written at one time, Vpp ramp up and RP# disable need only be done before the first byte write attempt. Additionally, when writing multiple bytes at once, examination of bits other than bit 7 (WSM Ready) need only occur after the last byte write has completed. The Status Register retains any error bits until the Clear Status Register command is written.



```
The following code gives an example of a possible block erase algorithm.
Note that Vpp does not need to be cycled between block erases when a string of block
erases occurs. Ramp Vpp to 12V before the first block erase and leave at 12V until after
completion of the last block erase. Doing so minimizes Vpp ramp up-down delay and
maximizes block erase throughput
: () guggy
"INSERT SOFTWARE DELAY FOR VPP RAMP IF REQUIRED"
pwddis();
address
          = 0XxxxxxL;
if (erasbgn(address) == 1)
          "RECOVERY CODE-POWER NOT APPLIED (ID CHECK FAIL)"
else
          while (end(&status) )
          switch (eraschk(status))
                       case 0:
                       case 1:
                                  "RECOVERY CODE-VPP LOW DETECT ERROR"
                                  break;
                        case 2:
                                  "RECOVERY CODE-BLOCK ERASE ERROR"
                                  break;
                       case 3:
                                  "RECOVERY CODE-ERASE SEQUENCE ERROR"
          statclr():
vppdown();
```

This "C" routine gives an example of combining lower-level functions (found in following pages) to complete a block erase. Routines vppup() and pwddis() enable the 28F008SA for block erase. Function erasbgn() issues a block erase sequence to the device, end() detects block erase completion via Status Register bit 7, and eraschk() analyzes Status Register bits 3–6 to determine block erase success. If a string of blocks is to be erased at one time, Vpp ramp up and RP# disable need only be done before the first block erase attempt. Additionally, when erasing multiple blocks at once, examination of bits other than bit 7 (WSM Ready) need only occur after the last block erase has completed. The Status Register retains any error bits until the Clear Status Register command is written.



```
Function: Erasgbn
          Description: Begins erase of a block.
                   blckaddr: System address within the block to be erased
          Inputs:
          Outputs: None
          Returns: 0 = Block erase successfully initiated
                    1 = Block erase not initiated (ID check error)
          Device Read Mode on Return: Status Register (ID if returns 1)
          ERASETUP 0X20
                                        /* Erase Setup command
          ERASCONF OXDO
                                         /* Erase Confirm command
#define
int erasbgn(blckaddr)
byte far *blckaddr:
                                        /* blckaddr is an address within the block to be erased
          byte mfgrid, deviceid;
          if (idread(&mfgrid,&deviceid)==1) /* ID read error; device not powered up?
                    return (1);
          *blckaddr = ERASETUP;
                                         /* Write Erase Setup command to block address
          *blckaddr = ERASCONF;
                                         /* Write Erase Confirm command to block address
          return (0):
```

Routine erasbgn() issues a block erase command sequence to a 28F008SA. It is passed the desired system address for the block to be erased. After calling idread(), it writes the erase command sequence at the specified address. It returns "0" if block erase initiation was successful, and "1" if the ID read fails (device not powered up or RP# not disabled).



```
Function: Erassusp
          Description: Suspends block erase to read from another block
          Inputs:
                    None
          Outputs: None
                    0 = Block erase suspended
          Returns:
                    1 = Error; Write State Machine not busy (block erase suspend not possible)
          Device Read Mode on Return: Status Register
#define
          RDYMASK
                    0X80
                                           Mask to isolate the WSM Status bit of the Status Register
#define
          WSWRDY
                    0880
                                        /* Status Register value after masking, signifying that
                                                     the WSM is no longer busy
#define
          SUSPMASK
                    0X40
                                           Mask to isolate the erase suspend status bit of the
                                                     Status Register
#define
          ESUSPYES
                    0X40
                                         /* Status Register value after masking, signifying that
                                                    block erase has been suspended
#define
                                         /* Read Status Register command
          STATREAD
                    0X70
#define
          SYSADDR
                                           This constant can be initialized to any address within
                                                     the memory map of the target 28F008SA and is
                                                     alterable depending on the system architecture
#define
          SUSPCMD
                    OYRO
                                         /* Erase Suspend command
int erassusp()
          byte far *stataddr:
                                        /* Pointer variable used to write commands to device
                                                                                                       */
          stataddr = (byte far *)SYSADDR:
                                           Write Erase Suspend command to the device
          *stateddr = SUSPCMD .
          *stataddr = STATREAD:
                                         /* Write Read Status Register command..necessary in case
                                                     erase is already completed
          while ((*stataddr & RDYMASK)
                                        != WSMRDY)
                                         /* Will remain in while loop until bit 7 of the Status
                                                    Register goes to 1, signifying that
                                                     the WSM is no longer busy
          if ((*stataddr & SUSPMASK) = ESUSPYES)
                                        /* Erase is suspended..return code "0"
                    return (0):
                                         /*Erase has already completed; suspend not possible.
          return (1);
                                                    Error code "1"
```

Routine erassusp() issues the erase suspend command to a 28F008SA. It first makes sure the WSM is truly busy, then issues the erase suspend command and polls Status Register bits 7 and 6 until they indicate erase suspension. It returns "0" if block erase was successful, and "1" if the WSM was not busy when suspend was attempted.



```
Function: Erasres
          Description: Resumes block erase previously suspended
          Inputs:
                   None
          Outputs:
                   None
          Returns:
                    0 = Block erase resumed
                    1 = Error; Block erase not suspended when function called
          Device Read Mode on Return: Status Register
#define
          RDYMASK
                    OXXO
                                        /* Mask to isolate the WSM Status bit of the Status Register */
#define
          WSMRDY
                    0X80
                                        /* Status Register value after masking, signifying that the
                                                  WSM is no longer busy
          SUSPMASK
                                        /* Mask to isolate the erase suspend status bit of the
#define
                   0X40
                                                  Status Register
                                        /* Status Register value after masking, signifying that
#define
          ESUSPYES
                    0740
                                                  block erase has been suspended
                                        /* Read Status Register command
#define
          STATREAD
                    0X70
          SYSADDR
                                           This constant can be initialized to any address within
#define
                                                  the memory map of the target 28F008SA and is
                                                   alterable depending on the system architecture
#define
          RESUMEND OXDO
                                        /* Erase Resume command
int erasres()
          byte far *stataddr;
                                        /* Pointer variable used to write commands to device
          stataddr = (byte far *)SYSADDR;
          *stataddr = STATREAD;
                                        /* Write Read Status Register command to 28F008SA
          if ((*stataddr & SUSPMASK)
                                     != ESUSPYES)
                    return (1):
                                        /* Block erase not suspended. Error code "1"
                                        /* Write Erase Resume command to the device
          *stataddr = RESUMCMD:
          while ((*stataddr & SUSPMASK) == ESUSPYES)
                                        /* Will remain in while loop until bit 6 of the Status
                                                  Register goes to 0, signifying block
                                        /*
                                                   erase resumption
          while ((*stataddr & RDYMASK) == WSMRDY)
                                        /* Will remain in while loop until bit 7 of the Status
                                        /*
                                                  Register goes to 0, signifying that the WSM is
                                        ·
/*
                                                   once again busy
          return (0);
```

Routine erasres() issues the erase resume command to a 28F008SA. It first makes sure the WSM is truly suspended, then issues the erase resume command and polls Status Register bits 7 and 6 until the indicate WSM resumption. It returns "0" if block erase resume was successful, and "1" if the WSM was not suspended when resumption was attempted.



```
Function: End
            Description: Checks to see if the WSM is busy (is byte write/block erase completed?)
            Inputs:
                           None
            Outputs:
                           statdata: Status Register data read from device
                           0 = Byte Write/Block Erase completed
            Returns:
                           1 = Byte Write/Block Erase still in progress
            Device Read Mode on Return: Status Register
#define
            RDYMASK
                           08X0
                                               /* Mask to isolate the WSM Status bit of the Status
#define
            WSMRDY
                                               /* Register value after masking, signifying that the
                           0X80
                                               /*
                                                         WSM is no longer busy
            STATREAD
                                               /* Read Status Register command
#define
                           0X70
#define
            SYSADDR
                           0
                                               /* This constant can be initialized to any address within*/
                                                          the memory map of the target 28F008SA and is
                                                          alterable depending on the system architecture */
int end(statdata)
byte *statdata;
                                                /* Allows Status Register data to be passed back to the
                                                         main program for further analysis
            byte far *stataddr:
                                                /* Pointer variable used to write commands to device
                           = (byte far *)SYSADDR;
            stataddr
                                                /* Write Read Status Register command to 28F008SA
            *stataddr
                           = STATREAD;
            if (((*statdata = *stataddr) & RDYMASK) != WSMRDY)
                                                /* Byte write/block erasure still in progress...code
                           return (1);
                                                /* Byte write/block erase attempt completed...code "0"
            return (0);
```

Routine end() detects completion of byte write or block erase operations of a 28F008SA. It passes back the Status Register data it reads from the device. It also returns "0" if Status Register bit 7 indicates WSM "Ready", and "1" if indication is that the WSM is still "Busy".



```
Function: Eraschk
          Description: Completes full Status Register check for block erase (proper command
                    sequence, Vpp low detect, block erase success). This routine assumes that block
                    erase completion has already been checked in function end(), and therefore does
                    not check the WSM Status bit of the Status Register
          Inputs:
                    statdata: Status Register data read in function end
          Outputs:
                    None
                    0 = Block erase completed successfully
          Returns:
                    1 = Error; Vpp low detect
                    2 = Error; Block erase error
                    3 = Error; Improper command sequencing
          Device Read Mode on Return: Same as when entered
#define
          ESEOMASK 0X30
                                        /* Mask to isolate the erase and byte write status bits of
                                                   the Status Register
#define
          ESEQFAIL
                    0730
                                           Status Register value after masking if block erase
                                                  command sequence error has been detected
          EERRMSK
#define
                    0X20
                                           Mask to isolate the erase status bit of the
                                                  Status Register
          ERASERR
                                        /* Status Register value after masking if block erase error
#define
                    0.820
                                                  has been detected
#define
          VLOWMASK
                                         /* Mask to isolate the Vpp status bit of the Status Register
                    0X08
                                           Status Register value after masking if Vpp low
#define
          VPPLOW
                    0708
                                                  has been detected
int eraschk(statdata)
bvte statdata:
                                           Status Register data that has been already read from the
                                                   28F008SA in function end()
          if ((statdata & VLOWMASK) == VPPLOW)
                                        /* Vpp low detect error, return code "1"
                    return (1);
          if ((statdata & EERRMSK) == ERASERR)
                                        /* Block erase error detect, return code "2"
                    return (2);
          if ((statdata & ESEQMASK) == ESEQFAIL)
                    return (3);
                                        /* Block erase command sequence error, return code "3"
          return (0);
                                        /* Block erase success, return code "0"
```

Routine eraschk() takes the Status Register data read in end() and further analyzes it. It returns "0" if block erase was successful, "1" if V<sub>PP</sub> low error was detected, "2" if block erase error was reported and "3" if an erase command sequence error was found (erase setup followed by a command other than erase confirm). This is useful after a block or string of blocks has been erased, to check for successful completion.



```
Function: Writebgn
          Description: Begins byte write sequence
                                                                                                        */
*/
*/
*/
                    wdata: Data to be written into the device
                    waddr: Target address to be written
          Returns: 0 = Byte write successfully initiated
                    1 = Byte write not initiated (ID check error)
          Device Read Mode on Return: Status Register (ID if returns 1)
          SETUPOMD OXAO
                                         /* Byte Write Setup command
#define
int writebgn(wdata,waddr)
byte wdata:
                                         /* Data to be written into the 28F008SA
byte far *waddr:
                                         /* waddr is the destination address for the data
                                                   to be written
          byte mfgrid, deviceid;
          if (idread(&mfgrid,&deviceid) == 1) /* Device ID read error...powered up?
                                                                                                        * /
                    return (1);
          *waddr
                    = SETUPCMD:
                                         /* Write Byte Write Setup command and destination address
          *waddr
                    = wdata;
                                         /* Write byte write data and destination address
          return (0):
}
          Function: Writechk
          Description: Completes full Status Register check for byte write (Vpp low detect, byte
                    write success). This routine assumes that byte write completion has already
                    been checked in function end() and therefore does not check the WSM Status
                                                                                                        */
*/
*/
*/
*/
*/
                    bit of the Status Register
                    statdata: Status Register data read in function end()
          Inputs:
          Outputs:
                    None
          Returns:
                    0 = Byte write completed successfully
                    1 = Error; Vpp low detect
                    2 = Error; Byte write error
          Device Read Mode on Return: Status Register
#define
          WERRMSK
                                         /* Mask to isolate the byte write error bit of the
                                                                                                        */
*/
                                                   Status Register
                                         /* Status Register value after masking if byte write error
          WRITERR
                    0110
#define
                                                  has been detected
                                         /* Mask to isolate the Vpp status bit of the
#define
          VLOWMASK
                    0X08
                                                   Status Register
#define
          VPPT-OW
                    UXUS
                                         /* Status Register value after masking if Vpp low
                                                   has been detected
int writechk(statdata)
bvte statdata:
                                         /* Status Register data that has been already read from the
                                                   28F008SA in function end()
          if ((statdata & VLOWMASK) == VPPLOW)
                    return (1);
                                         /* Vpp low detect error, return code "1"
          if ((statdata & WERRMSK) == WRITERR)
                                         /* Byte write error detect, return code "2"
                    return (2):
                                         /* Byte/string write success, return code "0"
          return (0);
```

Routine writebgn() issues a byte write command sequence to a 28F008SA. It is passed the desired system address for the byte to be written, as well as the data to be written there. After calling idread(), it writes the byte write command sequence at the specified address. It returns "0" if byte write initiation was successful, and "1" if the ID read fails (device not powered up or RP# not disabled).

Routine writechk() takes the Status Register data read in end() and further analyzes it. It returns "0" if byte write was successful, "1" if Vpp low error was detected, and "2" if byte write error was reported. This is useful after a byte or string of bytes has been written, to check for successful completion.



```
Function: Idread
           Description: Reads the manufacturer and device IDs from the target 29F008SA
           Inputs:
                      None
           Outputs:
                      mfgrid: Returned manufacturer ID
                       deviceid: Returned device ID
                      0 = ID read correct
           Returns:
                       1 = Wrong or no ID
           Device Read Mode on Return: Intelligent Identifier
#define
           MFGRADDR O
                                              /* Address "0" for the target 28F008SA...alterable depending */
                                                         on the system architecture
#define
           DEVICADD
                                              /* Address "1" for the target 28F008SA...alterable depending */
                                                         on the system architecture
                                              /* Inteligent Identifier command
#define
           IDRDCOMM
                       0890
#define
           INTELID
                       0X89
                                              /* Manufacturer ID for Intel devices
#define
           DVCID
                       SAOXO
                                              /* Device IDs for 28F008SA
#define
           DVCID2
                       OXOAl
int idread(mfgrid,deviceid)
byte *mfgrid;
                                              /* The manufacturer ID read by this function, to be
                                                 transferred back to the calling program
The device ID read by this function, to be transferred
byte *deviceid:
                                                         back to the calling function
           byte far *tempaddr:
                                              /* Pointer address variable used to read IDs
            tempaddr = (byte far *) MFGRADDR;
            *tempaddr = IDRDCOMM;
                                              /* Write Intelligent Identifier command to an address within */
                                                         the 28F008SA memory map (in this case 00 hex)
           *mfgrid = *tempaddr; /* Read mfgr ID, tempaddr still points at address tempaddr = (byte far *)DEVICADD; /* Point to address "l" for the device specific ID *deviceid = *tempaddr; /* Read device ID ** (*deviceid != DVCID2)))
            if ((*mfgrid != INTELID)
                                             *deviceid != DVCID) && (*deviceid != DVCID2)))
                                              /* ID read error; device powered up?
                       return (1);
            return (0);
```

Routine idread() issues the Intelligent Identifier command to a 28F008SA. It passes back the manufacturer and device IDs it reads. In addition, it returns "0" if the IDs read matched those expected for the 28F008SA or 28F008SA-L, and "1" if either the manufacturer or device IDs did not match.



```
Function: Statrd
          Description: Returns contents of the target 28F008SA Status Register
          Inputs:
                   None
          Outputs: statdata: Returned Status Register data
          Returns: Nothing
          Device Read Mode on Return: Status Register
#define
          STATREAD 0X70
                                        /* Read Status Register command
#define
          SYSADDR
                    ٥
                                        /* This constant can be initialized to any address within
                                                  the memory map of the target 28F008SA and is
                                                  alterable depending on the system architecture
int statrd(statdata)
byte *statdata:
                                        /* Allows Status Register data to be passed back to the
                                                  calling program for further analysis
1
          byte far *stataddr:
                                        /* Pointer variable used to write commands to device
          stataddr = (byte far *)SYSADDR;
          *stataddr = STATREAD;
                                        /* Write Read Status Register command to 28F008SA
          *statdata = *stataddr:
          return;
}
         Function: Statclr
          Description: Clears the 28F008SA Status Register
          Inputs:
                   None
          Outputs: None
Returns: Nothing
          Device Read Mode on Return: Array
#define
          STATCLER 0X50
                                         /* Clear Status Register command
                                        /* This constant can be initialized to any address within
#define
          SYSADDR
                    0
                                                  the memory map of the target 28F008SA and is
                                                  alterable depending on the system architecture
int statclr()
                                        /* Pointer variable used to write commands to device
          byte far *stataddr:
          stataddr = (byte far *) SYSADDR;
                                        /* Write Clear Status Register command to 28F008SA
          *stataddr = STATCLER;
          return;
}
```

Routine statrd() reads a 28F008SA Status Register. It issues the Read Status Register command and passes back the data it obtains.

Routine statclr() issues the Clear Status Register command to a 28F008SA. This routine is required after analyzing Status Register contents in routines like eraschk() and writechk(). The 28F008SA Status Register retains state of bits 3-6 until they are cleared by the Clear Status Register command.



```
Function: Rdmode
         Description: Puts the target 28F008SA in Read Array Mode. This function might be used, for
                    example, to prepare the system for return to code execution out of the Flash
                    memory after byte write or block erase algorithms have been executed off-chip
          Inputs:
                    None
          Outputs:
                   None
         Returns:
                   Nothing
          Device Read Mode on Return: Array
         RDARRAY
                    OXEE
                                        /* Read Array command
#define
#define
          SYSADDR
                    O
                                        /* This constant can be initialized to any address within
                                                  the memory map of the target 28F008SA and is
                                                  alterable depending on the system architecture
int rdmode()
          byte far *tempaddr:
                                        /* Pointer variable used to write commands to the device
          tempaddr = (byte far *)SYSADDR:
          *tempaddr = RDARRAY;
                                        /* Write Read Array command to 28F008SA
          return:
          Function: Rdbyte
          Description: Reads a byte of data from a specified address and returns it to the
                       calling program
                    raddr: Target address to be read from
          Outputs: rdata: Data at the specified address
          Returns: Nothing
          Device Read Mode on Return: Array
#define
         RDARRAY
                   OXFF
                                        /* Read array command
int rdbyte(rdata,raddr)
byte *rdata;
                                        /* Returns data read from the device at specified address
byte far *raddr;
                                        /* Raddr is the target address to be read from
          *raddr
                    = RDARRAY;
                                        /* Write read array command to an address within the
                                                  28F008SA (in this case the target address)
                                        /* Read from the specified address and store
          *rdata
                    = *raddr:
          return:
```

Routine rdmode() simply puts a 28F008SA in Read Array mode. This is useful after byte write and block erase operations, to return the 28F008SA to its "normal" mode of operation. After block erase or byte write, the 28F008SA will continue to output Status Register data until the Read Array command is issued to it, for example.

Routine rdbyte() not only puts the 28F008SA in Read Array mode, it also reads a byte of data. It is passed the desired system byte address, and passes back the data at that address.



```
Function: Vppup
          Description: Ramps the Vpp supply to the target 28F008SA to enable byte write or block
                    erase. This routine can be tailored to the individual system architecture. For
                    purposes of this example, I assumed that a system Control Register existed at
                    system address 20000 hex, with the following definitions:
                              Bit 7: Vpph Control: 1 = Enabled
                                                    0 = Disabled
                              Bit 6: PWD Control:
                                                   1 = PowerDown Enabled
                                                    0 = PowerDown Disabled
                              Bits 5-0: Undefined
          Inputs:
                    None
          Outputs: None
          Returns: Nothing
          Device Read Mode on Return: As existed before entering the function. Part is now ready for
                    program or erase
#define
          VPPHIGH
                                        /* Bit 7 = 1, Vpp elevated to Vpph
                                        /* Assumed system Control Register Address
#define
          SYSCADDR 0X20000
int vppup()
          byte far *contaddr:
                                         /* Pointer variable used to write data to the system
                                                  Control Register
          contaddr = (byte far *) SYSCADDR;
          *contaddr = *contaddr | VPPHIGH; /* Read current Control Register data, "OR" with
                                                  constant to ramp Vpp
          return:
}
          Function: Vppdown
          Description: Ramps down the Vpp supply to the target 28F008SA to disable byte write/block
                    erase. See above for a description of the assumed system Control Register.
          Inputs:
          Outputs: None
          Returns: Nothing
          Device Read Mode on Return: As existed before entering the function. Part now has high Vpp
                    disabled. If byte write or block erase was in progress when this function was
                    called, it will complete unsuccessfully with Vpp low error in the
                    Status Register.
          VPPDWN
                    OX7F
#define
                                        /* Bit 7 = 0, Vpp lowered to Vppl
          SYSCADDR 0X20000
                                        /* Assumed system Control Register Address
#define
int vppdown()
          byte far *contaddr;
                                         /* Pointer variable used to write data to the system
                                                  Control Register
          contaddr = (byte far *)SYSCADDR;
          *contaddr = *contaddr & VPPDWN; /* Read current Control Register data, "AND" with /* constant to lower Vpp
          return;
```

Functions vppup() and vppdown() give examples of how to control via software the hardware that enables or disables 12V Vpp to a 28F008SA. The actual hardware implementation chosen will drive any modification of these routines.



```
Description: Toggles the 28F008SA RP# pin low to put the device in Deep PowerDown mode.
                    See above for a description of the assumed system Control Register.
          Inputs:
                    None
          Outputs:
                   None
         Returns: Nothing
          Device Read Mode on Return: The part is powered down. If byte write or block erase was in
                    progress when this function was called, it will abort with resulting partially
                    written or erased data. Recovery in the form of repeat of byte write or block
                    erase will be required once the part transitions out of powerdown, to
                    initialize data to a known state.
          PWD
                                        /* Bit 6 = 1, RP# enabled
#define
                    0X40
                    0X20000
                                        /* Assumed system Control Register Address
#define
          SYSCADDR
int pwden()
          byte far *contaddr;
                                        /* Pointer variable used to write data to the system
                                                  Control Register
          contaddr = (byte far *)SYSCADDR;
          *contaddr = *contaddr | PWD; /* Read current Control Register data, "OR" with constant
                                                  to enable Deep PowerDown
          Function: Pwddis
          Description: Toggles the 28F008SA RP# pin high to transition the part out of Deep
                    PowerDown. See above for a description of the assumed system Control Register.
          Inputs:
                    None
          Outputs:
                    None
          Returns: Nothing
          Device Read Mode on Return: Read Array mode. Low voltage is removed from the RP# pin.
                    28F008SA output pins will output valid data time tPHQV after the RP# pin
                    transitions high (reference the datasheet AC Read Characteristics) assuming
                    valid states on all other control and power supply pins.
#define
          PWDOFF
                    OXBE
                                        /* Bit 6 = 0, RP# disabled
#define
          SYSCADDR 0X20000
                                        /* Assumed system Control Register Address
int pwddis()
          byte far *contaddr:
                                        /* Pointer variable used to write data to the system
                                                  Control Register
          contaddr = (byte far *) SYSCADDR;
          *contaddr = *contaddr & PWDOFF; /* Read current Control Register data, "AND" with
                                                     constant to disable Deep PowerDown
          return;
```

Functions pwden() and pwddis() give examples of how to control via software the hardware that enables or disables a 28F008SA RP# input. The actual hardware implementation chosen will drive any modification of these routines.



#### **ADDITIONAL INFORMATION**

|        | 28F008SA Datasheet                   | Order Number<br>290429 |
|--------|--------------------------------------|------------------------|
|        | 28F008SA-L Datasheet                 | 290435                 |
| AP-359 | "28F008SA Hardware Interfacing"      | 292094                 |
| AP-364 | "28F008SA Automation and Algorithms" | 292099                 |
| ER-27  | "The Intel 28F008SA Flash Memory"    | 294011                 |
| ER-28  | "ETOX-III Flash Memory Technology"   | 294012                 |

#### **REVISION HISTORY**

| Number | Description                                     |
|--------|-------------------------------------------------|
| 002    | Revised Erase Suspend Algorithm in "C" Drivers. |
| 003    | PWD# pin renamed RP# to match JEDEC standards.  |

3





# APPLICATION NOTE

# Implementing Mobile PC Designs Using High Density FlashFile<sup>TM</sup> Components

DON VERNER
SENIOR APPLICATIONS ENGINEER

March 1994

# IMPLEMENTING MOBILE PC DESIGNS USING HIGH DENSITY FlashFileTM COMPONENTS

| <b>CONTENTS</b> PAGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | CONTENTS PAGE              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| 1.0 INTRODUCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 3.4 Chipset Considerations |
| 2.0 SOFTWARE DESIGN       3-589         2.1 XIP Operating System       3-589         2.2 DOS In Flash Implementation       3-590         2.3 Resident Flash Disk       3-592         2.3.1 Microsoft's Flashfile       3-593         2.4 Resident Flash Disk (RFD) and       3-593         2.4 Resident Flash Disk (RFD) and       3-593         2.4.1 ExCA Software Interface       3-594         2.4.2 RFD Socket Services       3-596         2.4.3 ExCA Card Services       3-596         2.4.4 iCARD29 File System       3-596         2.4.5 RFD Socket Services       3-596         2.4.5 RFD Socket Services       3-597         2.5 XIP Graphical Users Interface       (GUI) Overview       3-597         2.6 XIP GUI Implementation       3-598         2.7 Pen Extensions       3-598         3.0 HARDWARE       3-598 | 4.1 RFA Diagnostic         |
| 3.1 Resident Flash Disk Implementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                            |



#### 1.0 INTRODUCTION

As personal computers migrate to platforms that are easily held with one hand, a revolutionary system architecture is required to meet space and power requirements.

- An architecture that is not bounded by what has been done before with existing memory architecture, but free to meet the demanding requirements of mobile end users.
- An architecture free to adapt and accommodate new technological advances in software and hardware, while protecting end-users initial base hardware investment.

Implementing this new system architecture requires traditional PC storage media such as ROM, DRAM, floppy disk and hard disk to move aside and make room for the latest in memory storage, Intel's FlashFile<sup>TM</sup> memory (see architecture comparison in Figure 1.).

| Application | Data<br>Manipulation | Code<br>Execution | File & Code<br>Storage                                    |
|-------------|----------------------|-------------------|-----------------------------------------------------------|
| Desktops    | DRAM                 | DRAM/ROM          | FDD/HDD                                                   |
| Portables   | DRAM F               |                   | FLASH<br>- Resident Disk<br>- Flash Card<br>- Flash Drive |
|             |                      |                   | 292097-1                                                  |

Figure 1. Architecture Comparison

By combining FlashFile memory with new system architecture, completely new types of computers are now possible that fit in the palm of your hand and replace or integrate many of the code or storage functions of other memory types. Moreover, FlashFile memory enables hand-held computers to last many hours on just a couple of AA batteries. FlashFile memory can be used for storing eXecute- In-Place (XIP) code in the system's memory map, while additionally functioning like a disk for file and program storage. Since this type of design features FlashFile memory resident on the PC's motherboard and is typically arranged in an array, it is described as a Resident Flash Array (or RFA). To further differentiate the two tasks of an RFA, the file store task is called a Resident Flash Disk (RFD), while the XIP task is called Resident Flash for XIP (or RFX) code storage.

The FlashFile memory is also used in card form as specified by the Personal Computer Memory Card International Association (PCMCIA). Flash memory cards provide file and program storage similar to an RFD, but add the feature of removability, increasing or adding to ease-of-use for the end user. The PCMCIA specification addresses both the memory and I/O card's physical, electrical and mechanical characteristics, while leaving the host PC implementation relatively free for interpretation. Enhancing the PCMCIA specification, Intel developed the Exchangeable Card Architecture (ExCATM), which defines the host PC system card interface. ExCA further refines the PCMCIA specification and provides for card exchangeability and inter-operability for both memory and I/O cards.

Memory and I/O cards complement this new mobile architecture by integrating many of the common but functionally separate tasks used by today's mobile professional in either electronic or paper form. Some of these tasks are schedule keepers, phones, address books, checkbooks, credit cards, fax, pagers, personal voice storage, task managers/schedulers, paperless form reports, scratch pads, and notepads.

## 1.1 Why A New Memory Architecture?

The ideal hand held memory system is:

- Power Conscious (prolongs battery life and reduces heat)
- Dense (stores lots of code and data in a small amount of space but weighs very little)
- Updateable (allows in-situ code enhancements)
- Fast (lets you read and write data quickly)
- Inexpensive (low cost per megabyte)
- Reliable (retains data when exposed to extreme temperature and mechanical shock)

Since the PC's introduction over 10 years ago, designers have grappled with how to construct memory systems that met the above criteria. Portable computing makes the system design even tougher with more stringent requirements for low power, low volume and less weight. The best combination available for portable designs in their infancy was the same as used for the desktop; solid-state memory and magnetic storage, i.e., SRAMs, DRAMS plus magnetic hard disks. DRAMs are dense and inexpensive, yet slower than the processors they serve, and they are volatile. SRAMs, although fast enough to keep pace with processors, are relegated to caching schemes (compensating for DRAM's slowness) due to low density and high cost while also being volatile. Magnetic hard disks, the nonvolatile append-



age to DRAM and SRAM, are dense, inexpensive on a cost-per-megabyte basis and nonvolatile, but are slow, power hungry, take up a sizable amount of volume and are susceptible to damage from physical shock.

Mobile computing designs cannot depend on hard drives as portable notebook PCs do. Volume (4" x 8 x 0.5" or less), power (two AAs), and shock constraints preclude using even the 1.3" hard drives available today. Also, vitally important data such as credit card numbers or transactions, signatures, or checkbook information demands reliability of the highest order.

#### 1.2 The Flash Memory Alternative

#### **High Density**

Intel's ETOX III Flash Memory Cell is 30% smaller than equivalent DRAM cells; therefore it will closely track DRAM density. Intel's 28F008SA FlashFile Memory can store 8 megabits, or one megabyte, of data. Flash memory is more scaleable than DRAM because the flash storage cell is not sensitive to soft error failure, therefore it can have a more simple cell structure. Thus as density increases and process lithography continues to shrink, flash memory will pace and ultimately overtake the DRAM technology treadmill.

#### Updatable

ROMs and EPROMs may offer lower device costs, but if servicing the customer or end-user is important to an OEM, overall system cost must be factored in. Although ROMs and EPROMs are nonvolatile, changing the code within them is either very difficult (in the case of EPROMs) or entirely impossible (in the case of ROMs). Whole inventories of ROMs could be lost in the event of a catastrophic bug, while an innovative design with FlashFile memory can be updated in the factory or by end-users via networks, OEM Bulletin Board Systems, or other memory cards. Updating systems could actually become a second source of income for OEMs and Independent Software Vendors, enhancing the quality of the product while increasing end-user satisfaction.

#### **Power Conscious**

Intel's FlashFile memory provides a deep powerdown mode, reducing power consumption to typically less than 0.2  $\mu$ A. Typical read current is only 20 mA while typical standby current (flash memory not being accessed with CE# high) is only 30  $\mu$ A. Additionally, FlashFile devices operating at 3.3 V<sub>CC</sub> are available for state-of-the-art low power consumption designs.

#### **Fast**

Don't be misled by technology-to-technology speed comparisons. Architecting a system around FlashFile memory bypasses the code/data bottleneck created by connecting slow mechanical serial memory (such as disks) to a high-performance, parallel-bussed processor system. For example, data seek time for a 1.8" magnetic hard disk is 20 ms, plus an 8 ms average rotational delay, while flash memory access time is less than 0.1 ms. At the chip level, read speeds for FlashFile memory are about 85 ns. Therefore, either direct execution of code from flash memory or downloading to system RAM will dramatically enhance overall system performance.

#### Nonvolatile

Unlike DRAM or SRAM, FlashFile memory requires no battery backup. Further, Intel's flash devices retain data typically for over 100 years, well beyond the useful lifetime of even the most advanced computer.

#### Rugged and Reliable

On average, today's hard-disk drives can withstand up to 10 Gs of operating shock; Intel's FlashFile memory can withstand as much as 1000 Gs. FlashFile components can operate beyond 70°C while magnetic drives are limited to 55°C. Intel's FlashFile Memory can be cycled 100,000 times per block or segment. Even beyond that cycle level, FlashFile does not fail or lock up like EEPROM devices, it just tends to take longer to erase blocks and program bytes than the times specified in the data sheet. By employing wear-leveling techniques, a 10 KB file written every 5 minutes, 24 hours a day to a 20 MB flash array takes 1.2 million hours or 136 years before reaching the 10,000 cycle level.

Many applications benefit from ROMed or XIP versions of code, particularly hand held personal computers, vertical application pen-based clipboards, and industrial control and data accumulation equipment. These applications pose system design constraints requiring small form factor, low power consumption, and ruggedized construction due to active mobile users or harsh environments. Exposure to shock, vibration, or temperature extremes is common, precluding the use of rotating media. Flash memory provides an excellent code storage choice for such system designs featuring thin TSOP packaging, low (deep powerdown mode) or zero (capability to shut off power without losing data) power consumption, and 1000 G shock resistance and extended temperature products. Additionally flash memory provides remote or end-user update capability over ROMs, allowing OEM's to service their products more efficiently and add new software features and applications after the sale.



The features of Intel's FlashFile memory truly enables new, compact and portable system architecture. This application note discusses implementing just such a design using Intel's boot block flash memory and Intel's FlashFile (28F008SA) components for extended memory eXecute-In-Place (XIP) code store, disk-like functionality for file and program storage, and BIOS code storage.

#### **Related Publications**

The following data books and reference manuals provide valuable information for developing an RFA-based design:

- Intel 28F008SA Data Sheet Order number 290429
- Microsoft MS-DOS 5.00 ROM Technical Specification and OEM Adaptation Kit (OAK)
- Microsoft Flash Filing System OAK
- Microsoft Windows 3.1 ROM Technical Specification and OAK

For additional information on flash memory, power supply solutions and EPLDs, see Appendix A.

#### 2.0 SOFTWARE DESIGN

Software design is considered first for solid-state designs because the software functionality desired affects in large part how the hardware design is implemented. Many software products exist for solid-state systems:

- DOS operating systems from Microsoft, Novell's Palm DOS and Datalight's ROM-DOS
- A Graphical User Interface (GUI) operating system in Windows 3.1 ROM version
- Application software from Microsoft (such as Word, Excel and MS-Works) and Lotus 1-2-3 Version 2.2.

Because no standardization exists, implementation differs from package to package or vendor to vendor. Therefore, this application note describes a system using MS DOS ROM Version, MS Flash Filing System, Windows 3.1 ROM Version plus Pen extensions. All are readily available applications today and offer the highest inter-compatibility. However, the hardware and software design concepts presented here work just as well with Novell's (formally DRI) Palm DOS and also GO Corporation's Penpoint operating systems.

#### 2.1 XIP Operating System

The first decision one must make for a solid-state software design is the operating system. Many alternatives exist for small hand held computer systems. Any solution depends on what requirements are placed on desktop compatibility, software compatibility, and ease of developing applications. In the pen-based market, DOS compatibility is not necessarily a requirement. This is evident by the multiple emerging entries of pen-based GUI's. However, data transfer using a medium such as memory cards between desktop systems and hand held computers depends on an agreed file format. At least for now, DOS is still the major operating system of choice for the largest number of desktop systems. Therefore, DOS compatibility is still a necessity for many hand held computing systems and is incorporated in this design.

To insure compatibility and easy system integration, MS DOS 5.0 ROM Version is the easiest choice. With this version, an XIP DOS implementation can be configured to as small as 64 KB using just the Runtime Kernel and a minimized command interpreter. If CONFIG.SYS and AUTOEXEC.BAT processing is required, an additional 56 KB are required plus a ROM DISK large enough to hold AUTOEXEC.BAT, CONFIG.SYS, and any drivers and files that are referenced by either file.

Microsoft provided the capability for additional XIP DOS applications to be added to an MS DOS XIP implementation by providing two new DOS functions, "Find First ROM Program" and "Find Next ROM Program." This allows DOS-based XIP applications (such as OEM-specific utilities and applications or Embedded DOS applications) to easily be added to the MS DOS 5 ROM build.

Many different memory configurations MS-DOS ROM are possible by distributing various software pieces (Microsoft refers to them as granules) between different ROM locations below and above the 1 MB address space. Certain restrictions exist on individual granules requiring them to appear below 1 MB. The granules and address location requirements are specified in a table within the MS DOS ROM 5.0 OAK. Approximately 43 KB of granules must be located below the first 1 MB of address space. Other granules can be located either below or above 1 MB. The total size of all granules in this design is approximately 128 KB.

#### **How MS DOS ROM Boots Up**

For system startup and booting DOS without a disk, MS DOS 5 ROM must intercept the INT 19h call made by the BIOS. This is accomplished by locating a granule as an adapter ROM within adapter space (C0000h-EFFFFh). This granule contains the ROM scan identifier "55AAh" which must appear on a 2 KB boundary and identifies the module as a ROM to the BIOS during Power On Self-Test (POST), and also identifies the MS DOS 5 ROM INT 19h interceptor. When the BIOS Post code identifies the ROM, control is turned over to the ROM for its initialization. At this time, the MS DOS 5 ROM redirects the INT 19h vector to the MS DOS 5 ROM code and control returns back to the



BIOS POST code. When the BIOS is completely finished testing and initializing, it issues INT 19h, and the MS DOS 5 ROM INT 19h handler gains control. The handler loads the MS DOS 5 ROM bootstrap loader into RAM and passes control to it. If the bootstrap loader includes the "Multi-Boot" option, a list of menu boot options are presented to the user if an OEM defined key is being pressed. The menu might look like Figure 2.

| Booting | g from a disk:                                       |
|---------|------------------------------------------------------|
| 1.      | Boot from Floppy Disk.                               |
| 2.      | Boot from Hard Disk                                  |
| Booting | g from ROM:                                          |
| 3.      | Floppy is default; process startup files.            |
| 4.      | Hard drive is default; process startup files.        |
| 5.      | Floppy is default; do not process startup files.     |
| 6.      | Hard drive is default; do not process startup files. |
| 7.      | ROM drive is default; process startup files.         |

Figure 2. Multi-Boot Menu

The menu is activated by pressing the ALT key during the system memory scan, which is the default provided in the OAK. Other types of keys may be selected by the OEM for their specific implementation. Selecting the options under Booting from a disk will bypass the ROM system completely. Selecting the options under Booting from ROM will invoke MS DOS 5 ROM and whatever the option specifies for processing the startup files, CONFIG.SYS and AUTOEXEC.BAT.

If the Multi-Boot option is not available or is not activated by the user, the MS DOS 5 ROM bootstrap loader reads a byte from CMOS RAM to determine boot options. The byte is defined in Figure 3.

| Reserved                                                                                                                                                                                                                                                                                                                        | Default<br>Drive If<br>ROM Boot | Default<br>Drive If<br>ROM Boot | ROM<br>CONFIG.SYS<br>Processing | Default<br>Boot |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|---------------------------------|---------------------------------|-----------------|
| 7 to 4                                                                                                                                                                                                                                                                                                                          | 3                               | 2                               | 1                               | 0               |
| Default Boot Bit 0:  0- Boot from ROM  1- Normal disk boot operation (first is drive 00, then drive 80)  ROM Configuration Processing Bit 1:  0- Process CONFIG.SYS and AUTOEXEC.BAT from default drive  1- Do NOT process CONFIG.SYS or AUTOEXEC.BAT files  Default Drive if ROM Boot Bits 2 & 3:  00- First Floppy Drive (0h) |                                 |                                 |                                 |                 |
| 01- First Hard Drive (80h)<br>10- ROM Drive                                                                                                                                                                                                                                                                                     |                                 |                                 |                                 |                 |

Figure 3. CMOS Byte Definitions

If the system is to boot from ROM by either selecting the Multi-Boot option or reading the CMOS byte, the MS DOS 5 ROM bootstrap loader loads BIOS (note: not system BIOS, but the BIOS layer of MS DOS) and DOS initialization granules into RAM, records the addresses of the resident BIOS and DOS code granules in the BIOS data area, records boot options (default drive, CONFIG.SYS & AUTOEXEC.BAT processing) in the BIOS data area, and passes control to BIOS initialization. Just before the end of BIOS initialization, control is passed to SYSINIT which moves itself and DOS data and initialization code to high memory where both SYSINIT and DOS initialization takes place. Next SYSINIT then reads and processes the CONFIG.SYS file where installed drivers called in CONFIG.SYS and additional elements of the DPB chain will be placed in memory following the existing DOS structures as well as system buffers allocated. At this point, system bootstrap is finished and the command interpreter is started using the DOS call to execute ROM utilities. If a full command processor is chosen, the user will now see "C:>" prompt.

#### 2.2 DOS In Flash Implementation

For this particular implementation, a full version of MS DOS with the full Command processor was chosen. This configuration uses 64 KB of adapter space (upper memory) at E0000h to EFFFFh for MS-DOS 5 ROM, and a combination 64 KB XIP binary file and a 256 KB ROM Disk binary file located in extended memory at F90000h. See Figure 4. ROM DOS and ROM Disk Memory Maps. This location is just after the end of the XIP GUI code block. The 64 KB XIP Binary contains the transient portion of COMMAND.COM and the DOS BIOS initialization and is created during the build of the MS DOS 5 ROM system, while the 256 KB ROM Drive contains the necessary files for bringing up the system and loading the MS Flash File System drivers which is addressed in the next section.





Figure 4. ROM DOS and ROM Disk Memory Maps

The E0000h segment was chosen because it happens to be free on the flash BIOS storage chip. Also, later on in this design we will be adding an RFD, which uses up the whole D0000h segment, and ExCA which requires 16 KB of adapter space that we located at CC000h (see Figure 4 for a memory map). The ROM disk image location was chosen because there was room available in the extended XIP portion. The XIP portion is located at C00000h (12 MB) due to compatibility reasons with the 386SL processor and SL window constraints. In a non-SL design, the ROM disk portion of MS DOS ROM can be located anywhere in extended memory above 1 MB.

A copy of the ROM image description file is included in Appendix B. The following summarizes the steps

taken for building a ROM version of DOS is taken from the MS-DOS 5.00 ROM OAK. Please refer to the MS-DOS 5.00 ROM OAK for specific details.

There are a set of compile options specified in the MS DOS 5 ROM OAK that need to be defined by the OEM for their particular implementation and are contained in the OAK file named "VERSION.INC". The compile options used for this example are listed as follows:



ROMDOS equ TRUE
POWER equ FALSE
ROMDRIVE equ TRUE
CMOS equ TRUE
CONFIGPROC equ TRUE

For this application this means that for:

"ROMDOS" — a ROMDOS build (as opposed

to DISK build simulation) is

used

"POWER" — the MS DOS APM and power

management are NOT used

"ROMDRIVE" — the compiler will use the internal

ROMDRIVE drivers

"CMOS" — forces MS DOS 5 ROM to look at the CMOS byte if the Multi-

at the CMOS byte if the Multi-Boot option is not chosen

"CONFIGPROC" — normal CONFIG.SYS and
AUTOEXEC.BAT processing

will be used

Since we are planning to use a ROM DRIVE, MS DOS 5 ROM needs to know where the ROM DRIVE exists. To set the ROM drive base address, the MS DOS 5 ROM OAK file ROMRDHI.ASM must be modified. Edit the file and set the ROMDRIVERBASE\_LO equal to 0000h and the ROMDRIVERBASE\_HI equal to 0FAh, or 64 KB above the base address of the extended memory XIP module.

Now the MS DOS ROM binaries are ready for building. Using the MS NMK utility, 3 separate binary files are compiled based on the requirements and addresses specified in the MS-DOS ROM Image Description file in Appendix B. ROM binary files 1 and 2 can be combined into one 64 KB binary image as follows:

copy /b ROM1.BIN+ROM2.BIN ROMDOS5.BIN

Once the XIP binaries are built, the rest of the ROM disk needs to be built. First, specify a RAM Drive within your build or development PC using the MS DOS RAMDRIVE.SYS device driver as follows:

device = RAMDRIVE.SYS 256 /e

After rebooting your PC, copy the files needed for your particular application. For an example of CONFIG.SYS and AUTOEXEC.BAT files, see Appendix C. Change the drive label as per the MS DOS 5 OAK instructions and then use the MS DOS IMGET utility to capture the image of the RAM drive into a binary file. Next, concatenate the ROM3.BIN binary image created by the NMK with the ROM Disk image captured from the RAM drive by using the MS DOS copy command as stated earlier:

copy /b ROM3.BIN+RDISK.BIN ROMDSK.BIN

This will create a 327 KB binary file with both XIP DOS code and the ROM Disk code for a single load into flash memory.

Loading the ROMDOS5.BIN file into the system's flash BIOS chip requires the use of a BIOS Independent Software Vendor's (ISV) Flash Update Utility. Most major BIOS ISVs now offer such utilities. If your particular system design uses a BIOS developed internally, refer to Intel's AP-341 "Designing an Updatable BIOS Using FLASH Memory" (order number 292077) for more information on flash BIOS designs and related software.

Loading the ROMDISK.BIN file requires developing a DOS-based utility to access flash memory in Protected Mode. Creating this utility is discussed under Section 4.0, Software Utilities, subsection 4.2 Binary Loader.

#### 2.3 Resident Flash Disk

Once a DOS-based, XIP operating system is in place, the next area to work on is file storage for flash memory. File storage is possible with either FlashFile components or FlashFile cards, since they appear the same to file system software. However, the characteristics of flash memory are very unlike magnetic storage media characteristics. File Allocation Table (FAT)-based systems rely on the fact that the operating system has unrestricted write capability and/or access to the media. particularly when updating the FAT for a file creation, update or deletion. Flash memory on the other hand, does not necessarily allow write access 100% of the time. When the flash memory media is completely erased (all FFh's), writing data to the media can occur at any time and at any location. Additional data writes within the same block but at different locations can also occur. However, once a bit is written to a zero (0b), erasure of the whole block is required before allowing that particular bit to change back to one (1b). This asymmetrical characteristic of flash memory prevents using a straight implementation of the FAT-based file architecture and requires an alternative file system implementation to take advantage of Flash Memory benefits.

#### **Blocking**

Intel's FlashFile memory offers 64 KB separately erasable blocks enhancing the use of flash memory as a file storage medium. The large block size (as opposed to 512 byte blocks or sectors) provides the system with fewer total blocks to manage, resulting in less system overhead used for file management. Additionally, large blocks reduce file fragmentation since large files will most likely be contained in one block as opposed to several 512 byte sectors. This reduced fragmentation



also improves read performance since files are more likely to be intact with a Flash File System vs. a FAT file system. These features led to the creation of Microsoft's Flash Filing System.

#### 2.3.1 MICROSOFT'S FLASH FILING SYSTEM

To enhance the use of flash memory as a disk, Microsoft created the Flash Filing System. This file system operates as a list of linked lists while keeping track of individual block erasure and file deletions, using minimal system overhead. File allocation structures use indirectly linked lists, allowing the file system to update files and data within the files without first requiring the area where the file is located to be erased and then updated. During file deletion, a file's header structure is written to mark the file as deleted, removing the file from the file allocation listing. Once the array of flash memory contains a majority of deleted files, the file system performs a (background) cleanup operation and copies good files out to free blocks and erases the blocks with all the deleted files. This achieves the goal of the user being able to use flash memory the same as they would use any other mass storage media without doing anything different.

Three distinct parts comprise the file system organization and implementation:

- A File System Redirector, whose job is to intercept the disk operations passed to MS DOS by an application and translate them into generic file operations, passing them on to the file system driver.
- A File System Driver, which accepts generic file operations passed to it from the File System Redirector, implements the architecture and logic of the Microsoft Flash Filing System, and passes low-level commands such as read, write, copy, and erase to the device driver.
- A Device Driver, which accepts low-level commands from the File System Driver and interfaces to the host system hardware implementation.

The File System Redirector performs a task analogous to a network redirector for LAN (Local Area Network) systems and appends itself to MS DOS. Any applications then think they are running from a networked file. Some classes of applications and utilities will not operate via this interface. Specifically, those applications that issue the INT 13h disk BIOS I/O call, INT 25h DosAbsRead, or INT 26h DosAbsWrite calls will not work properly with the Flash Filing system, just as they would not work over a network LAN. The File System Driver treats the flash media as a collection of large blocks, all identical in size. Individual block statistics are kept within a variable length structure at the top of

the block with the remainder of the space available for directory, file control structures and file data storage. The File System Driver also determines when de-allocated space (deleted files or directories) within a block is reclaimed for re-use.

The device driver portion is OEM-modifiable and needs to be written for the specific hardware example used. This device driver, specifically called iCARD29, is covered in more detail in the next section, ExCA Architecture, under iCARDDRV File System Driver Summary. The only MS FlashFile System hardware requirement is a single window available per socket in a system's adapter space that addresses all the flash memory to be used. Window size and base address are left to the system designer to decide, based on system design requirements. Some hardware guidelines are:

- Register-defined window size of either 4 KB, 8 KB, 16 KB, or 32 KB
- Register-defined base address in adapter space (C0000h to DFFFFh)

For more detailed information on Microsoft's Flash Filing System, consult the Microsoft Flash Filing System OAK.

## 2.4 Resident Flash Disk (RFD) and ExCA Architecture

Many systems which use an RFA will also want to incorporate PCMCIA memory and I/O cards. If an RFD uses the same software architecture used for PCMCIA cards, less software duplication is present in systems containing both cards and RFDs. This section discusses the Intel Exchangeable Card Architecture (ExCA) as it applies to an RFD and a Flash Filing system.

Most of this section was excerpted from the ExCA 1.1 Specification. The reader is encouraged to obtain that document for more details not revealed in this discussion. Other documents are the PCMCIA PC Card Standard Release 2.0, the PCMCIA Card Services Interface Specification, and the PCMCIA Socket Services Interface Specification Release 2.0.

ExCA specifies a standard host system hardware and software interface for 68 pin, PCMCIA/JEIDA memory and I/O cards. ExCA Release 1.10 defines the minimum hardware and software interfaces that card and system designers can rely on for basic compatibility across PC Cards, systems, and related software. By defining these interfaces, ExCA makes the PCMCIA goal of PC Card inter-operability a reality.



#### 2.4.1 ExCA SOFTWARE INTERFACE

The primary purpose of the ExCA Software Interface is to explicitly define a minimal set of socket control and resource access functions upon which higher-level PC Card Client device drivers can rely. A PCMCIA implementor may incorporate a range of functions beyond the basic Memory Card Interface specified in PCMCIA 1.0. For PCMCIA 2.0, three primary functional extensions to the specification exist. They are: I/O devices, L-XIP-mapped memory ("L" stands for LIM or Lotus, Intel, Microsoft), and E-XIP-mapped memory ("E" stands for Extended or Protected mode memory). While basic memory requirements can be met with a single, small memory-mapped window or even via an I/O approach, both XIP modes require direct-mapping interface capability, with very specific boundaries in the L-XIP mode. Without an ExCA-like hardware and software support for direct-mapped memory, XIP-formatted cards cannot function. The ExCA socket hardware and software specifications define basic, clear compatibility definitions for PC cards, software drivers, and host systems.

ExCA allows PC Cards and sockets to be accessed by multiple PCMCIA-aware device drivers, configuration utilities and applications, with efficient and non-conflicting use of system resources. An architectural diagram of ExCA functionality is shown in Figure 5. The primary components of the software interface are Socket Services and Card Services. Socket Services provides the lowest-level function set for socket hardware adapter control. Card Services allocates resources and coordinates PC Card-related activities for higher-level client device drivers.





Figure 5. By using the same software architecture used for PCMCIA cards, less software duplication is present in systems containing both cards and Resident Flash Disks.



#### 2.4.2 ExCA SOCKET SERVICES

ExCA Socket Services is the lowest-level software interface that directly controls PC Card sockets. Socket Services defines a software interface to manipulate socket adapter hardware in a way that is independent of hardware implementation. Socket Services defines several abstract resources which can be manipulated. An Adapter is the hardware that supports connecting one or more 68-pin PCMCIA Sockets to a host system, or in the case of a resident flash disk, the hardware that supports a memory interface only. A Socket is the hardware that supports a single 68-pin PCMCIA connector. A Window is the hardware that supports mapping a region of system memory or I/O address space to a region of card memory or I/O address space. A Card is a PCMCIA card that is inserted into a socket. Example functions are: configure a socket for an I/O or memory interface, control socket power voltages and make callbacks for PC Card insertion and status changes

Socket Services handlers use minimal RAM so that they will fit within a ROM-BIOS. The Socket Services interface can be used during POST, and must be ROM-resident to support booting from a PC Card. The interface is accessed via an 8086-compatible register-based protocol, and invoked through software interrupt 1Ah, with functions starting at 80h. This interrupt is shared with the real-time CMOS Clock Driver. The Socket Services software interrupt is called with the proper settings in the host processor's registers. The functions returns status via the Carry flag and registers specific to the function invoked.

Multiple hardware socket adapter interfaces can be supported by chaining multiple Socket Services handlers. This includes providing Socket Services support for motherboard-resident flash memory arrays by treating the control circuitry and memory array as if it were a PC Card single socket/card combination.

#### 2.4.3 ExCA CARD SERVICES

Card Services is the interface used to manipulate ExCA-related system resources. Card Services is subdivided into five functional categories: Client Services, Resource Management, Client Utilities, Bulk Memory Services, and Advanced Client Services. Client Services provide for client initialization and the callback registration of clients. Resource Management provides basic access to available system resources, combining knowledge of the current status of system resources with the underlying Socket Services adapter control functions. Client Utilities perform common tasks required by clients so that functions, such as CIS (Card Information

Structure) tuple access, do not need to be duplicated in each of the client device drivers. Bulk Memory Services provide read, write, copy, and erase memory functions for use by file systems or other generic memory clients that need to be isolated from memory hardware details. Advanced Client Services provide specific functions for clients with special needs.

Card Services provide a packet-based request interface (i.e., uses a block of RAM for passing inputs and outputs between the caller and the interface) which provides a standard protocol for PC Card client device drivers to access cards and their required system resources. It provides separate registration and callbacks for card insertion and card status change event notifications, allowing associated client device drivers to take the appropriate actions. For file system read, write, erase and copy operations, a special interface is provided for Memory Technology Drivers (MTDs) which can handle the details of different memory technologies.

#### NOTE:

This interface is not used by iCARD29. Instead, the MTD functions are built into iCARD29.

Resource Management provides a protocol for sharing resources within an environment, where previously the end-user was responsible for resolving resource conflicts. Resource Management resolves resource contentions without end-user interaction.

Advanced Client Services contains a ReturnSSEntry function which is essentially a direct bypass to Socket Services. Card Services require Socket Services to manipulate PC Cards and socket hardware. ExCA client drivers should typically interact directly with Card Services and not Socket Services.

Card Services is typically implemented as a device driver. Card Services provides function number AFh in the Socket Services interrupt 1Ah interface for real-mode operation. During initialization, Card Services determines the state of the host environment. This includes determining available system memory, available I/O ports, IRQ assignments, installed PC Cards and socket state. How this is performed is implementation specific.

#### 2.4.4 iCARD29 FILE SYSTEM DRIVER

iCARDRV2.EXE is an Intel developed, low-level, flash memory driver for the MS Flash Filing System. It provides read, write, copy, and erase functions within the ExCA architecture and interfaces to a PCMCIA standard Card Services 2.0 (which provides proper resource arbitration). iCARD29 is completely independent of other peer level drivers and performs no direct calls to



Socket Services. Support for Intel's Series 1 and Series 2 flash memory cards and the RFA flash disk is provided. iCARD29 is also used to read ROM cards and read/write SRAM cards.

#### 2.4.5 RFD SOCKET SERVICES

RFD "SocketServices" functions similar to ExCA SocketServices in that the software interface to manipulate socket adapter hardware is preserved, but an RFD SocketServices does not control any sockets or cards or respond to card removal and insertion events. RFD SocketServices allows a resident flash disk implementation, through chipset logic or external logic, to appear to ExCA software and the system as another Adapter using a single Window mechanism, accessing permanently installed flash memory on a motherboard. All the rest of ExCA SocketServices functions are kept as they relate to this definition. An example of a nonworking RFD SocketServices function is using it to configure an I/O card. If requested to complete such an operation, RFA SocketServices will respond with "Function not supported."

For more information on the specific hardware design used for a Resident Flash Disk, refer to Section 3.5.

## 2.5 XIP Graphical Users Interface (GUI) Overview

Many GUIs exist today, but not all are configured to run in a minimized XIP mode for portables. Some designs may implement a simple DOS-based pen interface on top of an XIP DOS, like Communications Intelligence Corporation's PenDOS\*, and add a single application like a forms recorder. Other designs may not use XIP DOS at all and the system design revolves around the XIP GUI requirements alone.

Microsoft leads the rest of the software industry in XIP GUI development, releasing the Windows 3.1 ROM Development Kit in September of 1992 and recently introducing the Modular Windows Development Kit in January of 1993. Both are XIP GUI implementations of the Windows GUI Operating System and are fully modularized for OEM configuration. Modularization assists OEMs by simplifying the streamlining of an O/S's suitability to task by allowing the OEM to choose which functions are important and required for a particular design and which functions can be left out. Benefits to the OEM are:

- Preserved API for using existing Windows applications or new application development
- Reduced development time and costs by using standard Windows application development tools and a wide choice of Windows software developers
- Ease of use for end-user

#### Modular Windows

Microsoft's Modular Windows Operating System uses a subset of the Windows 3.1 Operating System and includes extensions supporting TV-based multimedia players. Target market is home entertainment, but could easily be adapted for machine control on factory floors. The differences between Modular Windows and Windows 3.1 ROM are summarized below:

- Reduced support for the Windows 3.1 application programming interface (API)
- Reduced support for Windows 3.1 extension libraries
- New user-interface controls (instead of pull-down menus)
- New support for hand-control input devices

Software requirements are:

• MS DOS 5.0 in XIP form

System requirements are:

- 80286 or greater CPU
- 1 MB RAM minimum
- 1 MB of XIP memory (Flash, EPROM, or ROM)

Since the focus of this application note is personal computers, Sub-Notebooks and below, Modular Windows implementations will not be discussed. However, many of the principles of putting Modular Windows code in flash memory (memory maps, software tools, flash updatability, etc.) are the same here as the Windows 3.1 ROM example which is discussed later in this section.

#### Windows 3.1 ROM Version

Computers running Windows in ROM or XIP mode are very similar to standard PC running disk-based Windows. The only major exception is the presence of a large amount of XIP code storage in extended memory from which Windows executes, and a smaller amount of XIP code storage in adapter space. For the rest of this discussion, the Windows XIP code stored in extended memory is referred to as HIROM.BIN and the small amount of Windows XIP code stored in Real Mode space is referred to as LOROM.BIN.

Two modes of operation are possible for XIP Windows; Standard and Enhanced, just as on disk-based PCs. However, each require different system resources for the XIP Windows version.



For Standard Mode, Windows executes fully in ROM, leaving almost all the system RAM available for user programs. This means that all Windows "core code" including DOSX.EXE, USER.EXE, GDI, the Windows kernel and all drivers run from XIP storage space. Also, all shell programs, applets, fonts and other Windows resources are stored in and run from XIP storage space without being loaded into RAM.

Enhanced Mode Windows must execute partially from RAM. Enhanced Mode components such as WIN386.EXE and VxDs (virtual device drivers) must be loaded into RAM from some type of disk (a flash disk, ROM disk, or flash card) for execution, as their code writes back to their execution location from time to time and creates errors if loaded into XIP code storage such as flash memory. Components shared between modes, specifically USER.EXE, GDI, the kernel and drivers, continue to run from their stored locations in XIP address space.

Additionally, for either Standard or Enhanced modes, all Windows 3.1 features are supported in XIP Windows. The only limiting factors are the amounts of available RAM, XIP storage and, in the case of Enhanced mode, disk space.

#### **Adding Applications**

The Windows 3.1 ROM Development Kit (RDK) can add any Windows executable program or application into the main XIP binary image file HIROM.BIN. The application must conform to the XIP application requirements specified in the Windows 3.1 Technical Specification. Microsoft is capable of supplying XIP versions of Word for Windows, Excel, Microsoft Mail and Microsoft Works but must be developed between an OEM and Microsoft on a platform-by-platform basis.

Once the O/S and application functionality is determined and the build script CONTENTS.ROM edited, the RDK produces two binary images: the large HIROM.BIN Extended mode image containing O/S and application code, and the small Real mode LOROM.BIN image containing the listing of all the XIP code contained in HIROM.BIN. After both XIP Windows binary files are loaded into flash memory and the system is up and running, clicking on an application causes the XIP Windows kernel to search its internal listing (LOROM.BIN) for an XIP image module first. If the image is not found within the XIP listing, the Windows kernel then searches the file paths present at runtime to try and load the application from its current file directories. If the program is not found within

file directories, XIP Windows returns "Application missing, file not found." Additions of other extensions to the XIP image such as multimedia support and Pen Windows are added in a similar manner.

#### 2.6 XIP GUI Implementation

As mentioned earlier, XIP Windows requires two modules; a small amount of XIP storage in device adapter space called LOROM.BIN, and a larger amount of XIP storage called HIROM.BIN in extended memory space. The LOROM.BIN file contains information about the modules loaded in the HIROM.BIN XIP (see Figure 6) image and must be accessed in real mode by three modules, WIN.COM, RSWAP.EXE, WIN386.EXE. Additionally, portions of the DOS extender (DOSX.EXE) must be able to run in real mode and are therefore located in the LOROM.BIN XIP image. The information the three modules look for is contained in the ROM Table Of Contents (ROMTOC), also located in LOROM.BIN and contains general information about both XIP images (small and large), entry point addresses for initialization, and a list of the executables stored in the large XIP image.



Figure 6. 16 MByte XIP GUI Memory Map

The extended memory XIP image contains the bulk of the system's code and data segments, EXE headers, and a prototype Local Descriptor Table (LDT) which is a data structure defining the addresses, sizes and types of segments used by 80286, Intel386<sup>TM</sup>, or Intel486<sup>TM</sup> processors. For more information on a Windows 3.1 XIP-based system, please refer to the Microsoft Windows 3.1 ROM Development Kit.



#### **Software Requirements**

- MS DOS 5.0 or equivalent in XIP mode
- Software Utility to load both small and large XIP images into flash memory
- For Enhanced Mode disk space requirements, MS Flash Filing System 2.0 combined with ExCA software for a Resident flash disk.

#### **System Requirements**

- 80286 CPU or greater
- RAM: Minimum of 1 MB for Standard Mode or 2 MB for Enhanced mode
- XIP Store: Minimum of 2 MB for Standard Mode, 3+ MB for Enhanced mode
- Flash Disk Store: Zero for Standard Mode, 2 MB for Enhanced mode

For this particular design example, Enhanced mode functionality is used to show a full implementation of Windows. An RFD is used to load WIN386.EXE, VxDs and all the \*.INI and \*.GRP files. A complete listing of the CONTENTS.ROM file used by the Windows ROM Image Builder utility to create an XIP Windows system is shown in Appendix D. The Windows RDK Enhanced Full sample CONTENTS.ROM file is used as a template and edited to locate the LOROM.BIN file at C8000h and is a total of 16 KB. The HIROM.BIN file is located at C00000h and is a total of 3.6 MB.

#### 2.7 Pen Extensions

Microsoft's Windows for Pen Computing is an extension to Microsoft Windows version 3.1 and has its own SDK. Pen Windows Extensions do not require any changes to existing Windows 3.1 applications and a se-

lection of pen recognizer drivers come bundled in the SDK provide for fast development of a pen-based system. In particular, the Wacom PL-100V pen tablet and VGA graphics card can be added to an ISA bus slot for early debug and pen software development.

All the Pen Windows extensions are directly executable within the HIROM XIP image and can be added to the CONTENTS.ROM listing.

#### 3.0 HARDWARE

This section describes the general hardware requirements for an RFA design, then discusses a specific implementation using the SL architecture as an example (primarily due to the built-in ISA Sliding Window). Many of the concepts presented here can easily be incorporated into new chipsets designs to take advantage of the benefits flash memory brings to solid-state designs.

#### 3.1 Resident Flash Disk Implementation

As stated in Section 2.3, the MS Flash Filing System requires a hardware mapping window in Real Mode address space. This window is similar in function to an EMS mapping window, but unlike EMS this window interfaces directly to flash memory. The SL Superset provides an example of just such a mapping, using in the ISA Sliding Window. The window is configured via the SL's ISAWINDOW register and has a fixed base address of D0000h and a fixed size of 64 KB. By setting the correct address in the register, the full 16 MB ISA address space is viewable in 64 KB increments. Additionally, the register defines access to the 16 MB flash disk address space made available by a separate flash disk Chipselect (see Figure 7).





Figure 7. Flash Disk Mapping



Although the built-in functionality of the ISA Sliding Window is quite nice, the large 64 KB footprint of the window in Real Mode address space is difficult to work around. For a non-SL implementation, smaller, more flexible sliding windows are possible through external logic (FPGAs or EPLDs) or hopefully from future PC chipsets desiring to provide the capability the flash memory offers. The hardware requirements are simply:

- A Window base address that appears in Real Mode memory somewhere in adapter space (C0000h to DFFFFh) that is also register definable.
- 2. A Window size that is also register definable for either 4 KB, 8 KB, 16 KB, or 32 KB.

These two options provide a level of flexibility for an OEM's system implementation and reduces the memory footprint in adapter space.

The flash disk address mapping in Figure 7 shows the flash disk and ISA bus address maps together. The SL's ISA Sliding window allows 64 KB blocks of the flash disk address space to be mapped into the Real mode area from D0000h to DFFFFFh for access by the MS FlashFile System. For some ideas on how to implement an external logic flash disk implementation, see AP-343 "Solutions for High Density Applications Using Intel Flash Memory," order number 292079. The application note describes a complete design for an ISA Bus add-in card. A local bus design can be derived from the ISA Bus implementation or the SL implementation logic discussed in Section 3.6, Schematic Overview.

#### 3.2 XIP DOS Implementation

As stated in Section 2.2 DOS in Flash Implementation, MS DOS 5.0 ROM Version is built assuming the E0000h segment location and also consists of a ROM Disk located in extended memory at F90000h. The only reason for the ROM disk location is to avoid 386SL co-

processor errata at the 8 MB location and window base address constraints, which must be divisible by the window size in use. In non-SL designs, the ROM Disk can be located anywhere above 1 MB in a NON-cacheable region. The design example uses Intel's 2 Mb, 28F002BX-T boot block flash memory. This device is organized with varying sized blocks; a 16 KB hardware lockable boot block, two 8 KB separately erasable Parameter Blocks, and separately erasable 96 KB and 128 KB main code blocks. To unlock and allow programming and erasure of the boot block, an additional 12V must be applied to the PWD# pin, thereby guaranteeing hardware protection. The benefit of using boot block architecture is that in the unlikely event that something happens during a BIOS code update, the system can recover using the kernel code in the boot block to initialize enough of the system to access a floppy drive or memory card socket to load in BIOS update code and a BIOS binary file.

Using a 2 Mb (256 KB) device enables the design to use a single memory chip for 4 separate code modules: the standard AT compatibility BIOS (64 KB), MS DOS 5.0 ROM (64 KB), Video BIOS (32 KB), and Power Management Code (32 KB). The sum of all 4 modules is greater than 128 KB and if mapped straight down from the top of the 1 MB address space, could cover both the BIOS and all of the adapter space. To avoid this conflict, some chipset designs physically position the BIOS function at the top of the 16 MB memory map, then use 64 KB mapping windows to position the correct block between E0000h and FFFFFh.

The SL Superset provides a second BIOS ROM chipselect enabling only one 128 KB portion to appear at E0000h to FFFFFh at a time. Additionally, the SL Superset provides an ISA Sliding Window which allowed windowed access into protected mode space. Figure 8 shows how each module is mapped into the boot block flash memory.





Figure 8. Boot Block Mapping

The boot block flash memory chip is physically located at the top of the 16 MB address space, but the SL Superset logically locates the top 128 KB of the chip into Real Mode address space just below 1 MB. Additionally, an exclusive OR gate is tied to the highest order address line, flipping the 2 Mb boot block chip at its mid point. This places the locked boot block just under the first 128 KB of the part, while the other 128 KB containing the AT System BIOS and MS DOS 5.0 ROM appears at the top of the device. This is done to position the boot block (which contains BIOS recovery code) out of the IBM BIOS compatibility table area, allowing access to the AT System BIOS and MS DOS ROM code.

When the system boots, the processor jumps to the AT BIOS location by default. As the system is booting, the BIOS enables the ISA Sliding Window to access the other 128 KB of boot block flash memory, and proceeds to copy the Power Management code to its special location within the System Management Mode space. Next, the BIOS copies the Video BIOS code into shadow memory at CO000h to C7FFFh and turns off the ISA Sliding Window. The BIOS then scans the MS DOS 5.0 ROM adapter code, and allows MS DOS ROM to hook INT 19h, and finishes the rest of its POST before turning control over to DOS by issuing INT 19h.



#### 3.3 XIP GUI Implementation

As stated earlier, Windows 3.1 ROM Version takes up 3.6 MB of extended address (HIROM.BIN) and 16 KB of Real mode adapter address space (LOROM.BIN). HIROM.BIN can be located anywhere above 1 MB and should probably be high enough above the DRAM address space to allow additional DRAM to be added to the system by the end-user. Ideally, the system design should be able to cache the area where the Windows HIROM XIP code is located. This allows the system to take advantage of XIP code locality since XIP code should produce a very high cache hit ratio. Since the 28F008SA Flash-File memory is a x8 device, x16 access is accomplished by pairing two devices for a LOW Byte HIGH Byte configuration. This creates an erasable block size of 128 KB.

The LOROM.BIN file has a couple of implementation options. One method is to use a spare block out of the extended memory XIP region. This method requires external logic to decode the specific adapter space address dedicated to the LOROM function, and generate a chipselect to the last block of flash memory. Since the LOROM.BIN file size is only 16 KB and the smallest erasable block size is 128 KB, 112 KB of the block is left unused. Given that the HIROM and LOROM files are updated together, the HIROM file could feasibly use the extra space if necessary.

Another option for the LOROM file is to use some free storage space within the 2 Mb boot block flash memory chip. The file could then be copied to the correct adapter space shadow RAM location at boot time. Copying the LOROM.BIN file can occur at the same time that Video BIOS and Power Management code are copied. This method provides update capability while reducing external logic requirements. The only hinge factor is getting the system's BIOS code to copy the file before or during POST.

Either option is possible. The choice is dependent on determining which is easier, modifying hardware or modifying a BIOS bootup process.

#### 3.4 Chipset Considerations

Chipset designers interested in implementing an RFAready chipset should consider the following recommendations for RFA hardware requirements:

#### Flash BIOS > 128 KByte

 Minimally, include a Flip Bit on the highest order address line. This allows 128 KB pages to move in and out of the same 128 KB address space.  Position the BIOS at the top of 16 MB or 32 MB address space, keeping the flip bit and include a window mapping mechanism similar to an EMS-like window. This window provides temporary Real mode access of the 2nd 128 KB of BIOS code storage.

#### **RFD Functionality**

- Include a built-in Flash disk Chipselect to minimize external logic
- Add an EMS-like mapping window
  - Register defined, base address between C0000h and DFFFFh
  - Register defined window size adjustable 4 KB, 8 KB, 16 KB, and 32 KB
  - Register address capability to 64 MB RFD

#### **XIP Code Functionality**

- Include a built-in XIP Flash Chipselect
- Add 2 register defined, cacheable windows
  - Adjustable base address anywhere above 1 MB
  - Size adjustable 2 MB, 4 MB, or 8 MB

#### 3.5 SL Based Design

Lacking an off-the-shelf, RFA-ready chipset and system, an SL Superset design is used as an example. To achieve as close to local bus access times as possible, the SL's Peripheral Interface (PI) Bus is used. The PI Bus is asynchronous and runs a CPU cycles plus one additional wait state.

To position the FlashFile memory on the PI Bus into the system's address map, a spare Video Window register (GABCR) is used (see Figure 9). For the design example, a base address of C00000h is used combined with a window size of 4 MB. The C00000h base address avoids some conflicts with 386SL systems at the 8 MB address location. Since the GABCRs window base address must be divisible by its size, the 12 MB address made the most sense (avoiding the 8 MB location) while being high enough to allow at least 8 MB of system RAM. For any other XIP system design, any base address should be usable. Although the GABCR register positions the FlashFile memory correctly and routes all system address map accesses to C00000h to FFFFFFh to the PI Bus, by the fact that the GABCR is a graphics window, it is defined as a non-cacheable window.

Include a cache enable/disable bit within the register

These requirements work for non-Intel architecture just as well as for the Intel architecture.





#### 3.6 Schematic Overview

Appendix F contains schematics for the SL Superset example design. This section reviews the major portions of the schematic.

Even though the SL Superset provides a flash disk Window and Chipselect, two EPLDs are needed to decode the flash disk Chipselect from Video Chipselects, while the XIP flash memory required externally generated chipselects. Additional logic is also needed to decode the LOROM.BIN stub at CC000h and route the access to the highest block of XIP Memory.

The RFA example design uses both an Intel 85C090-15 and an Intel 5AC312-25 EPLD to provide board con-

trol logic. This logic generates flash memory chip enables, flash memory control signals, ROM Stub decoding, PI bus cycle decoding and bus cycle termination, and enables the mode registers. For details on the EPLD equations, see Appendix E.

#### 85C090

The Intel 85C090 also controls the mix between how much flash memory is used for Resident Flash Disk Memory (FDM) and how much flash Disk Memory (RFD) and how much flash memory is used for XIP Memory. The EPLD description files in Appendix E show how to change the equations to obtain the desired mix needed for any particular OEM's implementation.



#### 5AC312 Mode Registers

The 5AC312 provides two registers to control V<sub>PP</sub>, power down, and the Ready Interrupt. The registers are written and read with PI Bus Memory cycles to the upper 64 KB of the Flash Disk Address Plane. This space is otherwise unused; no flash memory resides there. Address assignments in the flash disk plane are as follows:

FF0000h Power Control Register (Wt/Rd)
FF0002h Interrupt Control Register (Wt/Rd)
FF0004h (Reserved)
FF0006h Clear Flash Disk Memory READY
Interrupt (Wt only)

The Clear Flash disk Memory READY Interrupt is not used with FlashFile System 1.0. It is intended to be used with the next file system from Microsoft. The above assignments alias every 8 Bytes (4 words) up to FFFFFFEh.

The Power Control Register bits are defined as follows:

| Bit  |                                         |
|------|-----------------------------------------|
| 0    | Enable all Flash Memory V <sub>PP</sub> |
|      | (if jumper E9-E10 installed)            |
| 1    | (Reserved; reads as a zero)             |
| 2    | (Reserved; reads as a zero)             |
| 3    | Power Down all flash memory             |
| 4-15 | Undefined                               |

The Interrupt Control Register bits are defined as follows:

Bit

- 0 Enable Flash Memory READY Interrupt
- 1 Flash Memory READY Interrupt (Read only)
- 2 Flash Memory Any Zone Busy (Read only)
- 3 (Reserved; reads as zero)
- 4-15 Undefined

Reserved bits should be written as zeroes; they will read as zeroes. Undefined bits should be written as zeroes; they may read as either zeroes or ones.

Cold boot (RSTDRV) clears all defined bits in the register. Warm boot (CTRL-ALT-DEL) does not affect the contents of the register.

The Flash Memory READY interrupt is cleared by writing to address FF0006h in the flash disk Address plane. The data written is not interpreted; it should be all zeros.

A major power consumer on the RFA example design board is the 85C090 EPLD. This is due to using Turbo Mode to quickly decode the PI Bus signals and minimize RFA access time. Unfortunately, this causes a constant current draw of 160 mA. The EPLD's Normal mode cannot be used since there is no advance warning of an XIP flash memory access.

#### PRDY# Enable Jumper

The PI Bus signal PRDY# has a very weak pull-up resistor on the motherboard. Consequently, it has to be driven high (inactive) for a short time at the end of each cycle. Timing for this logic comes from the early taps on the delay line as follows:

100 Nanosecond delay line (SXTTLDM-121)E4-E5

200 Nanosecond delay line (SXTTLDM-125)E4-E3

#### **Power Control**

The purpose of the SMOUT4 signal was to allow the RFA Daughter board to perform a local standby, powering down various devices on the RFA Daughter board. However, since the EPLD must remain powered on until Global suspend, and consumes a high amount of current compared to the FlashFile power consumption, local standby was not implemented.

#### 4.0 SOFTWARE UTILITIES

A few software utilities need to be created to load the binaries created for XIP code implementations.

#### 4.1 RFA Diagnostic

It is highly recommended that system designers develop simple diagnostic tools to test the hardware at a very low level (i.e., write byte, write word, read word, erase block). Such a tool proves invaluable when debugging new hardware and software designs and resolving hardware and software conflicts.



#### 4.2 RFA Binary Loader

The RFA Binary files HIROM.BIN, LOROM.BIN, and ROM Disk must all be loaded into Protected Mode from Real Mode. This can be accomplished a number of ways:

- Use a DOS Extender. This provides a quick method to create a utility using the tools a DOS extender provides. However, licensing may prove to be difficult or expensive.
- Using BIOS-based extended memory calls. These actually worked quite nicely and reliably, but proved to be slow and doubled the time to erase and program HIROM.BIN.
- Putting the processor in flat mode. This method allows for fast, direct access to the extended memory, but cannot be done under windows.

For lab testing, our binary loader used a simple file name plus command line parameters. A system for endusers would need a more elaborate user interface to guide them through the software update. Some basic software requirements outside of the basic file read/ write capabilities and command line parsing for the flash memory Binary Loader are:

Incorporate basic flash memory program and erasure commands. These software drivers are available for both ASM86 and "C" in Application Note-360 "28F008SA" Software Drivers, order number 292095-002. This application note addresses things like read device identifier, Vpp ramp time, x8 and x16 parallel programming and block erasure by providing proven, tested routines for each.

- Choose a method of Protected Mode access that makes the most sense for you.
- Allow for specific base addresses to be entered by the user, while within the program automatically determining what block and the number of blocks to be erased from the base address and binary file size.

#### 5.0 SUMMARY

This application note discussed a new system architecture based on solid-state software and hardware design concepts. This new architecture is based on using flash memory for the following; BIOS + DOS code storage, a nonvolatile RAM disk or RFD, and as XIP GUI code storage or RFX. Specific flash memory component and PCMCIA card information is found in their respective datasheets. Contact your local Intel or distribution sales office for more information or to obtain assistance in evaluating Boot Block or FlashFile memory components, as well as Intel's product line of PCMCIA Flash Memory Cards.



## APPENDIX A ADDITIONAL PUBLICATIONS

- Intel "28F008SA Hardware Interfacing" Application Note Order number 292094
- > Intel "28F008SA Software Drivers" Application Note Order number 292095
- Intel "Power Supply Solutions for Flash Memory" Application Note Order number 292092
- ➤ Intel 85C090 24-Macrocell CHMOS EPLD Order number 290247
- Intel 5AC312 12-Macrocell CHMOS EPLD Order number 290247

292097-9





## APPENDIX B MS DOS ROM IMAGE DESCRIPTION

| ***************************************           |
|---------------------------------------------------|
| RFA ROM DOS Description File                      |
| OM image description file for 64K of ROM space at |
| E0000-EFFFF and one 256K ROMDISK module at F90000 |
| \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\            |
| ctual file sizes created: Three 32K modules       |
| M1=Int 19 hook and Resident DOS Code              |
| M1SIZE=8000                                       |
| M1MAX=7FFF                                        |
| M1TYPE=SEG                                        |
| M1ADDR=E000                                       |
| M1CHKSUM=YES                                      |
| MINUMBLOCKS=40                                    |
| M1FILES=\romhead\romboot.bin\dos\resdos.16        |

ROM2=COMMAND ROM Hdr Res. BIOS Code Bootstrap loader Resident Command Code

ROM2SIZE=8000

ROM2MAX=7FFF

ROM2TYPE=SEG

ROM2ADDR=E800

ROM2CHKSUM=YES

292097-10

#### ROM2NUMBLOCKS=40

ROM2FILES=..\cmd\command\romhead.bin ..\bios\resbio.16 \ ..\romload\romhoad.sys ..\cmd\command\rescom.16 ..\dos\romdos.sys

ROM3=Command interpreter
ROM3SIZE=10000
ROM3MAX=FFFF
ROM3TYPE=BASE
ROM3ADDR=F90000
ROM3FILES=..\cmd\command\command.16 ..\bios\rombio.sys





## APPENDIX C ROMDISK CONFIG.SYS AND AUTOEXEC.BAT

#### **AUTOEXEC.BAT**

@echo off
prompt \$P\$G
set path=c:\;d:\rdk10\build\disk;d:\utils;d:\diags;
c:\doskey
doskey d=dir \$1 \$2
d:\rdk10\build\disk\smartdrv.exe 1024 1024
set TEMP=d:\
ver /r
echo "MS DOS ROM, Card & Flash Disk SS 2.0, MS FlashFile System 2,"
echo "and Windows 3.1 ROM"

#### **CONFIG.SYS**

DEVICE=c:\HIMEM.SYS

break=on buffers=40

files=40

lastdrive=H

DOS=HIGH,UMB

REM FlashFile System Drivers

Device=C:\rfaslss.sys

Device=C:\ss365sl.exe

Device=C:\cs.exe

Device=C:\rtinit.exe

Device=C:\icard29.exe

Device=C:\ms-flash.sys





# APPENDIX D WINDOWS 3.1 CONTENTS.ROM

NOTE: Semi-colons denote a commented-out line which is NOT added to the HIROM Binary file.

| NOTE: Semi-colons denote a commo                                                                                         | ented-out line which is NOT added to the HIROM                                                                                                                                                     | Binary Ille. |        |
|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|
| Windows 3.1 ROM Development I<br>Sample ROM Description File<br>Copyright Microsoft Corporation, 1                       |                                                                                                                                                                                                    |              |        |
| Enhanced Mode, Full<br>10/20/92 Removed TT Fonts                                                                         |                                                                                                                                                                                                    |              |        |
| ROMS                                                                                                                     |                                                                                                                                                                                                    |              |        |
| Specifies length of ROMs and the lat which they are to appear.                                                           | linear addresses                                                                                                                                                                                   |              |        |
| Name Address Length (max)                                                                                                |                                                                                                                                                                                                    |              |        |
| LoROM 0c8000 004000 ; 16k<br>HiROM C00000 3FFC00 ; 4 Mb                                                                  |                                                                                                                                                                                                    |              |        |
| TABLES                                                                                                                   |                                                                                                                                                                                                    |              |        |
| Specifies information for tables to                                                                                      | reside in ROM.                                                                                                                                                                                     |              |        |
| ROMTOC 100 LoROM<br>NUMFILENT 14<br>LDT 1024 HIROM 256<br>WINFLAGS 13<br>WINFLAGS 15<br>SYSDIR system<br>ROMVERSION 1000 | ; ROMTOC entries ; FILES entries ; Local Descriptor Table ; 286 version; Value is in HEX ; 386 version; Value is in HEX ; Windows directory on disk (optional) ; 1 = masked ROM, 000 = OEM version |              |        |
| MODULES                                                                                                                  |                                                                                                                                                                                                    |              |        |
| Specifies modules to be loaded into Format is as follows:  Module SEG File ROI                                           |                                                                                                                                                                                                    |              |        |
| DOSX.EXE %ROMFILES%do<br>SEG 2 HIRON                                                                                     | •                                                                                                                                                                                                  | MS DOS ext   | tender |



HiROM SEG 3 : DXPMCODE %ROMFILES%krnl286.exe HiROM : KERNEL.EXE : 286 kernel KERNEL EXE %ROMFILES%kml386.exe HiROM ; 386 kernel (ROM version) : Drivers (Replaceable) -SYSTEM.DRV %ROMFILES%system.drv HiROM ; System KEYBOARD.DRV %ROMFILES%keyboard.drv HiROM ; Keyboard SEG 10 COMP : Do not remove! : Display VGAROM2.DRV %ROMFILES%vgarom2.drv HiROM ; 386 VGA ; 286 SuperVGA ; 286 SuperVGA ; VGAROM2.DRV %ROMFILES%vgarom2.drv HiROM ; SVGAR2.DRV %ROMFILES%svgar2.drv HiROM ; SVGAR3.DRV %ROMFILES%svgar3.drv HiROM ; 386 SuperVGA HiROM MOUSE.DRV %ROMFILES%mouse.drv : Mouse **SEG 2 RAM COMP NORELOC** : Do not remove! ; NOMOUSE.DRV %ROMFILES%nomouse.drv HiROM : No mouse COMM.DRV %ROMFILES%comm.drv HiROM : COM. LPT **SEG 2 RAM COMP NORELOC** : Do not remove! SEG 3 COMP ; Do not remove! MMSOUND.DRV %ROMFILES%mmsound.drv HiROM : Sound : Core ----%ROMFILES%gdi.exe HiROM : ROM version GDI.EXE USER.EXE %ROMFILES%user.exe HiROM : ROM version SEG 3 RAM COMP NORELOC ; Do not remove! : Non-Replaceable System DLLs -----SHELL.DLL %ROMFILES%shell.dll HiROM ; Shell APIs LZEXPAND.DLL %ROMFILES%lzexpand.dll HiROM WIN87EM.DLL %ROMFILES%win87em.dll HiROM ; Expansion : Math emulator ; Replaceable System DLLs -----COMMDLG.DLL %ROMFILES%commdlg.dll HiROM STUB : Common dialogs OLECLI.DLL %ROMFILES%olecli.dll HiROM STUB : OLE Client OLESVR.DLL %ROMFILES%olesvr.dll HiROM STUB ; OLE Server TOOLHELP.DLL %ROMFILES%toolhelp.dll HiROM STUB ; Tool Help DLL DDEML.DLL %ROMFILES%ddeml.dll HiROM STUB : DDE %ROMFILES%ver.dll HiROM STUB VER.DLL ; Version DLL ; Multimedia Extensions -----MMSYSTEM.DLL %ROMFILES%mmsystem.dll HiROM STUB ; Multimedia



| SND.CPL %RETAIL%snd.cpl HiROM<br>MPLAYER.EXE %RETAIL%mplayer.exe HiROM<br>SOUNDREC.EXE %RETAIL%soundrec.exe HiROM                                                                                 | ; Sound icon<br>; Media Player<br>; Sound Recorder                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| ; Advanced Power Management (APM)                                                                                                                                                                 |                                                                                                 |
| ; POWER.DRV %RETAIL%power.drv HiROM                                                                                                                                                               | ; APM driver                                                                                    |
| ; Shell Programs                                                                                                                                                                                  |                                                                                                 |
| PROGMAN.EXE %RETAIL%progman.exe HiROM WINFILE.EXE %RETAIL%winfile.exe HiROM TASKMAN.EXE %RETAIL%taskman.exe HiROM WINHELP.EXE %RETAIL%winhelp.exe HIROM WINTUTOR.EXE %RETAIL%wintutor.exe HIROM   | ; Program Mgr<br>; File Manager<br>; Task Manager<br>; Windows Help<br>; Tutorial               |
| ; Control Panel                                                                                                                                                                                   |                                                                                                 |
| DRIVERS.CPL %RETAIL%drivers.cpl HiROM MAIN.CPL %ROMFILES%main.cpl HiROM CONTROL.EXE %RETAIL%control.exe HiROM                                                                                     | ; Drivers icon<br>; Main icons<br>; Control Panel                                               |
| ; Printing Support                                                                                                                                                                                |                                                                                                 |
| ; PRINTMAN.EXE %RETAIL%printman.exe HiROM<br>; UNIDRV.DLL %ROMFILES%unidrv.dll HiROM<br>; DMCOLOR.DLL %ROMFILES%dmcolor.dll HiROM                                                                 | ; Print Mgr<br>; Uni driver<br>; Uni driver                                                     |
| ; System Fonts                                                                                                                                                                                    |                                                                                                 |
| VGASYS.FON %RETAIL%vgasys.fon HiROM<br>VGAFIX.FON %RETAIL%vgafix.fon HiROM<br>VGAOEM.FON %RETAIL%vgaoem.fon HiROM                                                                                 | ; System (VGA)<br>; Fixed pitch<br>; OEM                                                        |
| ; Bitmap Fonts                                                                                                                                                                                    |                                                                                                 |
| COURE FON %RETAIL%coure fon HIROM<br>SERIFE FON %RETAIL%serife fon HIROM<br>SMALLE FON %RETAIL%smalle fon HIROM<br>SSERIFE FON %RETAIL%sserife fon HIROM<br>SYMBOLE FON %RETAIL%symbole fon HIROM | ; Courier (VGA)<br>; MS Serif (VGA)<br>; Small (VGA)<br>; MS Sans Serif (VGA)<br>; Symbol (VGA) |
| ; Plotter Fonts                                                                                                                                                                                   |                                                                                                 |
| MODERN.FON %RETAIL%modern.fon HiROM<br>ROMAN.FON %RETAIL%roman.fon HiROM<br>SCRIPT.FON %RETAIL%script.fon HiROM                                                                                   | ; Modern<br>; Roman<br>; Script                                                                 |
| ; TrueType Fonts                                                                                                                                                                                  | <del>-</del> ·                                                                                  |



| ARIAL.FOT %RETAIL%arial.fot HiROM ARIALBD.FOT %RETAIL%arialbd.fot HiROM ARIALBI.FOT %RETAIL%ariali.fot HiROM ARIALI.FOT %RETAIL%ariali.fot HIROM COUR.FOT %RETAIL%cour.fot HIROM COURBD.FOT %RETAIL%courbd.fot HIROM COURBI.FOT %RETAIL%courbi.fot HIROM COURI.FOT %RETAIL%courbi.fot HIROM SYMBOL.FOT %RETAIL%symbol.fot HIROM TIMES.FOT %RETAIL%times.fot HIROM TIMESBD.FOT %RETAIL%timesbd.fot HIROM TIMESBD.FOT %RETAIL%timesbd.fot HIROM TIMESBI.FOT %RETAIL%timesbd.fot HIROM TIMESBI.FOT %RETAIL%timesbi.fot HIROM TIMESI.FOT %RETAIL%timesbi.fot HIROM TIMESI.FOT %RETAIL%timesi.fot HIROM WINGDING.FOT %RETAIL%wingding.fot HIROM | ; Arial ; Arial Bold ; Arial Bold Italic ; Arial Italic ; Courier New ; Courier New Bold ; Courier New Bold Italic ; Courier New Italic ; Symbol ; Times New Roman ; Times New Roman Bold ; Times New Roman Bold Italic ; Times New Roman Italic ; WingDings |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ; MS DOS App Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                              |
| WINOA386.MOD %RETAIL%winoa386.mod HiROM<br>SEG 1 RAM COMP NORELOC<br>SEG 2 RAM COMP NORELOC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ; Enh mode grabber ; Std mode MS DOS app support ; Do not remove! ; Enh mode MS DOS app support ; Do not remove! ; Do not remove! ; Do not remove!                                                                                                           |
| DOSAPP.FON %RETAIL%dosapp.fon HiROM<br>EGA80WOA.FON %RETAIL%ega80woa.fon HIROM<br>EGA40WOA.FON %RETAIL%ega80woa.fon HIROM<br>CGA80WOA.FON %RETAIL%ega80woa.fon HIROM<br>CGA40WOA.FON %RETAIL%cga40woa.fon HIROM                                                                                                                                                                                                                                                                                                                                                                                                                            | ; MS DOS app window fonts                                                                                                                                                                                                                                    |
| ; Applets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                              |
| CALC.EXE %RETAIL%calc.exe HiROM CALENDAR.EXE %RETAIL%calendar.exe HiROM CARDFILE.EXE %RETAIL%cardfile.exe HiROM CHARMAP.EXE %RETAIL%charmap.exe HiROM CLIPBRD.EXE %RETAIL%clipbrd.exe HiROM CLOCK.EXE %RETAIL%clock.exe HiROM NOTEPAD.EXE %RETAIL%notepad.exe HiROM PACKAGER.EXE %RETAIL%packager.exe HiROM PBRUSH.DLL %RETAIL%pbrush.dll HiROM PBRUSH.EXE %RETAIL%pbrush.exe HiROM PIFEDIT.EXE %RETAIL%pifedit.exe HiROM RECORDER.DLL %RETAIL%recorder.dll HiROM RECORDER.EXE %RETAIL%recorder.exe HiROM SOL.EXE %RETAIL%sol.exe HiROM TERMINAL.EXE %RETAIL%sol.exe HiROM                                                                 | ; Calculator ; Calendar ; Cardfile ; Character Map ; Clipboard Viewer ; Clock ; Notepad applet ; Packager applet ; for Paintbrush ; Paintbrush ; PIF Editor ; for RECORDER.EXE ; Recorder ; Solitaire ; Terminal                                             |
| ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 292097-16                                                                                                                                                                                                                                                    |



WINMINE.EXE %RETAIL%winmine.exe **HiROM** : WinMine WRITE.EXE %RETAIL%write.exe **HiROM** : Write : Applications -**FILES** ; Specifies optional files to be installed into ROM. ; TrueType TTF font files are specified in this section. : ROM Name Path ROM ; TrueType Data -ARIAL.TTF %RETAIL%arial.ttf **HiROM** ; Arial ARIALBD.TTF %RETAIL%arialbd.ttf HiROM ; Arial Bold ARIALBI.TTF %RETAIL%arialbi.ttf ; Arial Bold Italic **HiROM** ARIALI.TTF %RETAIL%ariali.ttf HiROM ; Arial Italic : COUR.TTF %RETAIL%cour.ttf **HiROM** : Courier New %RETAIL%courbd.ttf COURBD.TTF HiROM : Courier New Bold COURBITTF %RETAIL%courbittf : Courier New Bold Italic HiROM **COURLTTF** %RETAIL%couri.ttf HiROM ; Courier New Italic SYMBOL.TTF %RETAIL%symbol.ttf HiROM ; Symbol TIMES.TTF %RETAIL%times.ttf **HiROM** ; Times New Roman TIMESBD.TTF %RETAIL%timesbd.ttf HiROM : Times New Roman Bold TIMESBI.TTF %RETAIL%timesbi.ttf ; Times New Roman Bold Italic **HiROM** TIMESI.TTF %RETAIL%timesi.ttf HiROM ; Times New Roman Italic WINGDING.TTF %RETAIL%wingding.ttf HiROM ; WingDings





# APPENDIX E EPLD EQUATIONS

Included below are the equations for both the 85C090 and the 5AC312 EPLDs. See the RFA Schematic Diskette for disk-readable \*.ADF and \*.JED files.

#### 85C090 EPLD

CN\_SPC\_A.ADF 85C090

OPTIONS: TURBO=ON PART: N85C090 % PLCC %

%



This EPLD provides the main control logic of the Resident Flash Array Evaluation board. The following is included:

Flash Memory chip enables
Modes Register chip enable (RS\_CE/FLASH\_CE5)
ROM Stub control logic
74FCT623 Data Buffer Control
74FCT373 Address Latches Gate control (HOLD#)
WT, WT#, and RD# generation

CN REV A - 04/06/92 Initial release

CN\_SPC\_A - 04/08/92 Reconfigured Flash Array to provide 8 Meg of Flash Disk and 4 Meg of Executable Memory.

CN SPC B - 04/29/92 Update to allow byte writes.

CN REV B - 06/01/92 Added generalize configuration scheme.

%

#### INPUTS: DL OUT@2 % % Delay line out (high edge sets PRDY f/f) PM@4 % PI bus Memory or IO# PCMD#@14 % PI bus Command PSTART DLY#@42 % Delayed PSTART# signal (used to create HOLD#) % % PI/ISA bus Latched Addresses A14@5 A15@19 A16@20 % LA17@21 % PI/ISA bus Unlatched Addresses LA18@26 LA19@25 LA20@27 LA21@28 LA22@29 LA23@30 MRDC#@3 % ISA bus Memory Read (All 16MByte) VGACS#@13 % VGA Chip Select FLASHDCS#@12 % Flash Disk Chip Select % % PI bus PW/R# (latched) L PW@41 EN PRDY@40 % Enable PRDY# driver SA00@43 % Latched address bit 00 SBHE L#@37 % Latched System Byte High Enable %

#### **OUTPUTS:**

FLASH\_CE0#@15 % Flash Memory Zone pairs Chip Selects % FLASH\_CE1#@16 FLASH\_CE2#@35

## intel<sub>®</sub>

FLASH CE3#@34

```
FLASH CE4#@33
FLASH CE5#@32
             % ROM Stub Chip Select
                                                  %
RS_CE@31
RD#@6
            % Read Strobe
                                          %
WT_L#@10
              % Write Strobe, Lower Byte
                                              %
WT U#@8
             % Write Strobe, Upper Byte
                                              %
            % Write Strobe (Active High for 74F623 enable) %
WT@36
                                                  %
             % Hold Address Latches (close gate)
HOLD#@7
SA16@11
            % HIGH for Sel RS, else 3-S
                                              %
DL IN@38
             % Delay line driver
PRDY#@9
             % PI bus signal
                                              %
PRDY@18
                % D-type f/f
                                              %
NETWORK:
PM
       = INP(PM)
nPCMD
          = INP(PCMD#)
nPSTART_DLY = INP(PSTART_DLY#)
A14
        = INP(A14)
A15
        = INP(A15)
A16
        = INP(A16)
LA17
        = INP(LA17)
LA18
        = INP(LA18)
LA19
        = INP(LA19)
LA<sub>2</sub>0
        = INP(LA20)
LA21
        = INP(LA21)
LA22
        = INP(LA22)
LA23
        = INP(LA23)
nMRDC
          = INP(MRDC#)
          = INP(VGACS#)
nVGACS
nFLASHDCS = INP(FLASHDCS#)
L PW
         = INP(L_PW)
           = INP(EN PRDY)
EN PRDY
DL OUT
          = INP(DL OUT)
SA00
        = INP(SA00)
nSBHE L
          = INP(SBHE L#)
FLASH CEO#,nFLASH CEO
                          = COIF( FLASH CE0, VCC)
                          = COIF( FLASH CE1.VCC)
FLASH CE1#,nFLASH CE1
FLASH CE2#,nFLASH CE2
                          = COIF( FLASH CE2, VCC)
FLASH CE3#,nFLASH CE3
                          = COIF(_FLASH_CE3,VCC)
FLASH CE4#,nFLASH CE4
                          = COIF( FLASH CE4, VCC)
FLASH CE5#,nFLASH CE5
                         = COIF( FLASH CE5, VCC)
RS CE, RS CEf
                   = COIF(iRS CE, VCC)
RD#
               = CONF(_RD,VCC)
WT L#
                = CONF( WT L, VCC)
WT U#
                = CONF(_WT_U,VCC)
WT
               = CONF(iWT, VCC)
```



```
HOLD#
                = CONF( HOLD, VCC)
DL IN, DL INf
                  = COIF(iDL IN, VCC)
PRDY, PRDYf
                   = RORF(VCC,DL OUT, DL IN,GND,VCC)
PRDY#
                = CONF(_PRDY,EN_PRDY)
SA16
               = CONF(VCC,Rd RS)
EQUATIONS:
% Internal Declarations %
PCMD
         = nPCMD';
PSTART DLY = nPSTART_DLY';
MRDC
         = nMRDC':
VGACS
         = nVGACS':
FLASHDCS = nFLASHDCS';
SBHE_L = nSBHE_L';
FLASH CEO = nFLASH CEO';
FLASH CE1 = nFLASH CE1';
FLASH CE2 = nFLASH CE2';
FLASH CE3 = nFLASH CE3';
FLASH CE4 = nFLASH CE4';
FLASH CE5 = nFLASH CE5';
DL IN = DL INf;
PRDY
         = PRDYf;
Hold
       = PSTART DLY
      + PCMD
      + MRDC;
Open
       = /Hold;
Closed = /Open;
Sel FDM = FLASHDCS; % Flash Disk Memory (mem cycles only) %
Sel XIP = /FLASHDCS * /VGACS * PM; % Execute-in-place Memory %
% ROM Stub. 0C8000h through 0CBFFEh %
Sel RS = /FLASHDCS * /VGACS * /LA23 * /LA22 * /LA21
       */LA20 * LA19 * LA18 */LA17 */A16 * A15 */A14;
Sel_Modes = Sel_FDM * LA23 * LA22 * LA21 * LA20 % Modes Reg %
          * LA19 * LA18 * LA17 * A16;
Modes_CE = RS_CEf * /FLASH_CE5;
Rd RS = RS CEf * FLASH_CE5;
Yes = VCC;
```



No = GND:

% Demo Configuration Z2eqFD = No;

% Zone pairs 0 and 1 are unconditionally assigned to the Flash Disk. Zone pair 5 is unconditionally assigned to the Executable Memory. Zone pairs 2, 3, and 4 are assigned with the three equations below by selecting either Yes or No for the three Flash Disk assignments. Assignments must be in order; 3 can be assigned to the Flash Disk only if 2 is, and 4 can be assigned to the Flash Disk only if 2 and 3 is. Zone pairs not assigned to the Flash Disk are automatically assigned to Executable Memory. %

```
Z3eqFD = No;
Z4eqFD = No:
% Customer Configuration %
Z2eqFD = Yes;
Z3eqFD = Yes:
Z4eqFD = No;
Z2eqXIP8 = /Z2eqFD;
Z3eqXIP8 = /Z2eqXIP8 * /Z3eqFD;
Z3eqXIPA = Z2eqXIP8 * /Z3eqFD;
Z4eqXIP8 = /Z2eqXIP8 * /Z3eqXIP8 * /Z4eqFD;
Z4eqXIPA = Z3eqXIP8 * /Z4eqFD;
Z4eqXIPC = Z3eqXIPA * /Z4eqFD;
Z5eqXIP8 = /Z2eqXIP8 * /Z3eqXIP8 * /Z4eqXIP8;
Z5eqXIPA = Z4eqXIP8;
Z5eqXIPC = Z4eqXIPA;
Z5eqXIPE = Z4eqXIPC;
% Outputs %
% Zone pairs 0 and 1 are unconditionally assigned to Flash Disk. %
FLASH_CE0' = Open * Sel_FDM * /LA23 * /LA22 * /LA21
       + Closed * FLASH_CE0;
```

% Zone pairs 2, 3, and 4 are conditionally assigned to either Flash Disk or Execute-in-Place memory. XIP starts at 800000h to avoid conflict with ROM Stub. %



```
FLASH CE2' = Open * Sel FDM * /LA23 * LA22 * /LA21 * Z2eqFD
      + Open * Sel XIP * LA23 * /LA22 * /LA21 * Z2eqXIP8
      + Closed * FLASH CE2;
FLASH CE3' = Open * Sel FDM * /LA23 * LA22 * LA21 * Z3eqFD
      + Open * Sel XIP * LA23 * /LA22 * /LA21 * Z3eqXIP8
      + Open * Sel_XIP * LA23 * /LA22 * LA21 * Z3eqXIPA
      + Closed * FLASH_CE3;
FLASH CE4' = Open * Sel FDM * LA23 * /LA22 * /LA21 * Z4eqFD
      + Open * Sel XIP * LA23 * /LA22 * /LA21 * Z4eqXIP8
      + Open * Sel XIP * LA23 * /LA22 * LA21 * Z4eqXIPA
      + Open * Sel XIP * LA23 * LA22 * /LA21 * Z4eqXIPC
      + Closed * FLASH CE4;
% Zone pair 5 is unconditionally assigned to Execute-in-Place.
 Zone pair 5 is also enabled if Rom Stub is selected. %
+ Open * Sel XIP * LA23 * /LA22 * LA21 * Z5eqXIPA
      + Open * Sel XIP * LA23 * LA22 * /LA21 * Z5eqXIPC
      + Open * Sel_XIP * LA23 * LA22 * LA21 * Z5eqXIPE
      + Open * Sel_RS
      + Closed * FLASH CE5;
% RS CE forces Flash Addresses 15 through 20 high. This, along
 with the activation of FLASH CE5#, cause ROM Stub accesses to
 go to the upper 16 KBytes of Zone pair 5. %
iRS_CE = Open * Sel_RS
      + Open * Sel Modes
      + Closed * RS_CEf;
RD'
      = PCMD * FLASH CE0 * /L PW
      + PCMD * FLASH CE1 * /L PW
      + PCMD * FLASH CE2 * /L PW
      + PCMD * FLASH CE3 * /L PW
      + PCMD * FLASH CE4 * /L PW
      + PCMD * FLASH CE5 * /L PW
      + PCMD * Modes CE */L PW
      + MRDC * Rd RS;
_WT_U' = PCMD * FLASH_CE0 * L_PW * SBHE_L
      + PCMD * FLASH CE1 * L PW * SBHE L
      + PCMD * FLASH_CE2 * L_PW * SBHE_L
      + PCMD * FLASH CE3 * L PW * SBHE L
      + PCMD * FLASH_CE4 * L_PW * SBHE_L
      + PCMD * FLASH CE5 * L PW * SBHE L
      + PCMD * FLASH CE5 * L PW * RS CEf % RS CE->SBHE L 3-S %
      + PCMD * Modes CE * L PW * SBHE L;
```



```
WT_L' = PCMD * FLASH_CEO * L_PW * /SA00
     + PCMD * FLASH CE1 * L PW * /SA00
     + PCMD * FLASH CE2 * L PW * /SA00
     + PCMD * FLASH CE3 * L PW * /SA00
     + PCMD * FLASH CE4 * L PW * /SA00
     + PCMD * FLASH CE5 * L PW */SA00
     + PCMD * Modes CE * L PW */SA00;
iWT
       = PCMD * FLASH CE0 * L PW
     + PCMD * FLASH CE1 * L PW
     + PCMD * FLASH CE2 * L PW
     + PCMD * FLASH CE3 * L PW
     + PCMD * FLASH CE4 * L PW
     + PCMD * FLASH CE5 * L PW
     + PCMD * Modes CE * L PW;
HOLD'
       = Hold;
        = PCMD * FLASH CE0
iDL IN
     + PCMD * FLASH_CE1
     + PCMD * FLASH CE2
     + PCMD * FLASH CE3
     + PCMD * FLASH CE4
     + PCMD * FLASH CE5
     + PCMD * Modes_CE;
END$
```



#### 5AC312 EPLD

OPTIONS: TURBO = OFF PART: N5AC312 % PLCC %

%

This EPLD contains logic for the following:
Flash Array VPP control
FDM and XIP Power Down control
Flash Disk Memory READY Interrupt control

MD\_REV\_A - 04/08/92 Initial release

MD\_REV\_B - 04/29/92 MODES\_CE now a function for FLASH\_CE5 and RS\_CE, rather than separate. This is to save pins on the other EPLD.

%

## int<sub>el®</sub>

SD02,SD02f

```
INPUTS:
WT#@2
            % Write Strobe
                                           %
RD#@4
            % Read Strobe
                                           %
SA01@9
            % Buffered/Latched Address bit 01
                                               %
SA02@10
             % Buffered/Latched Address bit 02
                                               %
RSTDRV@16 % ISA bus Reset Driver
                                               %
                 % All Flash ICs assigned to Flash Disk are RDY %
ALL RDY@27
               % +5LOCAL ON when this is high
SMOUT4@12
FLASH CE5#@6
RS_CE@8
             % ROM Stub Chip Select
                                               %
OUTPUTS:
% Output pins %
EN FLASH VPP@22
                     % Pwr Cntrl Reg bit 00; Enable Flash Array VPP
                                                                 %
PWR UP@26 % Pwr Cntrl Reg /bit 03
PWRD#@3
              % Power control signal to entire Flash Array
INTR@13
             % Intr Cntrl Reg bit 00; Flash Disk RDY Intr %
SD00@17
             % Internal Data Bus
SD01@18
SD02@20
SD03@21
UNUSED23@23
UNUSED24@24
% Buried Macrocells %
CLR INTRf
              % Clear Interrupt flip-flop
EN INTRf
             % Modes Reg bit 02; Enable Flash Disk RDY Intr
NETWORK:
nWT
        = INP(WT#)
nRD
        = INP(RD#)
SA01
        = INP(SA01)
SA02
        = INP(SA02)
RSTDRV
          = INP(RSTDRV)
ALL RDY = INP(ALL RDY)
SMOUT4 = INP(SMOUT4)
INTR CLK = CLKB(ALL RDY)
nFLASH CE5 = INP(FLASH CE5#)
RS CE = INP(RS CE)
SD00,SD00f
                   = COIF(iSD00,CHIP RD)
SD01,SD01f
                   = COIF(iSD01,CHIP_RD)
```

= COIF(iSD02,CHIP RD)



```
SD03,SD03f
                  = COIF(iSD03,CHIP RD)
EN FLASH VPP,EN FLASH VPPf = RORF(iEN FLASH VPP,nWT,RSTDRV,GND,VCC)
PWR UP,PWR UPf
                       = RORF(iPWR UP,nWT,GND,RSTDRV,VCC)
PWRD#
                  = CONF( PWRD, VCC)
EN INTRf
                  = NORF(iEN INTR,nWT,RSTDRV,GND)
INTR,INTRf
                  = RORF(VCC,INTR CLK,CLR INTR(GND,VCC)
CLR INTRf
                   = NOCF(iCLR INTR)
UNUSED23
                   = CONF(GND, VCC)
UNUSED24
                   = CONF(GND, VCC)
EQUATIONS:
% Internal declarations %
RD
        = nRD':
WT
        = nWT:
FLASH_CE5 = nFLASH_CE5';
Modes_CE = RS_CE * /FLASH_CE5;
Sel Pwr Reg = Modes CE * /SA02 * /SA01;
Sel Intr Reg = Modes CE */SA02 * SA01;
Sel Clr Intr = Modes CE * SA02 * SA01;
CHIP RD
           = RD * Modes CE;
FDM Busy
            =/ALL RDY;
% Outputs and buried registers %
iSD00
          = Sel Pwr Reg * EN FLASH VPPf
       + Sel_Intr_Reg * EN_INTRf;
iSD01
          = Sel Pwr Reg * GND
       + Sel Intr Reg * INTRf;
          = Sel Pwr Reg * GND
iSD02
       + Sel Intr Reg * FDM Busy;
iSD03
          = Sel Pwr Reg */PWR UPf
       + Sel Intr Reg * GND;
iEN FLASH VPP = Sel Pwr Reg * SD00f
        + /Sel_Pwr_Reg * EN_FLASH_VPPf,
            = Sel Pwr_Reg */SD03f
iPWR UP
```

+ /Sel\_Pwr\_Reg \* PWR\_UPf;

\_PWRD = PWR\_UPf + SMOUT4;

iEN\_INTR = Sel\_Intr\_Reg \* SD00f + /Sel\_Intr\_Reg \* EN\_INTRf;

iCLR\_INTR = RSTDRV +/EN\_INTRf + WT \* Sel\_Clr\_Intr;

END\$





### APPENDIX F RFA SCHEMATICS

































intel<sub>®</sub>

**AP-364** 

# APPLICATION NOTE

# **28F008SA Automation and Algorithms**

BRIAN DIPERT
MCD MARKETING APPLICATIONS

September 1993

## 28F008SA Automation and Algorithms

| CONTENTS                                                                                                                                     | PAGE  | CONTENTS                                                                                                                             | PAGE                   |
|----------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| 1.0 INTRODUCTION  2.0 AUTOMATION AND ALGORITHMS  2.1 28F008SA Automation and the Write State Machine  Command User Interface Status Register | 3-642 | 2.3 Block Erase Algorithm 2.4 Erase Suspend/Resume Algorithm                                                                         | 3-647<br>3-647<br>lext |
| 2.2 Byte Write Algorithm                                                                                                                     | 3-645 | Erase Setup Erase Erase Command Error Erase Suspend to Status/Array Read Status Read Identifier 2.6 Block Erase As a Background Task |                        |
|                                                                                                                                              |       | ADDITIONAL INFORMATION                                                                                                               | 2 652                  |



#### 1.0 INTRODUCTION

The Intel 28F008SA FlashFile<sup>TM</sup> Memory is today's optimum solution for high density solid state storage. Flash memory, exemplified by the 28F008SA, is an enabling technology for today's powerful system designs that are higher performance, more compact, lighter, more rugged and have longer battery life.

Features of the 28F008SA include:

- High-Density Symmetrically Blocked Architecture:
- Sixteen 64-Kbyte Blocks
- Extended Cycling Capability
- 100,000 Block Erase Cycles
- 1.6 Million Block Erase Cycles per Chip
- Automated Byte Write and Block Erase
- Command User Interface
- Status Register
- System Performance Enhancements
- RY/BY# Status Output
- Erase Suspend Capability
- Deep Powerdown Mode
- 0.20 μA I<sub>CC</sub> Typical
- Very High Performance Read
- 85 ns Maximum Access Time
- SRAM-Compatible Write Interface
- Hardware Data Protection Features
- Erase/Write Lockout during Power Transitions
- Industry Standard Packaging
- 40 Lead TSOP, 44 Lead PSOP
- ETOX III Nonvolatile Flash Memory Technology
- 12V Byte Write/Block Erase

The 28F008SA's automation is a significant enhancement to the manual algorithms of first-generation flash memory devices. System software and hardware designs that fully understand and exploit this automation will greatly benefit from its versatility and capabilities. The concepts presented in this document are applicable to such designs.

This application note discusses in-depth operation of the 28F008SA FlashFile memory Write State Machine and internal algorithms, emphasizing how they interface to system hardware and software. The 28F008SA datasheet (order number 290429) is a valuable reference document, providing in-depth device technical specifications, package pinouts and timing waveforms. Companion application note AP-359, "28F008SA Hardware Interfacing" (order number 292094) describes supply voltage derivation and filtering, control input/output implementation, high density layout and high speed design techniques, as well as providing example system interfaces to common microprocessor buses. AP-360, "28F008SA Software Drivers" (order number 292095) provides example ASM-86 and "C" routines for controlling the 28F008SA. AP-359 and AP-360 should be reviewed in conjunction with this application note and the 28F008SA datasheet for a complete understanding of this device.

### 2.0 AUTOMATION AND ALGORITHMS

Figure 1 shows a block diagram of the 28F008SA and its internal contents. Although a main subject of this application note is software interface to read and alter memory contents, it is useful to begin with an overview of the 28F008SA hardware subsections that are directly manipulated by the system. In particular, this application note will first discuss the Write State Machine (WSM) and Command User Interface/Status Register, and then explain the software routines that control this hardware.

## 2.1 28F008SA Automation and the Write State Machine

When the system microprocessor reads flash memory data from the 28F008SA, it uses control lines CE# and OE#, along with address inputs, to select a byte of data directly from the memory cell array. However, the system does not directly access the array when it writes to the 28F008SA; instead it writes to the Command User Interface, whose register contents are interpreted and translated into WSM actions. The WSM can be thought of as a dedicated "processor", along with companion clock-generation circuitry, integrated into the flash memory. After receiving proper commands or command sequences, it controls byte write and block erase algorithms internally. The status of the WSM is not invisible to the system; the WSM interfaces to the outside world through a full-featured Status Register and dedicated RY/BY# (Ready/Busy#) output. Automation has significant benefits, some of which are more obvious than others.





Figure 1. 28F008SA Block Diagram

The WSM architecture dramatically simplifies the program and erase algorithms of first-generation flash memory devices. Hardware/software timers, erase preprogramming, byte-by-byte verification and margining, pulse repetition and limited microprocessor multitasking capability throughout data update have been eliminated, replaced by a simple two-command write for both block erase and byte write. The 28F008SA WSM halts itself when its internal algorithms are complete, and can alert the system to this completion by a hardware interrupt (using RY/BY#) or via software polling of the 28F008SA Status Register.

Internal automation frees the system to execute higherpriority tasks while a 28F008SA is being block erased or byte written, and inherent in this capability is the most powerful advantage of the WSM. Operating systems prioritize file operations in the following order:

- Read
- Write
- Erase

When an array of 28F008SA components is used as solid-state storage (in a memory card, integrated in a flash-based "hard drive' iorm factor or resident on the system motherboard), system software can initiate slower block erase (0.3 sec minimum) of one or several

28F008SAs and, by not being "tied" to the erase algorithm, execute higher priority reads (85 ns minimum) or writes (6 μs minimum) of other 28F008SAs as operating system requests dictate. Additionally, erase suspend/resume capability allows data retrieval from a 28F008SA currently being block erased, again enabling "read" as the highest priority task. Block erase as a background task is discussed in Section 2.6 of this document.

#### **Command User Interface**

Table 2 shows the various command sequences that are accepted and interpreted by the 28F008SA Command User Interface and WSM. Writes to the CUI enable reading of device data and intelligent identifiers, reading and clearing of the Status Register, and commencement of internal byte write, block erase and erase suspend/resume algorithms. The CUI itself does not occupy a specifically addressable memory location, and contains a latch used to store the command and address/ data information needed to execute the command. Erase Setup and Erase Confirm commands require both appropriate command data and an address within the block to be erased. The Byte Write Setup command requires appropriate command data and the address of the location to be written, while the Byte Write command consists of the data to be written and its address location.



**Table 1. Status Register Definitions** 

| WSMS | ESS | ES | BWS | VPPS | R | R | R |
|------|-----|----|-----|------|---|---|---|
| 7    | 6   | 5  | 4   | .3   | 2 | 1 | 0 |

SR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

SR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Write

SR.4 = BYTE WRITE STATUS

1 = Error in Byte Write

0 = Successful Byte Write

 $SR.3 = V_{PP} STATUS$ 

1 = V<sub>PP</sub> Low Detect; Operation Abort

SR.2-SR.0 = RESERVED FOR FUTURE ENHANCEMENTS

 $0 = V_{PP} OK$ 

### .

These bits are reserved for future use and should be masked out when polling the Status Register.

### NOTES:

RY/BY# or the Write State Machine Status bit must first be checked to determine byte write or block erase completion, before the Byte Write or Erase Status bits are checked for success.

If the Byte Write AND Erase Status bits are set to "1"s during a block erase attempt, an improper command sequence was entered. Attempt the operation again.

If V<sub>PP</sub> low status is detected, the Status Register must be cleared before another byte write or block erase operation is attempted.

The V<sub>PP</sub> Status bit, unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM interrogates the V<sub>PP</sub> level only after the byte write or block erase command sequences have been entered and informs the system if V<sub>PP</sub> has not been switched on. The V<sub>PP</sub> Status bit is not guaranteed to report accurate feedback between V<sub>PPL</sub> and V<sub>PPH</sub>.

### **Table 2. Command Definitions**

| Command                          | Bus<br>Cycles | Notes   | First     | Bus Cycle |      | Secon     | d Bus Cyc | us Cycle |  |
|----------------------------------|---------------|---------|-----------|-----------|------|-----------|-----------|----------|--|
|                                  | Req'd         |         | Operation | Address   | Data | Operation | Address   | Data     |  |
| Read Array/Reset                 | 1             |         | Write     | Х         | FFH  |           | , !       |          |  |
| Intelligent Identifier           | 3             | 1, 2, 3 | Write     | Х         | 90H  | Read      | IA        | IID      |  |
| Read Status Register             | 2             | 2       | Write     | Х         | 70H  | Read      | X         | SRD      |  |
| Clear Status Register            | 1             |         | Write     | Х         | 50H  |           | -         |          |  |
| Erase Setup/Erase Confirm        | 2             | 1       | Write     | BA        | 20H  | Write     | BA        | DOH      |  |
| Erase Suspend/Erase Resume       | 2             |         | Write     | Х         | вон  | Write     | Х         | DOH      |  |
| Byte Write Setup/Write           | 2             | 1, 2, 4 | Write     | WA        | 40H  | Write     | WA        | WD       |  |
| Alternate Byte Write Setup/Write | 2             | 1, 2, 4 | Write     | WA        | 10H  | Write     | WA        | WD       |  |

### NOTES:

- 1. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
  - BA = Address within the block being erased.
  - WA = Address of memory location to be written.
- 2. SRD = Data read from Status Register. See Table 4 for a description of the Status Register bits.
  - WD = Data to be written at location WA. Data is latched on the rising edge of WE.
  - IID = Data read from intelligent identifiers.
- 3. Following the intelligent identifier command, two read operations access manufacturer and device codes.
- 4. Either 40H or 10H are recognized by the WSM as the Byte Write Setup command.
- 5. Commands other than those shown above are reserved by Intel for future device implementations and should not be used.



### Status Register

Table 1 shows the 28F008SA Status Register and defines its various bits. Like the Command User Interface, it does not occupy a specific memory location within the device. It functions as an output of the WSM, informing the system when internal byte write or block erase algorithms have completed, if these algorithms completed successfully, and whether the 28F008SA is currently in Erase Suspend mode. Bit 7 (Write State Machine Status) is replicated in the device RY/BY# hardware output. The default state of the upper 5 bits of the Status Register after powerup and return from deep powerdown mode is 10000 (binary).

A separate Clear Status Register command allows reinitialization of Status Register data after analysis. The Status Register is not cleared until this command is written to the 28F008SA.

Bits 5 and 4 of the Status Register, if set by the WSM via a byte write or block erase attempt, do not block subsequent attempts (they need not be cleared before another byte write/block erase command sequence is written to the device). However, if the WSM detects a "low Vpp" condition and subsequently sets bit 3 of the Status Register, the Status Register MUST be cleared before another algorithm command sequence will be recognized by the 28F008SA.

It is important to note that the V<sub>PP</sub> Status bit of the Status Register DOES NOT act like an always-functional A/D converter; its normal state, even with V<sub>PP</sub> below 6.5V, is "0". The WSM only analyzes the V<sub>PP</sub> level after a byte write or block erase command sequence has been written to the device, and if it detects that V<sub>PP</sub> is "low" it will cancel the impending byte write or block erase operation and set the V<sub>PP</sub> Status bit to "1". Therefore, the V<sub>PP</sub> Status bit cannot be used by the system as an indication of proper V<sub>PP</sub> level, before a byte write or block erase sequence is initiated. The system should instead insert an appropriate software delay between turning on V<sub>PP</sub> and writing an initial command sequence, or use external hardware as a V<sub>PP</sub> feedback mechanism.

### 2.2 Byte Write Algorithm

Figure 2 provides a graphical representation of the 28F008SA byte write algorithm. As can be seen, this consists solely of a two-command write sequence, followed by a periodic poll of the device RY/BY # output or Status Register. The 28F008SA automatically outputs Status Register data when read after the two-command byte write sequence (see Section 2.5). Byte write typically completes in 9  $\mu$ s.

The byte write algorithm requires high voltage  $V_{PPH}$  (12V  $\pm5\%$ ) on the device  $V_{PP}$  input until internal algorithm completion is reported by the WSM. If byte write is attempted while  $V_{PP}=V_{PPL}$  ( $\leq6.5V$ ), the  $V_{PP}$  Status bit of the Status Register will be set to "1", and array data will not be altered. Byte write attempts while  $V_{PPL} < V_{PP} < V_{PPH}$  produce spurious results and should not be attempted.

The Status Register will only report errors for "1"s that do not write to "0"s during a byte write attempt. Erasure (see Section 2.3) is the method used to change data "0"s to "1"s using flash technology. If the system software attempts to write "1"s to a byte at bit locations already at value "0", no Status Register error will be reported for those specific bits.

It is often desired to write multiple bytes of data at one time to memory. Since the Status Register is only cleared after the Clear Status Register command is written to the 28F008SA, a string of bytes can be sequentially written to the device before the "full status check procedure" examines Status Register bits other than SR.7.

Byte write abort occurs when the 28F008SA RP# (Reset/Powerdown) input drops to V<sub>IL</sub> (deep powerdown mode is entered), or V<sub>PP</sub> drops to V<sub>PPL</sub>. Although the WSM is halted in either case, byte data is partially written at the location where aborted. A repeat byte write sequence after system integrity is restored will complete the desired operation, or data can be initialized to a known value of "FF" thru block erasure.





| Bus<br>Operation | Command             | Comments                                                                                                                                |
|------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Write            | Byte Write<br>Setup | Data = 40H (10H)<br>Address = Byte to be written                                                                                        |
| Write            | Byte Write          | Data to be written<br>Address = Byte to be written                                                                                      |
| Standby/<br>Read |                     | Check RY/BY# VOH = Ready, VOL = Busy or Read Status Register Check SR.7 1 = Ready, 0 = Busy Toggle OE# or CE# to update Status Register |

Repeat for subsequent bytes

Full status check can be done after each byte or after a sequence of bytes

Write FFH after the last byte write operation to reset the device to Read Array Mode

### **FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                                                        |
|------------------|---------|---------------------------------------------------------------------------------|
| Optional<br>Read |         | CPU may already have read<br>Status Register data in WSM<br>Ready polling above |
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect                                    |
| Standby          |         | Check SR.4<br>1 = Byte Write Error                                              |

SR.3 MUST be cleared, if set during a byte write attempt, before further attempts are allowed by the Write State Machine

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple bytes are written before full status is checked

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 2. Automated Byte Write Flowchart



### 2.3 Block Erase Algorithm

Figure 3 provides a graphical representation of the 28F008SA block erase algorithm, similar in its two-command write sequence to the byte write algorithm discussed earlier. Both the Erase Setup and Erase Confirm commands must be accompanied by an address within the desired block to be erased to FFH. The 28F008SA automatically outputs Status Register data when read after the two-command block erase sequence (see Section 2.5). Block erase typically completes in 1.6 sec.

Again similar to byte write, the block erase algorithm requires high voltage  $V_{PPH}$  (12V  $\pm5\%$ ) on the device  $V_{PP}$  input until internal algorithm completion is reported by the WSM. If block erase is attempted while  $V_{PP}=V_{PPL}$  ( $\leq6.5V$ ), the  $V_{PP}$  Status bit of the Status Register will be set to "1", and array data will not be altered. Block erase attempts while  $V_{PPL}$  <  $V_{PP}$  <  $V_{PPH}$  produce spurious results and should not be attempted.

If write of the Erase Setup command is followed by write of any other command but Erase Confirm, the WSM will decode this as an illegal sequence. It will not attempt to erase the specified block, and will report error back to the system by setting both the Erase Status and Byte Write Status bits of the Status Register to "1". Since the Status Register is only cleared after the Clear Status Register command is written to the 28F008SA, a string of blocks within a 28F008SA can be sequentially erased before the "full status check procedure" examines Status Register bits other than SR.7.

Block erase abort occurs when the 28F008SA RP# (Reset/Powerdown) input drops to  $V_{IL}$  (deep powerdown mode is entered) or  $V_{PP}$  drops to  $V_{PPL}$ . A repeat block erase sequence after system integrity is restored will complete the desired operation.

## 2.4 Erase Suspend/Resume Algorithm

Figure 4 gives a software flowchart for implementing erase suspend/resume using the 28F008SA. As mentioned in Section 2.1, operating systems prioritize data reads highest, and consequently the 28F008SA has been designed with read as its highest performance function. Erase suspend allows system software to postpone WSM-controlled block erase if the system requests read of data from a different block of the same device. Although any block of the 28F008SA can be read, the block being erased when suspended will contain unknown data.

The 28F008SA is suspended by writing the Erase Suspend command (B0H) to it while the WSM is executing an erase algorithm. The WSM will halt block erase, set bits 7 and 6 of the Status Register to "1" and transition RY/BY# to V<sub>OH</sub>, after which time system software can read data from either the array or Status Register. Issuing the Erase Resume command (D0H) signals the WSM to resume block erase.

V<sub>PP</sub> must remain at V<sub>PPH</sub> throughout the erase suspend interval, even when reading from the flash memory array. The 28F008SA will detect a V<sub>PP</sub> transition to V<sub>PPL</sub> while suspended, and report this error via Status Register bit 3 (set to "1") after the Erase Resume command is written to it.





| Bus<br>Operation | Command          | Comments                                                                                        |
|------------------|------------------|-------------------------------------------------------------------------------------------------|
| Write            | Erase<br>Setup   | Data = 20H<br>Address = Within block to be<br>erased                                            |
| Write            | Erase<br>Confirm | Data = D0H<br>Address = Within block to be<br>erased                                            |
| Standby/<br>Read |                  | Check RY/BY# V <sub>OH</sub> = Ready, V <sub>OL</sub> = Busy or                                 |
|                  |                  | Read Status Register Check SR.7 1 = Ready, 0 = Busy Toggle OE# or CE# to update Status Register |

Repeat for subsequent blocks

Full status check can be done after each block or after a sequence of blocks

Write FFH after the last block erase operation to reset the device to Read Array Mode



| Bus<br>Operation | Command | Comments                                                                        |
|------------------|---------|---------------------------------------------------------------------------------|
| Optional<br>Read | ·       | CPU may already have read<br>Status Register data in WSM<br>Ready polling above |
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect                                    |
| Standby          |         | Check SR.4,5<br>Both 1 = Command Sequence<br>Error                              |
| Standby          |         | Check SR.5<br>1 = Block Erase Error                                             |

SR.3 MUST be cleared, if set during a block erase attempt, before further attempts are allowed by the Write State Machine

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked

If error is detected, clear the Status Register before attempting retry or other error recovery

Figure 3. Automated Block Erase Flowchart





Figure 4. Erase Suspend/Resume Flowchart



Since the WSM is driven by its own oscillator, internal to the 28F008SA, it operates asynchronously to the system CPU and its clock. Therefore, the possibility exists that the WSM could complete erase, returning to "ready", between when the system reads "busy" from the Status Register and writes the Erase Suspend command. Analyzing both the WSM Status and Erase Suspend Status bits of the Status Register, as shown in the flowchart, will alert the system to such an occurrence.

## 2.5 Write State Machine Current/Next State Overview

Byte write and block erase automation equate to tremendous power and capability in system implementations of the 28F008SA, if fully exploited. An in-depth understanding of the WSM, its states and its responses to inputs, will assist the software engineer in developing optimized driver routines for flash memory-based file storage and other high-performance applications. Table 3 lists all possible WSM "current states", command inputs and resultant "next states".

Non-shaded boxes highlight those state transitions which will most commonly occur when reading from and modifying 28F008SA contents, and these transitions should be understood in most depth. Shaded boxes, on the other hand, represent lesser-used or non-sensical transitions, such as improper erase command sequences.

Before reading the 28F008SA, if the current WSM mode is not known (if, for example, an interrupt service routine has potentially interacted with the device), first write the desired output command (i.e. Read Status Register, Read Array or Intelligent Identifier). This ensures that the 28F008SA will be in a known state when read and will output expected data.

### **Read Array**

The 28F008SA automatically defaults to Read Array mode when powered up, or when it returns from Deep Powerdown mode. As the name implies, the 28F008SA outputs array data when read in Read Array mode. Read Array is also the default mode after the Clear Status Register command is written in most other modes.

### **Byte Write Setup**

The 28F008SA transitions to Byte Write Setup mode after it receives the Byte Write Setup command. If the 28F008SA is read in Byte Write Setup mode, it outputs Status Register data.

### **Byte Write**

After the 28F008SA is placed in Byte Write Setup mode, the next address/data combination written to it transitions the WSM to Byte Write mode, where the "Byte Write Command" is latched as desired data to write to the array at the specified address location. Immediately, the WSM examines Vpp, and if it detects an invalid level, it halts with Vpp error indication in the Status Register (bit 3 = "1"). Bit 7 of the Status Register is "0", and the RY/BY # output is driven to  $V_{OL}$ , while the WSM is executing the internal byte write algorithm in Byte Write mode. The 28F008SA automatically outputs Status Register data when in Byte Write mode.

### **Erase Setup**

The 28F008SA transitions to Erase Setup mode after it receives the Erase Setup command. If the 28F008SA is read in Erase Setup mode, it outputs Status Register data.



Table 3. Write State Machine Current/Next States

|                                 |                  |                      | Command Input (and Next State) |                                    |                              |                                        |                               |                          |                               |                          |                  |
|---------------------------------|------------------|----------------------|--------------------------------|------------------------------------|------------------------------|----------------------------------------|-------------------------------|--------------------------|-------------------------------|--------------------------|------------------|
| Current<br>State                | RY/BY#<br>Status | Data<br>When<br>Read | Read<br>Array<br>(FFH)         | Byte<br>Write<br>Setup<br>(10/40H) | Erase<br>Setup<br>(20H)      | Erase<br>Confirm<br>(D0H)              | Erase<br>Suspend<br>(B0H)     | Erase<br>Resume<br>(D0H) | Read<br>Status<br>(70H)       | Clear<br>Status<br>(50H) | Read ID<br>(90H) |
| Read<br>Array                   | V <sub>OH</sub>  | Array                | Read<br>Array                  | Byte<br>Write<br>Setup             | Erase<br>Setup               | Read<br>Array                          | Read<br>Array                 | Read<br>Array            | Read<br>Status                | Read<br>Array            | Read ID          |
| Byte Write<br>Setup             | V <sub>OH</sub>  | Status               |                                | By                                 | te Write (0                  | Command                                | Input = D                     | ata to be                | Byte Writt                    | en)                      |                  |
| Byte Write<br>(Not<br>Complete) | V <sub>OL</sub>  | Status               |                                | Byte Write                         |                              |                                        |                               |                          |                               |                          |                  |
| Byte Write<br>(Complete)        | V <sub>OH</sub>  | Status               | Read<br>Array                  | Byte<br>Write<br>Setup             | Erase<br>Setup               |                                        | Read Array                    | ı                        | Read<br>Status                | Read<br>Array            | Read ID          |
| Erase<br>Setup                  | V <sub>OH</sub>  | Status               | Erase                          | Erase Command Error Erase          |                              | Erase Command Erase Erase Comman Error |                               | d Error                  |                               |                          |                  |
| Erase<br>Command<br>Error       | V <sub>OH</sub>  | Status               | Read<br>Array                  | Byte<br>Write<br>Setup             | Erase<br>Setup               |                                        | Read Array                    |                          | Read<br>Status                | Read<br>Array            | Read ID          |
| Erase<br>(Not<br>Complete)      | V <sub>OL</sub>  | Status               |                                | Erase                              |                              |                                        | Erase Suspend Erase to Status |                          |                               |                          |                  |
| Erase<br>(Complete)             | VoH              | Status               | Read<br>Array                  | Byte<br>Write<br>Setup             | Erase<br>Setup               |                                        | Read Array                    | ľ                        | Read<br>Status                | Read<br>Array            | Read ID          |
| Erase<br>Suspend<br>to Status   | V <sub>OH</sub>  | Status               | Erase<br>Suspend<br>to Array   | Reserved                           | Erase<br>Suspend<br>to Array | Erase                                  | Erase<br>Suspend<br>to Array  | Erase                    | Erase<br>Suspend<br>to Status |                          | Reserved         |
| Erase<br>Suspend<br>to Array    | V <sub>OH</sub>  | Array                | Erase<br>Suspend<br>to Array   | Reserved                           | Erase<br>Suspend<br>to Array | Erase                                  | Erase<br>Suspend<br>to Array  | Erase                    | Erase<br>Suspend<br>to Status | 14. 1. 34 SART 38 SAR    | Reserved         |
| Read<br>Status                  | V <sub>OH</sub>  | Status               | Read<br>Array                  | Byte<br>Write<br>Setup             | Erase<br>Setup               |                                        | Read Array                    | 1                        | Read<br>Status                | Read<br>Array            | Read ID          |
| Read<br>Identifier              | V <sub>OH</sub>  | ID                   | Read<br>Array                  | Byte<br>Write<br>Setup             | Erase<br>Setup               |                                        | Read Array                    |                          | Read<br>Status                | Read<br>Array            | Read ID          |

### NOTE:

<sup>1.</sup> State transitions labeled "Reserved" are set aside by Intel Corporation for potential future device implementations. Command sequences to access these states should not be attempted.



### **Erase**

After the 28F008SA is placed in Erase Setup mode, write of the Erase Confirm command transitions the WSM to Erase mode, where the specified address is decoded into one of 16 blocks to be erased. Immediately, the WSM examines Vpp, and if it detects an invalid level, it halts with Vpp error indication in the Status Register (bit 3 = "1"). Bit 7 of the Status Register is "0", and the RY/BY# output is driven to Vol, while the WSM is executing the internal block erase algorithm in Erase mode. The 28F008SA automatically outputs Status Register data when in Erase mode.

### **Erase Command Error**

This is the other possible transition mode after Erase Setup, and occurs when an invalid command (anything but Erase Confirm/Resume) is written to the 28F008SA as the second in the two-command block erase sequence. In this mode, the WSM does not attempt a block erase, and it returns an error indication to the system by setting both bits 4 and 5 of the Status Register to "1". The 28F008SA automatically outputs Status Register data when in Erase Command Error mode.

### **Erase Suspend to Status/Array**

While the WSM is busy executing an internal block erase algorithm, it can be placed in erase suspend by writing the Erase Suspend command. After receiving and decoding this command, the WSM suspends block erase, drives the RY/BY # output to  $V_{OH}$ , sets bits 6 and 7 of the Status Register to "1" and transitions to "Erase Suspend to Status" mode. The 28F008SA automatically outputs Status Register data when in "Erase Suspend to Status" mode.

The only valid command other than Read Status and Erase Resume at this time is Read Array, which transitions the WSM to "Erase Suspend to Array" mode. As the name implies, the 28F008SA outputs array data, not Status Register contents, in this mode. While in both Erase Suspend modes, Vpp must remain at VppH for erase to complete successfully when resumed.

Writing the Erase Resume (same as Erase Confirm) command to the 28F008SA transitions the WSM out of Erase Suspend and back to Erase. In conjunction with this, the WSM returns RY/BY# to  $V_{OL}$  and resets bits 6 and 7 of the WSM to "0".

### **Read Status**

As the name implies, the 28F008SA automatically outputs Status Register contents when read in Read Status mode. If system software writes the Clear Status command at this point, the WSM resets the Status Register to its default value and transitions to Read Array mode.

### Read Identifier

The 28F008SA outputs its manufacturer identifier of 89H when read from address 00000H when in Read Identifier mode. Similarly, a read from address 00001H returns the device identifier A2H. Using this information, the system can automatically match the device with its proper block erase and byte write algorithms. Reads from addresses other than 00000H and 00001H are not supported by Intel, and consistent results of such reads are not documented, guaranteed or recommended.

### 2.6 Block Erase as a Background Task

As mentioned earlier, the internal WSM block erase algorithm typically takes 1.6 seconds to complete. Proper implementation of block erase from a hardware and software standpoint, however, can mask this delay, by taking advantage of the 28F008SA's internal automation and full-featured system interface. Execution of block erase as a background task, with higher priority read and write functions in the foreground, is the key.

The recommended scenario includes an "intelligent" operating system routine which can keep track of "busy" devices in the 28F008SA array. After initiating block erase on these components, the operating system is free to concentrate on reads and writes, or any other pending requests that demand its attention. The 28F008SA RY/BY# output alerts the system when block erase completes, and the operating system acts on this completion in the resulting interrupt service routine.

Hardware interrupt via the RY/BY# output is a recommended technique for block erase. However, this method should be evaluated closely for alerting the system to byte write completion. The WSM typically completes a byte write attempt in 9 µs, a much shorter time than that consumed in many CPU interrupt latencies. In such cases, software polling of the 28F008SA Status Register to detect WSM "ready", versus hardware interrupt, will result in highest byte write performance. Reference AP-359, "28F008SA Hardware Interfacing", for circuit implementations that not only combine RY/BY#s into a common INT, but also allow RY/BY# masking if desired.



### **ADDITIONAL INFORMATION**

| 28F008SA | A Datasheet                          | Order<br>Number<br>290429 |
|----------|--------------------------------------|---------------------------|
|          | N-L Datasheet                        | 290435                    |
| 2010000  | 1-L Dalasheel                        | 290433                    |
| AP-359   | "28F008SA Hardware Interfacing"      | 292094                    |
| AP-360   | "28F008SA Software<br>Drivers"       | 292095                    |
| ER-27    | "The Intel 28F008SA Flash<br>Memory" | 294011                    |
| ER-28    | "ETOX-III Flash Memory               | 294012                    |

### **REVISION HISTORY**

| Number | Description                                    |
|--------|------------------------------------------------|
| 003    | PWD# pin renamed RP# to match JEDEC standards. |

3



# APPLICATION NOTE

# **Upgrade Considerations from** the 28F008SA to the 28F016SA

SALIM FEDEL
FLASH MEMORY APPLICATIONS ENGINEERING

March 1994

# Upgrade Considerations from the 28F008SA to the 28F016SA

| CONTENTS                                                                       | PAGE  | CONTENTS                                             | PAGE        |
|--------------------------------------------------------------------------------|-------|------------------------------------------------------|-------------|
| 1.0 PURPOSE                                                                    | 3-656 | 2.8 DC Compatibility                                 |             |
| 2.0 SIMILARITIES AND DIFFEREN<br>BETWEEN THE 28F016SA AND<br>28F008SA          | THE   | 3.0 HARDWARE DESIGN CONSIDERATIONS                   |             |
| 2.1 Pinout Differences                                                         | 3-656 | 3.1 Hardware Upgradability .                         | 3-661       |
| 2.1.1 Hardware Compatible Configuration                                        | 3-658 | 3.2 Hardware Decision Flowd                          | :hart 3-661 |
| <ul><li>2.2 Compatible Command-Set</li><li>2.3 Technology Comparison</li></ul> |       | 4.0 SOFTWARE DESIGN AND UPGRADABILITY CONSIDERATIONS | 3-662       |
| 2.4 Available Speeds                                                           |       | 4.1 Software Decision Flowd                          |             |
| 2.5 Available Packages                                                         | 3-660 | 5.0 COMPATIBLE SOFTWARE                              | :           |
| 2.6 Operating Modes                                                            | 3-660 | ALGORITHM FLOWCHARTS                                 |             |
| 2.7 AC Compatibility                                                           | 3-660 | 6.0 SUMMARY                                          | 3-666       |

7.0 REFERENCES .....



### 1.0 PURPOSE

The 28F016SA is the second member of Intel's FlashFile<sup>TM</sup> memory family. Its architecture evolved from that of the 28F008SA, Intel's first generation FlashFile memory device. The 28F016SA retains the standard 28F008SA's versatile capabilities and adds a Command Superset architecture which insures compatibility with the basic command-set.

This application note shows how to upgrade an existing 28F008SA-based design to the new 28F016SA memory device. Upgrades may require software modifications depending on the desired system functionality and straightforward hardware modifications to accommodate the new pinout.

### 2.0 SIMILARITIES AND DIFFERENCES BETWEEN THE 28F016SA AND THE 28F008SA

The 28F016SA memory is 100% command and algorithm, backward-compatible with the 28F008SA. It is defined as a Superset device which brings additional capabilities to system designs. Additional pins on the 28F016SA are added to define a user-selectable 8- or 16-bit wide memory, add on-chip write protection and multiple chip select signals. Note that you do not have to use the advanced features if you are performing a simple upgrade to the 28F016SA.

Before starting on your design upgrade, obtain the following specifications and application notes from Intel Corporation Literature Sales, 1 (800) 548-4725.

| Order # |
|---------|
| 290429  |
| 290489  |
| 297372  |
| 292095  |
| 292126  |
|         |

### 2.1 Pinout Differences

Whereas the 28F008SA is 8-bit wide (40Ld-TSOP package), the 28F016SA is a high performance 16-bit wide flash file memory offering a user-configurable bus width (56Ld-TSOP package). Hence an additional 8 I/O pins are on the 28F016SA. Furthermore, the implementation of additional features such as Write Protect and Block Locking and user-selectable 3.3V and 5V operation require the definition of control pins for these functions. Finally, the optimization of the 28F016SA's architecture to achieve very high write performance resulted in a different pinout configuration from the 28F008SA.

Both device pinouts preserve the locations of I/O pins on the right-hand side and the sequence of pin functions of the 56Ld-TSOP package. However, it is still required to relay out an existing PCB design in order to accommodate the 16-Mbit chips. Table 1 lists all pin names and their numbers, highlighting all the changes.



Table 1. 28F008SA, 28F016SA Pin Comparison Chart

|                      | 1. 201 0000          | A, 201 \             |    |       |
|----------------------|----------------------|----------------------|----|-------|
| 28F008SA<br>Pin Name | 28F016SA<br>Pin Name | 28F008SA<br>40L-TSOP |    | Notes |
| A <sub>0</sub>       | A <sub>0</sub>       | 24                   | 32 |       |
| A <sub>1</sub>       | A <sub>1</sub>       | 23                   | 28 |       |
| A <sub>2</sub>       | A <sub>2</sub>       | 22                   | 27 |       |
| A <sub>3</sub>       | A <sub>3</sub>       | 21                   | 26 |       |
| A <sub>4</sub>       | A <sub>4</sub>       | 20 、                 | 25 |       |
| A <sub>5</sub>       | A <sub>5</sub>       | 19                   | 24 |       |
| A <sub>6</sub>       | A <sub>6</sub>       | 18                   | 23 |       |
| A <sub>7</sub>       | A <sub>7</sub>       | 17                   | 22 |       |
| A <sub>8</sub>       | A <sub>8</sub>       | 16                   | 20 |       |
| A <sub>9</sub>       | A <sub>9</sub>       | 15                   | 19 |       |
| A <sub>10</sub>      | A <sub>10</sub>      | 14                   | 18 |       |
| A <sub>11</sub>      | A <sub>11</sub>      | 13                   | 17 |       |
| A <sub>12</sub>      | A <sub>12</sub>      | . 8                  | 13 |       |
| A <sub>13</sub>      | A <sub>13</sub>      | 7                    | 12 |       |
| A <sub>14</sub>      | A <sub>14</sub>      | 6                    | 11 |       |
| A <sub>15</sub>      | A <sub>15</sub>      | 5                    | 10 |       |
| A <sub>16</sub>      | A <sub>16</sub>      | 4                    | 8  |       |
| A <sub>17</sub>      | A <sub>17</sub>      | 3                    | 7  |       |
| A <sub>18</sub>      | A <sub>18</sub>      | 2                    | 6  |       |
| A <sub>19</sub>      | A <sub>19</sub>      | 1                    | 5  |       |
| _                    | A <sub>20</sub>      | _                    | 4  | 1     |
| DQ <sub>0</sub>      | DQ <sub>0</sub>      | 25                   | 33 |       |
| DQ <sub>1</sub>      | DQ <sub>1</sub>      | 26                   | 35 |       |
| DQ <sub>2</sub>      | DQ <sub>2</sub>      | 27                   | 38 |       |
| DQ <sub>3</sub>      | DQ <sub>3</sub>      | 28                   | 40 |       |
| DQ <sub>4</sub>      | DQ <sub>4</sub>      | 32                   | 44 |       |
| DQ <sub>5</sub>      | DQ <sub>5</sub>      | 33                   | 46 |       |

| 28F008SA<br>Pin Name | 28F016SA<br>Pin Name |        |            | Notes |
|----------------------|----------------------|--------|------------|-------|
| DQ <sub>6</sub>      | DQ <sub>6</sub>      | 34     | 49         |       |
| DQ <sub>7</sub>      | DQ <sub>7</sub>      | 35     | 51         |       |
|                      | DQ <sub>8</sub>      | _      | 34         |       |
| _                    | DQ <sub>9</sub>      | _      | 36         |       |
| _                    | DQ <sub>10</sub>     | _      | 39         |       |
| _                    | DQ <sub>11</sub>     | _      | 41         |       |
| _                    | DQ <sub>12</sub>     | _      | 45         |       |
| _                    | DQ <sub>13</sub>     |        | 47         |       |
|                      | DQ <sub>14</sub>     |        | 50         |       |
| _                    | DQ <sub>15</sub>     | _      | 52         |       |
| CE#                  | CE <sub>0</sub> #    | 9      | 14         |       |
| _                    | CE <sub>1</sub> #    | ·      | 2          | 2     |
| RP#                  | RP#                  | 12     | 16         | 3     |
| RY/BY#               | RY/BY#               | 36     | 53         | 4     |
| OE#                  | OE#                  | 37     | 54         |       |
| WE#                  | WE#                  | 38     | 55         |       |
|                      | BYTE#                | _      | 31         | 5     |
| _                    | WP#                  | _      | 56         |       |
|                      | 3/5#                 | _      | 1          | 6     |
| V <sub>PP</sub>      | . V <sub>PP</sub>    | 11     | 15         |       |
| V <sub>SS</sub>      | V <sub>SS</sub>      | 29, 30 | 21, 42, 48 |       |
| V <sub>CC</sub>      | V <sub>CC</sub>      | 10, 31 | 9, 37, 43  |       |
| NC                   | NC                   | 39, 40 | 3, 29, 30  |       |

### NOTES:

- Highest Order Address
   Dual CEx#
   Formerly Called PWD#
- 4. Open Drain for 28F016SA 5. x8/x16 Selection
- 6. Selects Supply Voltage



## 2.1.1 HARDWARE COMPATIBLE CONFIGURATION

The following is an example which shows the state of all pins when operating in a 28F008SA-compatible mode:

WP# = V<sub>CC</sub> (Write Protect feature disabled)

 $CE_0# = CE_1#$  (Chip Enable)

 $A_{20}$  = GND or  $V_{CC}$  (selects upper/lower 1 MB)

 $3/5# = GND (5V \text{ operation}) \text{ or } V_{CC} (3.3V \text{ operation})$ 

 $V_{CC}$  = 5.0V or 3.3V

BYTE# = GND (8-bit mode)

RY/BY# = Level Mode (set for default) with an external pull-up resistor

### NOTE:

The 28F008SA has a CMOS driven RY/BY# output for interrupt capability.



Figure 1. 28F016SA Configured as a 28F008SA-Compatible Memory



### 2.2 Compatible Command-Set

Byte Write

40H, 10H

Single Block Erase

20H

Erase Suspend to Read

B0H

Read Array

**FFH** 

Read CSR

70H

Clear CSR

50H

Read Intelligent IDs

90H

Table 2 28E008SA-Compatible Commands

| Command                         | Notes | First Bus Cycle |      |      | Second Bus Cycle |      |      |
|---------------------------------|-------|-----------------|------|------|------------------|------|------|
| Command                         |       | Oper            | Addr | Data | Oper             | Addr | Data |
| Read Array                      |       | Write           | Х    | FFH  | Read             | AA   | AD   |
| Intelligent Identifier          | 1     | Write           | X    | 90H  | Read             | IA   | ID   |
| Read Compatible Status Register | 2     | Write           | Х    | 70H  | Read             | Х    | CSRD |
| Clear Status Register           | 3     | Write           | Х    | 50H  |                  |      |      |
| Word/Byte Write                 |       | Write           | Х    | 40H  | Write            | WA   | WD   |
| Alternate Word/Byte Write       |       | Write           | Х    | 10H  | Write            | WA   | WD   |
| Block Erase/Confirm             |       | Write           | Х    | 20H  | Write            | ВА   | D0H  |
| Erase Suspend/Resume            |       | Write           | Х    | вон  | Write            | Х    | D0H  |

**ADDRESS** 

DATA

AA = Array Address

AD = Array Data

BA = Block Address

CSR = Compatible Status Register

IA = Identifier Address CSRD = CSR Data

WA = Write Address

GSR = Global Status Register BSR = Block Status Register

X = Don't Care

ID = Identifier Data

WD = Write Data

- 1. Following the Intelligent Identifier command, two Read operations access the manufacturer and device signature codes.
- 2. The CSR is automatically available after device enters Data Write, Erase, or Suspend operations.
- 3. Clears CSR.3, CSR.4 and CSR.5. Also clears GSR.5 and all BSR.5 and BSR.2 bits. See Status register definitions in the 28F016SA data sheet.



### 2.3 Technology Comparison

Both the 28F016SA and the 28F008SA are manufactured on Intel's Flash ETOX process technology. This technology is optimized for random access flash memory products with the highest read/write performance and lowest power consumption. The ETOX flash technology achieves very high reliability and quality.

### 2.4 Available Speeds

The 28F016SA designed on a 0.6  $\mu m$  ETOX IV process, achieves faster speeds than the 28F008SA manufactured on 0.8  $\mu m$  ETOX III process. Intel offers the 28F008SA in 5V-read version with speeds at 85/90 ns and 120 ns. The 28F016SA on the other hand is offered with a dual 3.3V and 5V read capability with speeds of (70/80 ns, 100 ns) and (120 ns, 150 ns) at 5V and 3.3V respectively. Note that both devices are offered at faster speeds (85 ns and 70 ns) under reduced loading conditions. Please consult the data sheets referenced in this application note.

### 2.5 Available Packages

The 28F016SA comes only in a 56Ld-Thin Small Outline Package (TSOP) optimized for its user-selectable x8/x16 memory architecture. The 28F008SA is offered in 2 packages, which are the 40Ld-TSOP (both standard and reverse pinout) and the 44Ld-Plastic Small Outline Package (PSOP).

### 2.6 Operating Modes

The 28F016SA behaves in the same manner as the 28F008SA. If a compatible command is written to the device, the Compatible Status Register contents are automatically put on the data bus. With the block locking disabled (WP# = high), the 28F016SA is identical to the 28F008SA, regardless of any lock-bit settings which define the lock state of a given block. The Command User Interface (CUI), Write State Machine (WSM) and Compatible Status Register (CSR) units function similarly on both devices.

The 28F016SA however, allows the user to issue multiple commands successively by watching the Queue bit (GSR.3 or BSR.3), a feature which improves performance, as described in the 28F016SA user's manual. Consult the 28F016SA data sheet and 28F016SA user's manual for detail operation.

### 2.7 AC Compatibility

The 28F016SA specifies the output Load circuit as an equivalent transmission line model which reflects the timing delays more accurately. The same diode/resistor circuit combination found in the 28F008SA data sheet also applies to the 28F016SA.

Address and Data are latched on the rising edge of WE# for both devices. All AC timing specifications are similar except for the differences noted in the data sheets. The 28F016SA has additional write timings describing the on-chip page buffers which do not exist on the 28F008SA.

### 2.8 DC Compatibility

Whereas the 28F008SA only operates at 5V  $V_{CC}$  and the 28F008SA-L only operates at 3.3V  $V_{CC}$ , the 28F016SA operates at both 3.3V and 5V  $V_{CC}$  supply voltages. In 5V mode of operation, the two devices are similar in terms of input/output level specifications. Consult the data sheets for differences in current consumption.

### 2.9 Power Considerations

In addition to the active, standby and deep power-down modes which exist on the 28F008SA, the 28F016SA has additional current modes useful in power management applications.

The two modes are:

Automatic Power Saving feature which is activated whenever the device addresses are not switching which is equivalent to a static mode of operation on the chip is accessed by a slowed clock. In this state, the chip typically draws less than 1 mA of total current.

The second low current mode of operation is enabled through command control, using the Sleep command. A Sleep command written to the device will put the chip in the lowest current state (deep power-down level) after all active operations have been processed. The device retains the value of its status registers while in sleep mode.

Note that the AC and DC specifications mentioned here are valid at the time this application note was written. Please reference the device data sheets for the latest up-to-date specifications.



## 3.0 HARDWARE DESIGN CONSIDERATIONS

If you are considering a density upgrade to the 28F016SA, careful attention to certain areas must be followed. This section is not intended to cover all potential issues related to system design, but rather as a guideline in designing an upgrade to the 28F016SA.

### 3.1 Hardware Upgradability

The following flowchart summarizes the logical steps a system designer must go through to complete a density upgrade. This simple upgradability procedure allows the 28F016SA-based system to achieve quicker time-to-market while incorporating future expandability to take advantage of the Superset features of the 28F016SA.

### 3.2 Hardware Decision Flowchart



3



# 4.0 SOFTWARE DESIGN AND UPGRADABILITY CONSIDERATIONS

In order to do a software upgrade to the 28F016SA, the software designer must pay attention to a few key areas. They can be grouped as follows:

Device Intelligent Identifler = A0H (versus A2H for 28F008SA)

Compatible Superset Commands
Compatible Status Register Checks only
Number of Erase Blocks

Device Drivers for the 28F008SA and the 28F016SA are provided in application notes AP-360 and AP-377 respectively.

Software drivers written for the 28F008SA need to recognize the new device ID and change the memory size boundaries in order to work on a 28F016SA-based system design.

Note that the 28F016SA can be treated as two 8-Mbit memory devices in a single package. The highest order address pin  $A_{20}$  is used to switch between the upper and the lower 1 Mbyte flash array. By preserving the same basic software driver code, an upgrade to the 28F016SA enables the quickest time-to-market.

### 4.1 Software Decision Flowchart





### 5.0 COMPATIBLE SOFTWARE ALGORITHM FLOWCHARTS



| Bus<br>Operation | Command            | Comments                                                                                    |
|------------------|--------------------|---------------------------------------------------------------------------------------------|
| Write            | Word/Byte<br>Write | D = 40H or 10H<br>A = X                                                                     |
| Write            |                    | D = WD<br>A = WA                                                                            |
| Read             |                    | Q = CSRD<br>Toggle CE <sub>0</sub> #, CE <sub>1</sub> #, or<br>OE# to update CSRD.<br>A = X |
| Standby          |                    | Check CSR.7<br>1 = WSM Ready<br>0 = WSM Busy                                                |

Repeat for subsequent Word/Byte Writes.

CSR Full Status Check can be done after each Word/Byte Write, or after a sequence of Word/Byte Writes.

Write FFH after the last operation to reset device to Read Array Mode.

See Command Bus definitions in the 28F016SA User's Manual for description of codes.

292124-4

### **CSR FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                                                |
|------------------|---------|-------------------------------------------------------------------------|
| Standby          |         | Check CSR.4  1 = Data Write Unsuccessful  0 = Data Write Successful     |
| Standby          |         | Check CSR.3<br>1 = V <sub>PP</sub> Low Detect<br>0 = V <sub>PP</sub> OK |

CSR.3/4 SHOULD be cleared, if set, before further attempts are initiated.

Figure 2. Word/Byte Writes





| Bus<br>Operation | Command     | Comments                                                                           |
|------------------|-------------|------------------------------------------------------------------------------------|
| Write            | Block Erase | D = 20H<br>A = X                                                                   |
| Write            | Confirm     | D = D0H<br>A = BA                                                                  |
| Read             |             | Q = CSRD Toggle CE <sub>0</sub> #, CE <sub>1</sub> #, or OE# to update CSRD. A = X |
| Standby          |             | Check CSR.7<br>1 = WSM Ready<br>0 = WSM Busy                                       |

Repeat for subsequent Block Erasures.

CSR Full Status Check can be done after each Block Erase, or after a sequence of Block Erasures.

Write FFH after the last operation to reset device to Read Array Mode.

See Command Bus definitions in the 28F016SA User's Manual for description of codes.

### **CSR FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                                                |
|------------------|---------|-------------------------------------------------------------------------|
| Standby          |         | Check CSR.5 1 = Erase Error 0 = Erase Successful                        |
| Standby          |         | Check CSR.3<br>1 = V <sub>PP</sub> Low Detect<br>0 = V <sub>PP</sub> OK |
| Standby          |         | Check CSR.4, 5 Both set to 1 = Command Sequence Error                   |

CSR.3/4/5 SHOULD be cleared, if set, before further attempts are initiated.

Figure 3. Block Erase





Figure 4. Erase Suspend to Read Array



### 6.0 SUMMARY

This application note summarizes the upgrade considerations and compatibility areas between the 28F016SA and the 28F008SA. It is merely intended as a simple guideline to achieve a density and/or performance up-

grade and to point out the key issues that the hardware and software designers must analyze during this process.

Consult the referenced documentation for a complete understanding of compatibility and device capabilities.

### 7.0 REFERENCES

| , ,                                                                    |              |
|------------------------------------------------------------------------|--------------|
| Document                                                               | Order Number |
| 28F016SA Data Sheet                                                    | 290489       |
| 28F016SA User's Manual                                                 | 297372       |
| DD28F032SA Data Sheet                                                  | 290490       |
| AP-377 The 28F016SA Software Drivers                                   | 292126       |
| AP-378 System Optimization using the Enhanced Features of the 28F016SA | 292127       |
| AP-362 Implementing Mobile PC Designs                                  |              |
| Using High Density FlashFile™ Components                               | 292097       |
| ER-33 ETOXIV Flash Memory Technology                                   | 294016       |
| 28F008SA 8 MB (1 MB x 8) FlashFile™ Memory Data Sheet                  | 290429       |
| AP-360 28F008SA FlashFile™ Software Drivers                            | 292095       |
| ER-27 The Intel 28F008SA FlashFile™ Memory                             | 294011       |
|                                                                        |              |

# APPLICATION NOTE

# 16-Mbit Flash Product Family Software Drivers 28F016SA, 28F016SV, 28F016XS, 28F016XD

TAYLOR GAUTIER
MCD APPLICATIONS ENGINEERING
PATRICK KILLELEA
MCD APPLICATIONS ENGINEERING
SALIM FEDEL
MCD APPLICATIONS ENGINEERING

December 1994

3

# 16-Mbit FLASH PRODUCT FAMILY SOFTWARE DRIVERS

| CONTENTS                           | PAGE  |
|------------------------------------|-------|
| INTRODUCTION                       |       |
| 28F016SA C DRIVERS                 |       |
| 28F016SA ASM86 DRIVERS             |       |
| APPENDIX A: FUNCTION CHANGES       | 3-719 |
| APPENDIX B: GLOSSARY OF TERMS      |       |
| APPENDIX C: ADDITIONAL INFORMATION |       |



### INTRODUCTION

### ABOUT THE CODE

This application note provides example software code for word writing, block erasing, and otherwise controlling Intel's 28F016SA, 28F016SV, 28F016XS and 28F016XD (hereafter referred to as 28F016SA) 16 Mbit symmetrically blocked memory components. Two programming languages are provided: high-level "C" for broad platform support, and more optimized ASM86 assembly. In many cases, the driver routines can be inserted "as is" into the main body of code being developed by the system software engineer. Extensive comments are included in each routine to facilitate adapting the code to specific applications.

The internal automation of the 28F016SA makes software timing loops unnecessary and results in platformindependent code. The following example code is designed to be executed in any type of memory and with all processor clock rates. C code can be used with many microprocessors and microcontrollers, while ASM86 assembly code provides a solution optimized for Intel microprocessors and embedded processors.

The 28F016SA, like the 28F008SA, is divided into 64 Kbyte blocks. Since the GSR and BSR are defined relative to the nearest preceding block beginning address, I often refer to this "block base" address in the comments.

### Assumptions:

- Pointers (in C) or EDI offsets (in ASM86) are four (4) bytes long, providing a flat addressing space over the entire 28F016SA device. This implies the use of 386 or higher machines. If the code is to be run on a machine with a smaller address space, the code must be modified to include some sort of "windowing" scheme which maps segments of flash into system memory. The Intel 82365 is commonly used for this purpose.
- "Ints" are 16 bit and "longs" 32 bit in C.
- It is assumed that these pointers return a value equal to what they are pointing to. In other words, even though the pointer may be four (4) bytes long, this does not imply that incrementing the pointer by one will move the pointer four (4) bytes in memory. It is entirely dependent upon what the pointer is pointing to that determines how the increment will be effected. In the case of four (4) byte pointers and 16-bit ints, incrementing the pointer by one will effectively move the pointer two (2) bytes.
- There exists a function "set\_pin" which can set an individual 28F016SA pin, given the pin number.

- There exists a function "get\_pin" which can return the value of an individual 28F016SA pin, given the pin number.
- The C code can access a function which derives the corresponding block base address from any given address.
- BYTE# pin on the device determines whether addressing refers to words or bytes. I assume word writes/reads to a single device. With minor modifications this code can be adapted for a pair of 28F016SAs in Byte mode.
- 28F016SA commands can be written to any address in the block or device to be affected by that command.

Both the C and ASM86 code in this document contain the following routines, in this order:

CSR\_word\_byte\_writes(compatible with 28F008SA) CSR\_block\_erase(compatible with 28F008SA) CSR\_\_erase\_\_suspend\_\_to\_\_read(compatible with 28F008SA) lock\_block lock\_status\_upload\_to\_BSR update\_data\_in\_a\_locked\_block add\_data\_in\_a\_locked\_block ESR\_word\_write two\_\_byte\_\_write ESR\_\_page\_\_buffer\_\_write ESR\_block\_erase ESR\_\_erase\_\_all\_\_unlocked\_\_blocks ESR\_suspend\_to\_read\_array ESR automatic erase suspend to write ESR full status check for data write ESR\_\_full\_\_status\_\_check\_\_for\_\_erase single\_load\_to\_pagebuffer sequential\_load\_to\_pagebuffer upload\_\_device\_\_information RYBY\_reconfiguration page\_buffer\_swap

The names of these routines have been changed to more closely match the algorithms presented in the 28F016SA User's Manual (Order Number 297372). Please see Appendix A for a table documenting these changes.

### **ABOUT THE 28F016SA**

Companion product datasheets for the 28F016SA should be reviewed in conjunction with this application note for a complete understanding of the device.

The example code makes extensive use of bit-masking when interpreting the status registers. As a quick review, note that any bit in a register can be tested by bitwise ANDing the register with the appropriate power of two. Since all of the bits other than the one being



tested are masked out, testing the resulting byte for truth is the same as testing the desired bit for truth. For example, if a register contains 01001010, the test for bit 3 would be ANDing the register with 00001000, or hex 8, and testing the result for truth:

| Binary     | Hex  |                |
|------------|------|----------------|
| 01001010   | 4A   | Register       |
| & 00001000 | & 08 | Mask for bit 3 |
| = 00001000 | = 08 | Result         |

In this case the result byte is true, indicating that bit 3 in the register was a 1.

The meanings of the individual bits of these registers is presented here for reference. Note that there are two status register spaces, both of which are distinct from the flash memory array address space. In the CSR space, the CSR is mapped to every address. In the ESR space, the GSR is mapped two words above the base of each 64K byte block, i.e. to addresses 2, 8002H, 10002H, etc. (in word mode), while each BSR is similarly mapped one word above the base of each 64K byte block to locations 1, 8001H, 10001H, etc. (in word mode), each BSR reflecting the status of its own block.

| CSR.7 | Write State Machine<br>Status | 1= ready<br>0= busy                                                                                     |
|-------|-------------------------------|---------------------------------------------------------------------------------------------------------|
| CSR.6 | Erase-suspend Status          | 1 = erase suspended<br>0 = erase in progress/<br>completed                                              |
| CSR.5 | Erase Status                  | 1 = error in block<br>erase<br>0 = successful block<br>erase                                            |
| CSR.4 | Data-write Status             | 1 = error in data write<br>0 = successful data<br>write                                                 |
| CSR.3 | V <sub>PP</sub> Status        | 1= V <sub>PP</sub> low detect/<br>operation aborted<br>0= V <sub>PP</sub> OK when<br>operation occurred |
| CSR.2 | Reserved for future use       |                                                                                                         |
| CSR.1 | Reserved for future use       | ١.                                                                                                      |
| CSR.0 | Reserved for future use       |                                                                                                         |

| GSR.7 | Write State Machine<br>Status   | 1 = ready<br>0 = busy                                                                    |
|-------|---------------------------------|------------------------------------------------------------------------------------------|
| GSR.6 | Operation-suspend<br>Status     | 1 = operation<br>suspended<br>0 = operation in<br>progress/<br>completed                 |
| GSR.5 | Device Operation<br>Status      | 1 = operation unsuccessful 0 = operation successful or running                           |
| GSR.4 | Device Sleep Status             | 1 = device in sleep<br>0 = device not in<br>sleep                                        |
| GSR.3 | Queue Status                    | 1= queue full<br>0= queue available                                                      |
| GSR.2 | Page Buffer<br>Availability     | 1 = one/two page<br>buffers available<br>0 = no page buffers<br>available                |
| GSR.1 | Page Buffer Status              | 1 = selected page<br>buffer ready<br>0 = selected page<br>buffer busy                    |
| GSR.0 | Page Buffer Select<br>Status    | 1 = page buffer 1<br>selected<br>0 = page buffer 0<br>selected                           |
| BSR.7 | Block Status                    | 1= ready<br>0= busy                                                                      |
| BSR.6 | Block-lock Status               | 1 = block unlocked<br>for write/erase<br>0 = block locked to<br>write/erase              |
| BSR.5 | Block Operation<br>Status       | 1= error in block<br>operation<br>0= successful block<br>operation                       |
| BSR.4 | Block Operation Abort<br>Status | 1 = block operation<br>aborted<br>0 = block operation<br>not aborted                     |
| BSR.3 | Queue Status                    | 1= device queue full<br>0= device queue<br>available                                     |
| BSR.2 | V <sub>PP</sub> Status          | 1 = V <sub>PP</sub> low detected<br>0 = V <sub>PP</sub> OK when<br>operation<br>occurred |
| BSR.1 | Reserved for future use         |                                                                                          |
| BSR.0 | Reserved for future use         |                                                                                          |



### 28F016SA Commands

The 28F016SA command set is a superset of the 28F008SA command set, giving existing 28F008SA code the ability to run on the 28F016SA with minimal modifications.

### 28F008SA-Compatible Commands

| 00         | invalid/reserved       |
|------------|------------------------|
| 20         | single block erase     |
| 40         | word/byte write        |
| 50         | clear status registers |
| 70         | read CSR               |
| 90         | read ID codes          |
| <b>B</b> 0 | erase suspend          |
| D0         | confirm/resume         |
| FF         | read flash array       |
|            |                        |

## 28F016SA Performance-Enhancement Commands

| 0C    | page buffer write to flash       |
|-------|----------------------------------|
| 71    | read GSR and BSRs (i.e. the ESR) |
| 72    | page buffer swap                 |
| 74    | single load to page buffer       |
| 75    | read page buffer                 |
| 77    | lock block                       |
| 80    | abort                            |
| 96,01 | RY/BY# enable to level-mode      |
| 96,02 | RY/BY# pulse on write            |
| 96,03 | RY/BY# pulse on erase            |
| 96,04 | RY/BY# pin disable               |
| 97    | upload BSRs with lock bit        |
| 99    | upload device information        |
| A7    | erase all unlocked blocks        |
| E0    | sequential load to page buffer   |
| T-0   | 1                                |

FB two-byte write



```
"C" DRIVERS
/**********************
/* Copyright Intel Corporation, 1993
/* File : stddefs.h
                                                      */
/* Standard definitions for C Drivers for the 28F016SA/SV/XS/XD Flash
                                                      */
/* memory components
/* Author : Taylor Gautier, Intel Corporation
                                                      */
/* Revision 1.0, 23 September 1994
                     0
#define HIGH
                     1
/*******************************
                                                      */
#define NO_ERROR 0
#define VPP LOW
                     1
#define OP_ABORTED
                     2
#define BLOCK_LOCKED
#define COMMAND_SEQ_ERROR
#define WP LOW
/**************************
#define BIT 0
                    0x0001
                     0x0002
#define BIT_1
#define BIT_2
                     0x0004
#define BIT_3
                     0x0008
#define BIT 4
                     0x0010
#define BIT 5
                     0x0020
#define BIT_6
                     0 \times 0040
#define BIT_7
                     0x0080
#define LOW_BYTE
                     0x00FF
#define HIGH BYTE
                     0xFF00
/* RY/BY# enable modes
#define RYBY_ENABLE_TO_LEVEL 1
#define RYBY_PULSE_ON_WRITE 2
#define RYBY_PULSE_ON_ERASE
#define RYBY_DISABLE
/* pin numbers
/* Write Protect pin (active low) is pin number 56 on standard
/* pinout of 28F016SA.
#define VPP 15
/* Vpp pin is pin number 15 on standard pinout of 28F016SA.
                                                       */
                                                    292126-1
```



```
/*****************
/* Copyright Intel Corporation, 1993
                                                                        */
/* File : drivers.c
/* Example C Routines for 28F016SA/SV/XS/XD Flash memory components
/* Original Author : Patrick Killelea, Intel Corporation
                                                                        */
/* Revised By : Taylor Gautier, Intel Corporation
                                                                        */
/* Revision 2.0, 23 September 1994
                                                                        */
                                                                        * /
/* NOTE: BYTE# pin on the device determines whether addressing
                                                                        */
/* refers to words or bytes. I assume word mode.
                                                                        */
/* NOTE: A 28F016SA command can be written to any address in the
                                                                        */
/* block or device to be affected by that command.
                                                                        */
           ****************
#include <stdio.h>
#include "stddefs.h"
void set_pin(int pin, int level)
/* set_pin is an implementation-dependent function which sets a
/* given pin on the standard 28F016SA pinout HIGH = 1 or LOW = 0.
int get_pin(int pin)
/* get_pin is an implementation-dependent function which returns a
                                                                        * /
/* given pin on the standard 28F016SA pinout HIGH = 1or LOW = 0
int *base(int *address)
/* base is an implementation-dependent function which takes an
/* address in the flash array and returns a pointer to the base
/* of that 64K byte block.
char *byte_base(char *address)
/* byte version of base function described above
                                                                        * /
                                                                    292126-2
```



```
int CSR_word_byte_writes(int *address, int data)
/* This procedure writes a byte to the 28F016SA.
/* It also works with the 28F008SA.
int CSR;
/* CSR variable is used to return contents of CSR register.
                                                                             */
*address = 0X1010;
/* Word Write command
                                                                             */
*address = data;
/* Actual data write to flash address.
                                                                             */
while(!(BIT_7 & *address));
/* Poll CSR until CSR.7 = 1 (WSM ready)
                                                                             */
CSR = *address;
/* Save CSR before clearing it.
*address = 0X5050;
/* Clear Status Registers command
*address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
                                                                             */
return(CSR);
/* Return CSR to be checked for status of operation.
                                                                             */
}
                                                                         292126-3
```



| <pre>int CSR_block_erase(int *address) {</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /   |
| •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | /   |
| *address = 0x2020;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| /* Single Block Erase command * *address = 0XD0D0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | /   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . / |
| *address = 0xD0D0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ′   |
| the same of the sa | /   |
| <pre>while(!(BIT_7 &amp; *address)) /* Poll CSR until CSR.7 = 1 (WSM ready) ***</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | . / |
| {                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ′   |
| ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | /   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /   |
| <b>}</b> ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| /* At this point, CSR.7 is 1, indicating WSM is not busy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | /   |
| /* Note that we are still reading from CSR by default.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| CSR = *address;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| ,,,,,,,, .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | /   |
| *address = 0X5050; /* Clear Status Registers command *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | . / |
| *address = 0xFFFF;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ′   |
| /* Write FFH after last operation to reset device to read array mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |
| return(CSR);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /   |
| <pre>} /* If a write has been queued, an automatic erase suspend occurs to write *</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | . / |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | :/  |
| 292126-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -4  |



```
int CSR_erase_suspend_to_read(int *read_address, int *erase_address, int
*result)
/* This procedure suspends an erase operation to do a read.
int CSR;
/* CSR variable is used to return contents of CSR register.
/* Assume erase is underway in block beginning at erase_address.
*erase_address = 0XB0B0;
/* Erase Suspend command
while(!(BIT_7 & *erase_address));
/* Poll CSR until CSR.7 = 1 (WSM ready)
if (BIT_6 & *erase_address) {
/* If CSR.6 = 1 (erase incomplete)
       *erase_address = OXFFFF;
       /* Read Flash Array command
       *result = *read_address;
       /* Do the actual read. Any number of reads can be done here.
       *erase_address = 0XD0D0;
       /* Erase Resume command
} else {
       *erase_address = 0XFFFF;
       /* Read Flash Array command
       *result = *read_address;
       /* Do the actual read. Any number of reads can be done here.
*erase_address = 0x7070;
/* Read CSR command
CSR = *erase_address;
/* Save CSR before clearing it.
*erase_address = 0x5050;
/* Clear Status Registers command
return(CSR);
/* Return CSR to be checked for status of operation.
                                                                        292126-5
```



```
int lock_block(int *lock_address)
/* This procedure locks a block on the 28F016SA.
                                                                             * /
int ESR;
/* ESR variable is used to return contents of GSR and BSR.
int *block_base = base(lock address);
/* Find pointer to base of block being locked.
*lock_address = 0X7171;
/* Read Extended Status Registers command
while (BIT_3 & *(block_base + 2));
/* Poll GSR until GSR.3 = 0 (queue available).
set_pin(WPB, HIGH);
/* Disable write protection by setting WPB high.
set pin(VPP, HIGH);
/* Enable Vpp, wait for ramp if necessary in this system.
*lock_address = 0x7777;
/* Lock Block command
*lock_address = 0XD0D0;
/* Confirmation command
*lock_address = 0x7171;
/* Read Extended Status Registers command
while (!(BIT_7 & *(block_base + 2)));
/* GSR is 2 words above 0; poll GSR until GSR.7 = 1 (WSM ready).
ESR = (*(block_base + 2) << 8) + (*(block_base + 1) & LOW_BYTE);
/* Put GSR in top byte and BSR in bottom byte of return value.
*lock_address = 0x5050;
/* Clear Status Registers command
*lock_address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
return(ESR);
                                                                        292126-6
```



```
int lock_status_upload_to_BSR(int *address)
/* This procedure uploads status information into the BSR from non-
/* volatile status bits.
int ESR;
/* ESR variable is used to return contents of GSR and BSR.
int *block_base = base(address);
/* Find pointer to base of 32K word block.
*address = 0X7171;
/* Read Extended Status Registers command
while (BIT_3 & *(block_base + 2));
/* Poll GSR until GSR.3 = 0 (queue available).
*address = 0x9797;
/* Lock-status Upload command
*address = 0XD0D0;
/* Confirmation command
*address = 0X7171;
/* Read Extended Status Registers command
while (!(BIT_7 & *(block_base + 2)));
/* Poll GSR until GSR.7 = 1 (WSM not busy)
ESR = (*(block_base + 2) << 8) + (*(block_base + 1) & LOW_BYTE);
/* Put GSR in top byte and BSR in bottom byte of return value.
*address = 0x5050;
/* Clear Status Registers command
*address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
                                                                             */
return(ESR);
                                                                         292126-7
```



```
int update_data_in_a_locked_block()
/* This routine is implemented as pseudo-code to provide an example of
                                                                             */
/* impementing the flowchart Updating Data in a Locked Block from the
                                                                              */
/* 28F016SA User's Manual
set_pin(WPB, HIGH);
/* set WP# high
block_erase_with_CSR(block_address);
/* erase block
                                                                              * /
set_pin(WPB, LOW);
/* set WP# low
WriteNewData():
/* Use one of Word/Byte Write, Two-Byte Write or Page Buffer Write to Flash*/
lock_block(block_address);
/* lock block if desired
                                                                              */
int add_data_in_a_locked_block()
/* This routine is implemented as pseudo-code to provide an example of
                                                                             * /
/* impementing the flowchart Updating Data in a Locked Block from the
                                                                              * /
/* 28F016SA User's Manual
                                                                              */
set_pin(WPB, HIGH);
/* set WP# high
                                                                              * /
WriteNewData();
/* Use one of Word/Byte Write, Two-Byte Write or Page Buffer Write to
/* Flash
set_pin(WPB, LOW);
/* set WP# low
                                                                              */
                                                                          292126-8
```



```
int ESR_word_write(int *write_address, int *data, int word_count)
/* This procedure writes a word to the 28F016SA.
int counter, ESR;
/* counter is used to loop through data array
/* ESR variable is used to return contents of GSR and BSR.
int *block_base = base(write_address);
for (counter = 0; counter < word_count; counter++) {</pre>
        *write_address = 0x7171;
        /* Read Extended Status Registers command
                                                                             */
       while (BIT_3 & *(block_base + 1));
        /* Poll BSR until BSR.3 of target address = 0 (queue available).
        /* BSR is 1 word above base of target block in status reg space.
        *write_address = 0x1010;
        /* Write word command
                                                                             */
        *write_address = data[counter];
        /* Write actual data.
                                                                             */
*write address = 0X7171:
/* Read Extended Status Registers command
while (!(BIT_7 & *(block_base + 1)));
/* Poll BSR until BSR.7 of target address = 1 (block ready).
ESR = (*(block_base + 2) << 8) + (*(block_base + 1) & LOW_BYTE);
/* Put GSR in top byte and BSR in bottom byte of return value.
*write_address = 0x5050;
/* Clear Status Registers command
*write_address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
                                                                             */
return(ESR);
                                                                         292126-9
```



```
int two_byte_write(char *address, char *data, int byte_count)
/* This routine is used when BYTE# is low, i.e. the 28F016SA
                                                                             */
/* is in byte mode, to emulate a word write.
                                                                             */
/* Because of this, commands are given as 0x00XY instead of 0xXYXY as in
                                                                             */
/* the rest of the code presented here.
/* *data is a byte array containg the low byte, high byte consecutively of */
/* each word.
int counter, ESR;
/* ESR variable is used to return contents of GSR and BSR.
                                                                             */
char *block_base = byte_base(address);
/* Find pointer to base of block.
                                                                             * /
for (counter = 0; counter < byte_count; counter++) {</pre>
        *address = 0X0071;
        /* Read Extended Status Registers command
       while (BIT_3 & *(block_base + 2));
        /* Poll BSR until BSR.3 of target address = 0 (queue available).
                                                                             */
        *address = 0x00FB;
        /* Two-byte Write command
                                                                             */
        *address = data[counter++];
        /* Load one byte of data register; A0 = 0 loads low byte, A1 high
                                                                             */
        *address = data[counter];
        /* 28F016SA automatically loads alternate byte of data register
                                                                             * /
/\star Write is initiated. Now we poll for successful completion.
                                                                             */
*address = 0X0071;
/* Read Extended Status Registers command
                                                                             */
while (!(BIT_7 & *(block_base + 2)));
/* Poll BSR until BSR.7 of target address = 1 (block ready).
                                                                             * /
/* BSR is 1 word above base of target block in status reg space.
                                                                             * /
ESR = (*(block_base + 4) << 8) + (*(block_base + 2) & LOW_BYTE);
/* Put GSR in top byte and BSR in bottom byte of return value.
*address = 0X0050;
/* Clear Status Registers command
*address = 0x00FF;
/* Write FFH after last operation to reset device to read array mode.
return(ESR);
}
                                                                         292126-10
```



```
int ESR_pagebuffer_write(int *address, int word_count)
/* This procedure writes from page buffer to flash.
                                                                             */
/* This routine assumes page buffer is already loaded.
                                                                             */
/* Address is where in flash array to begin writing.
                                                                             */
/* Low byte of word count word_count must be 127 or fewer, high must be 0.
                                                                             */
/* High byte of word count exists for future Page Buffer expandability.
                                                                             */
int ESR;
/* ESR variable is used to return contents of GSR and BSR.
                                                                             */
int *block_base = base(address);
/* Find pointer to base of block to be written.
*address = 0X7171;
/* Read Extended Status Registers command
                                                                             */
while (BIT_3 & *(block_base + 1));
/* Poll BSR until BSR.3 of target address = 0 (queue available).
                                                                             */
*address = 0X0C0C;
/* Page Buffer Write to Flash command
*address = word count;
/* high byte is a don't care, write the low byte
*address = 0;
/* write high byte of word_count which must be 0 (reserved for future use) */
*address = 0x7171;
/* Read Extended Status Registers command
while (!(BIT_7 & *(block_base + 1)));
/* Poll BSR until BSR.7 of target address =1 (block ready).
ESR = (*(block\_base + 2) << 8) + (*(block\_base + 1) & LOW\_BYTE);
/* Put GSR in top byte and BSR in bottom byte of return value.
*address = 0x5050;
/* Clear Status Registers command
*address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
return(ESR);
}
                                                                        292126-11
```



| <pre>int ESR_block_erase(int *erase_address) /* This procedure erases a block on the 28F016SA.</pre>              | */        |
|-------------------------------------------------------------------------------------------------------------------|-----------|
| {                                                                                                                 | ,         |
| <pre>int ESR; /* ESR variable is used to return contents of GSR and BSR.</pre>                                    | */        |
| int *block_base = base(erase_address);                                                                            | ~ /       |
| <pre>/* Find address of base of block being erased.</pre>                                                         | */        |
| *erase_address = 0x7171;                                                                                          |           |
| /* Read Extended Status Registers command                                                                         | */        |
| <pre>while (BIT_3 &amp; *(block_base + 1)); /* Poll BSR until BSR.3 of erase_address = 0 (queue available).</pre> | */        |
| /* BSR is 1 word above base of target block in ESR space.                                                         | */        |
| *erase_address = 0x2020;                                                                                          |           |
| /* Single Block Erase command                                                                                     | */        |
| *erase_address = 0XD0D0; /* Confirm command                                                                       | */        |
| *erase_address = 0xD0D0;                                                                                          | ,         |
| /* Resume command, per latest errata update                                                                       | */        |
| *erase_address = 0X7171;                                                                                          |           |
| <pre>/* Read Extended Status Registers command while (!(BIT_7 &amp; *(block_base + 1)));</pre>                    | */        |
| /* Poll BSR until BSR.7 of target erase_address = 1 (block ready).                                                | */        |
| ESR = (*(block_base + 2) << 8) + (*(block_base + 1) & LOW_BYTE);                                                  |           |
| /* Put GSR in top byte and BSR in bottom byte of return value.                                                    | */        |
| *erase_address = 0X5050;                                                                                          |           |
| /* Clear Status Registers command                                                                                 | */        |
| <pre>*erase_address = 0xFFFF; /* Write FFH after last operation to reset device to read array mode.</pre>         | */        |
| return(ESR);                                                                                                      | " /       |
| }                                                                                                                 |           |
|                                                                                                                   | 292126-12 |
|                                                                                                                   |           |



```
int ESR_erase_all_unlocked_blocks(int *device_address, long *failure_list)
/* This procedure erases all the unlocked blocks on a 28F016SA.
int GSR:
/* Return value will contain GSR in both top and bottom byte.
                                                                             * /
/* 32 bit long pointed to by failure_list is used to return map
                                                                             */
/* of block failures, each bit representing one block's status.
/* device_address points to base of chip.
int block;
/* block is used to hold block count for loop through blocks.
                                                                             */
long power = 1;
*failure_list = 0;
/* Initialize all 32 bits of failure list long to 0.
                                                                             */
*device_address = 0x7171;
/* Read Extended Status Registers
                                                                             */
while (BIT_3 & *(device_address + 1));
/* Poll BSR until BSR.3 of target address = 0 (queue available).
                                                                             */
*device_address = 0%A7A7;
/* Full-chip erase command
*device_address = 0XD0D0;
/* Confirm command
*device_address = 0X7171:
*/* Read Extended Status Registers command
while (!(BIT_7 & *(device_address + 2)));
/* Poll GSR until GSR.7 = 1 (WSM ready)
                                                                             * /
for (block = 0; block < 0x0020; block++)
        /* Go through blocks, looking at each BSR.5 for operation failure
        /* and setting appropriate bit in long pointed to by failure list.
        if (BIT_5 & *(device_address + block * 0X8000 + 1))
        /* Multiply block by 32K words to get to the base of each block.
                *failure_list += power;
                /* If the block failed, set that bit in the failure list.
        power = power << 1;
        /* Increment to next power of two to access next bit.
                                                                             * /
}
GSR = *(device_address + 2);
*device_address = 0x5050;
/* Clear Status Registers command
                                                                             */
*device_address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
return(GSR);
}
                                                                         292126-13
```



```
int ESR_suspend_to_read_array(int *address,int *result)
/* This procedure suspends an erase on the 28F016SA.
                                                                             */
/* Address is assumed to point to location to be read.
/* result is used to hold read value until procedure is complete.
int ESR:
/* ESR variable is used to return contents of GSR and BSR.
int *block_base = base(address);
*address = 0x7171;
/* Read Extended Status Registers command
                                                                             */
while (!(BIT_7 & *(block_base + 1)));
/* Poll BSR until BSR.7 of target address = 1 (block ready).
/* BSR is 1 word above base of target block in ESR space.
*address = 0XB0B0;
/* Operation Suspend command
*address = 0x7171;
/* Read Extended Status Registers command
                                                                             * /
while (!(BIT_7 & *(block_base + 2)));
/* Poll GSR until GSR.7 = 1 (WSM ready).
                                                                             * /
if (BIT_6 & *(block_base + 2)) {
/* GSR.6 = 1 indicates an operation was suspended on this device,
                                                                             */
       *address = 0XFFFF;
        /* Read Flash Array command
       *result = *address;
        /* Read the data.
                                                                             * /
       *address = 0XD0D0;
        /* Resume the operation.
} else {
       *address = 0XFFFF;
        /* Read Flash Array command
       *result = *address;
        /* Read the data.
}
*address = 0x7171;
/* Read Extended Status Registers command
ESR = (*(block_base + 2) << 8) + (*(block_base + 1) & LOW_BYTE);
/* Put GSR in top byte and BSR in bottom byte of return value.
*address = 0X5050;
/* Clear Status Registers command
                                                                             * /
return(ESR);
                                                                        292126-14
```



```
int ESR_automatic_erase_suspend_to_write(int *write_address, int
*erase_address, int data)
/* This procedure writes to one block while another is erasing.
                                                                             */
int ESR;
/* ESR variable is used to return contents of GSR and BSR.
                                                                             */
int * block_base = base(erase_address);
/* Find pointer to base of block being erased.
                                                                             * /
*erase_address = 0X7171;
/* Read Extended Status Register command
while (BIT_3 & *(block_base + 1));
/* Poll BSR until BSR.3 of target address = 0 (queue available).
/* BSR is 1 word above base of target block in ESR space.
*erase_address = 0x2020;
/* Erase Block command
*erase_address = 0XD0D0;
/* Confirm command
*erase_address = 0X7171;
/* Read Extended Status Register command
                                                                             */
while (BIT_3 & *(block_base + 1));
/* Poll BSR until BSR.3 of target address = 0 (queue available).
                                                                             * /
/* BSR is 1 word above base of target block in ESR space.
                                                                            */
*write_address = 0X4040;
/* Word Write command
*write address = data:
/* Write actual data.
/* Erase suspends, write takes place, then erase resumes.
*erase_address = 0X7171;
/* Read Extended Status Registers command
while (!(BIT_7 & *(block_base + 1)));
/* Poll BSR until BSR.7 of erase address = 1 (block ready).
/* BSR is 1 word above base of target block in status reg space.
ESR = (*(block_base + 2) << 8) + (*(block_base + 1) & LOW_BYTE);
/* Put GSR in top byte and BSR in bottom byte of return value.
*block_base = 0x5050;
/* Clear Status Registers command
*block_base = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
return(ESR);
}
                                                                        292126-15
```



```
int ESR_full_status_check_for_data_write(int *device_address)
int errorcode;
*device_address = 0x7171;
/* Read Extended Status Resisters command
                                                                            */
while (!(BIT_7 & *(device_address + 2)));
/* Poll GSR until GSR.7 = 1 (WSM ready)
/* to make sure data is valid
if (*(device_address + 1) & BIT 2) errorcode = VPP LOW;
/* BSR.2 = 1 indicates a Vpp Low Detect
else if (*(device_address + 1) & BIT_4) errorcode = OP_ABORTED;
/* BSR.4 = 1 indicates an Operation Abort
else if (get_pin(WPB) == LOW) errorcode = NO ERROR;
else if (*(device_address + 1) & BIT_6) errorcode = BLOCK_LOCKED;
/* BSR.6 = 1 indicates the Block was locked
else errorcode = NO_ERROR;
while (!(BIT_7 & *(device_address + 2)));
/* Poll GSR until GSR.7 = 1 (WSM ready)
/* make sure chip is ready to accept command
*device_address = 0x5050;
/* Clear Status Registers
                                                                            */
return errorcode;
}
                                                                        292126-16
```



```
int ESR_full_status_check_for_erase(int *device_address)
int errorcode = NO ERROR;
*device_address = 0x7171;
/* Read Extended Status Resisters command
                                                                            */
while (!(BIT_7 & *(device_address + 2)));
/* Poll GSR until GSR.7 = 1 (WSM ready)
/* make sure command completed
if (*(device_address + 1) & BIT_2) errorcode = VPP_LOW;
/* BSR.2 = 1 indicates a Vpp Low Detect
else if (*(device_address + 1) & BIT_4) errorcode = OP_ABORTED;
/* BSR.4 = 1 indicates an Operation Abort
else if (get_pin(WPB) == LOW && !(*(device_address + 1) & BIT_6))
                 errorcode = BLOCK_LOCKED;
/* BSR.6 = 0 indicates the Block was locked
if (errorcode == NO_ERROR) {
       *device_address = 0x7070;
        /* Read Compatible Status Register
       if ((*device_address & BIT_4) && (*device_address & BIT_5))
       /* CSR.4 and CSR.5 == 1 indicate a command sequence error
               errorcode = COMMAND_SEQ_ERROR;
while (!(BIT_7 & *(device_address + 2)));
/* Poll GSR until GSR.7 = 1 (WSM ready)
/* make sure device is ready
*device_address = 0x5050;
/* Clear Status Registers command
return errorcode;
                                                                        292126-17
```





```
void sequential_load_to_pagebuffer(int *device_address, char *start_address,
int word_count, int* data)
/* This procedure loads multiple words to a page buffer.
                                                                             * /
/* device_address points to base of chip.
/* Low byte of word_count must be 127 or fewer, high must be 0.
/* word_count is zero-based counting, i.e word_count == 0 loads 1 word,
                                                                             */
/* word_count == 1 loads 2 words etc.
/* High byte of word_count exists for future Page Buffer expandability.
                                                                             */
char counter:
/* counter is used to keep track of words written.
*device_address = 0x7171;
/* Read Extended Status Registers command
while (BIT_2 & *(device_address + 2));
/* Poll GSR until GSR.2 = 0 (page buffer available).
*device_address = 0XE0E0;
/* Sequential Page Buffer Load command
*start_address = word_count;
*start_address = 0;
/* Automatically loads high byte of count register
for (counter = 0; counter <= word_count; counter++)</pre>
       *(start_address + counter) = data[counter];
/* Loop through data, writing to page buffer.
/* This routine does not affect status registers.
*device_address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
                                                                        292126-19
```

## intط<sub>®</sub>

```
int upload_device_information(int *address)
/* This procedure uploads the device revision number to the variable DRC.
/* This implementation differs in that it does not loop as in the
                                                                             */
                                                                             */
/* algorithm. This is so the calling routine can have a chance to do
                                                                             */
/* error checking instead of looping forever waiting for the device
/* complete the operation.
int DRC = 0:
/* DRC variable is used to return device revision status.
int *block_base = base(address);
/* Find pointer to base of 32K word block.
*address = 0X7171;
/* Read Extended Status Registers command
                                                                             * /
while ((BIT_3 & *(block_base + 2)) && (!(BIT_7 & *(block_base + 2))));
/* Poll GSR until GSR.3 = 0 (queue available) and GSR.7 = 1
/* (WSM available).
*address = 0X9999;
/* Device information Upload command
*address = 0XD0D0:
/* Confirmation command
*address = 0X7171;
/* Read Extended Status Registers command
while (!(BIT_7 & *(block base + 2)));
/* Poll GSR until GSR.7 = 1 (WSM not busy)
if (BIT_5 & *(block_base+2)) return ((*(block_base+2) & HIGH_BYTE) << 8);</pre>
/* if GSR.5 = 1 operation was unsuccessful. Return GSR and 0 in DRC
*address = 0X7272;
/* Swap page buffer to bring buffer with status information to top.
*address = 0X7575;
/* Read Page Buffer command
                                                                             */
DRC = (*(block_base + 2) & 0XFF00 << 8) + (*(block_base + 3) & LOW_BYTE);</pre>
                                                                             * /
/* Put GSR in top byte of return value.
                                                                             */
/* User should check GSR for operation success
/* Put device revision code in bottom byte of return value.
                                                                             * /
/* Note that device revision code was read from word 3 in page buffer.
                                                                            x /
*address = 0x5050;
/* Clear Status registers command
                                                                             * /
*address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
return(DRC);
                                                                         292126-20
```



```
int RYBY_reconfigure(int *address, int mode)
/* this procedure changes the RY/BY# configuration mode to the given mode
int GSR:
/* the GSR variable is used to return the value of the GSR
                                                                              */
*address = 0x7171;
/* Read Extended Registers command
                                                                              */
while (BIT_3 & *(address+2));
/* Poll GSR until GSR.3 = 0 (queue available)
*address = 0x9696:
/* Enable RY/BY# configuration, next command configures RY/BY#
                                                                              */
switch (mode) {
       case RYBY_ENABLE_TO_LEVEL:
               *address = 0 \times 0101;
                /* Enable RY/BY# to level mode
               break;
       case RYBY_PULSE_ON_WRITE:
               *address = 0x0202;
                /* Enable RY/BY# to pulse on write
                                                                              */
               break;
       case RYBY_PULSE_ON_ERASE:
               *address = 0x0303;
               /* Enable RY/BY# to pulse on erase
               break;
       case RYBY_DISABLE:
       default:
               *address = 0 \times 0404:
               /* Enable RY/BY# to disable
                                                                              */
*address = 0X7171;
/* Read Extended Status Registers command
while (!(BIT_7 & *(address + 2)));
/* Poll GSR until GSR.7 = 1 (WSM ready)
GSR = *(address+2) & LOW_BYTE;
/* put GSR into low byte of return value
*address = 0x5050;
/* Clear Status registers command
                                                                             */
*address = 0xFFFF;
/* Write FFH after last operation to reset device to read array mode.
return (GSR);
}
                                                                         292126-21
```



| <pre>int page_buffer_swap(int *address) {</pre>                                                                                                                                                                                                                                                          |                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| /* This routine attempts to swap the page buffers, returning the value /* the GSR before the operation in the upper byte and the value of the /* after the operation in the lower byte for comparison /* For operation to be successful, the following must be true : /* (before) GSR.0 = (after) !GSR.0 | */<br>*/<br>*/<br>*/ |
| <pre>/* (after) GSR.5 = 0 int GSR;</pre>                                                                                                                                                                                                                                                                 | */                   |
| /* GSR variable is used to return contents of GSR before and after /* operation                                                                                                                                                                                                                          | */<br>*/             |
| *address = 0x7171;                                                                                                                                                                                                                                                                                       |                      |
| /* Read Extended Registers command                                                                                                                                                                                                                                                                       | */                   |
| GSR = *(address+2) << 8;                                                                                                                                                                                                                                                                                 | •                    |
| /* Put GSR into upper byte before page buffer swap                                                                                                                                                                                                                                                       | */                   |
| *address = 0x7272;                                                                                                                                                                                                                                                                                       |                      |
| /* write Page Buffer Swap command                                                                                                                                                                                                                                                                        | */                   |
| GSR  = (*(address+2) & LOW_BYTE);                                                                                                                                                                                                                                                                        |                      |
| <pre>/* Put GSR after operation into low byte for comparison *address = 0x5050;</pre>                                                                                                                                                                                                                    | */                   |
| /* Clear Status registers command                                                                                                                                                                                                                                                                        | * /                  |
| *address = 0xFFFF:                                                                                                                                                                                                                                                                                       | ,                    |
| /* Write FFH after last operation to reset device to read array mode.                                                                                                                                                                                                                                    | */                   |
| return (GSR);                                                                                                                                                                                                                                                                                            | ,                    |
| }                                                                                                                                                                                                                                                                                                        |                      |
|                                                                                                                                                                                                                                                                                                          | 292126-22            |

3.



```
ASM86 ASSEMBLY LANGUAGE DRIVERS
; Copyright Intel Corporation, 1993
; EXAMPLE ASM86 Drivers for the 28F016SA Flash memory component
; Original Author : Patrick Killelea, Intel Corporation
; Revised By : Taylor Gautier
; Revision 2.0, September 26, 1994
; The code assumes 32-bit flat model protected mode for simplicity.
; i.e. ES contains 0 and EDI accesses the entire memory space.
public 'CODE'
TRYT
     segment byte
     assume cs:TEXT
; Following is the structure by which all parameters are passed.
params STRUCT
     erase_addr
                         ?
                              ; base of block or device to
                    DD
                              ; erase
                         ?
     write_addr
                    DD
                              ; address to write to
     write base
                    DD
                         ?
                             : base address of block written
                             ; to
                         ?
                             ; address to read from
     read_addr
                    DD
                             ; base address of block read from
     read_base
                  . DD
                         ?
     lock_addr
                         ?
                             ; base address of block to lock
                    DD
     data_addr
                    DD
                         ?
                             ; address of data to write
     data
                    DW
                         ?
                             : data word to write
     pagebuffer_start_addr DB
                         ?
                             ; start address in page buffer
     word count
                              ; number of words for a multiple
                              : read/write
params ENDS
: Error Codes
NO ERROR
               DW
                    n
VPP_LOW
               DW
                    1
OP_ABORTED
               DW
                    2
BLOCK_LOCKED
               DW
                    3
COMMAND_SEQ_ERROR
               DW
WP_LOW
               DW
: Error Codes
RYBY_ENABLE_TO_LEVEL DW
                    1
RYBY_PULSE_ON_WRITE
               DW
                    2
RYBY_PULSE_ON_ERASE
               DW
                    3
RYBY DISABLE
               DW
                    4
; MACRO set_pin
; This macro pushes parameters needed for the set_pin routine, calls
                                               292126-23
```



```
; set_pin, and then pops those parameters. set_pin is an implementation-
; dependent function which sets a given pin on the standard 28F016SA
; pinout HIGH = 1 or LOW = 0.
; Data needed at the beginning of this macro:
; pin: 28F016SA pin number
; level:
          level to set pin
: Trashes : CX
MACRO set_pinpin, level
     push
          pin
                              : Push pin number
     push
          leve1
                              ; Push logic level of pin
     ca11
          near ptr set pin
                              ; Call set_pin
     gog
          CX
                              ; Pop off parameters
     pop
          CX
KMDM
This macro takes a pointer and increments it by two bytes. Use this
; macro for obtaining the offset to the BSR from a block base address
MACRO BSROFF pointer
     add
          pointer, 2
                              ; BSR is 2 bytes above base
                               : address
: MACRO GSROFF
; This macro takes a pointer and increments it by four bytes. Use this
; macro for obtaining the offset to the GSR from a block base address
MACRO GSROFF pointer
     add
          pointer, 4
                               ; GSR is 4 bytes above base
                               ; address
ENDM
; MACRO GSRBSROFF
; This macro takes a pointer and increments it by two bytes. Use this
; macro for obtaining the offset to the GSR from the BSR
MACRO GSRBSROFF pointer
     add
          pointer, 2
                               ; GSR is 2 bytes from BSR
ENDM
; MACRO BSRGSROFF
; This macro takes a pointer and subtracts it by two bytes. Use this
; macro for obtaining the offset to the BSR from the GSR
|-----
MACRO
     BSRGSROFF pointer
     sub
          pointer, 2
                              ; BSR is 2 bytes below GSR
ENDM
                                                292126-24
```



```
; PROCEDURE
           CSR_word_byte_writes
; This procedure writes a byte to the 28F016SA. It also works with a the
28F008SA.
; Param fields needed:
             params.data: data word to be written
             params.write_addr: offset of 28F016SA address to write
             BX: CSR, duplicated in both high and low bytes
CSR_word_byte_writes proc
                         near
             EDI, params.write_addr
      MOV
      mov
             ES: [EDI], 1010H
                                       ; Write To Flash command
      mov ES: [EDI], params.data
      ; Write data to 28F016SA.
WSM_busy1:
      mov
             AX, ES: [EDI]
                                       ; Read CSR
      test
             AX, 80H
                                       ; Look at CSR.7.
      jz
             short WSM_busy1
                                       ; Loop while CSR.7 = 0.
      ; Poll CSR until CSR.7 = 1, indicatingthat WSM is ready.
                                       ; Return CSR in BX.
      mov
      mov
             ES: [EDI], 5050H
                                       ; Clear Status Registers command
      mov
             ES: [EDI], FFFFH
                                       ; Reset device to read array mode
      ret
                                       ; Return to calling routine.
CSR word byte writes endp
                                                              292126-25
```



```
; PROCEDURE
            CSR_block_erase
; This procedure erases a 64K byte block on the 28F016SA.
; It also works with a pair of 28F008SAs.
; Param fields needed:
             erase_address: offset of base of 28F016SA block to erase
            AX: CSR, duplicated in both high and low bytes
proc
CSR block_erase
                          near
      mov
             EDI, params.erase_addr
      mov
             ES:[EDI],2020H
                                        ; Block Erase command
      mov
             ES:[EDI],DODOH
                                        : Erase Confirm command
             ES:[EDI],DODOH
                                        ; Resume Command per latest
      mov
                                        ; errata update
; Note that it is not strictly necessary to write an erase command to
; the base of a block; any address within the block will do.
WSM_busy2:
      mov .
             AX, ES: [EDI]
                                        ; Read CSR.
      test
            AX,80H
                                        ; If CSR.7 = 0, test sets ZF.
      ; System may issue an erase suspend command here to read data from a
       ; different block
             short WSM_busy2
                                        ; Loop while ZF is set.
      jz
      ; Poll CSR until CSR.7 = 1, indicating that WSM is ready.
             ES: [EDI], 5050H
                                        ; Clear Status Registers command
      mov
             ES: [EDI], FFFFH
                                        ; Reset device to read array mode
      mov
      ret
                                        ; Return to calling routine
                                        ; CSR is already in AX
CSR_block_erase endp
                                                               292126-26
```



```
; PROCEDURE CSR_erase_suspend_to_read
; This procedure suspends an erase operation to do a read.
; It also works with a pair of 28F008SAs.
; It assumes that erase is underway.
; Param fields needed:
             params.erase_addr: offset of 28F016SA block to erase
              params.read_addr: offset of 28F016SA address to read
             BX: CSR, duplicated in both high and low bytes
; Output:
             CX: data read from the address in params.read_addr
CSR_erase_suspend_to_read proc near
      mov
             EDI, params.erase_addr
                                         ; Set up offset of erase address.
             ES: [EDI], BOBOH
                                         ; Erase Suspend command
      mov
WSM_busy3:
      mov
              AX, ES: [EDI]
                                          ; Read CSR from any address.
       test
              AX, 80H
      İΖ
              short WSM busv3
       ; Poll CSR until CSR.7 = 1, indicating that WSM is ready.
      test
              AX,40H
                                          ; test CSR.6
      pushf
                                          ; save result for action later
      mov
              EDI, params.read_addr
                                          ; Set up offset of read address.
              ES: [EDI] , FFFFH
                                          ; Read Flash command
      MOV
              CX, ES: [EDI]
                                         ; Do actual read; put result in
      mov
                                         ; CX.
       ; Arbitrary number of reads can be done here.
      popf
                                          ; get back the result of CSR.6
       jΖ
                                          ; only resume if operation
              short no_resume_command
                                          ; suspended
      mov
              ES: [EDI], DODOH
                                          ; Erase Resume command
no_resume_command:
      MOV
              ES: [EDI],7070H
                                          ; Read CSR command
              BX, ES: [EDI]
                                          ; Read CSR from any address.
      mov
                                          ; Return CSR in BX.
                                          ; Return to calling routine.
CSR_erase_suspend_to_read endp
                                                                  292126-27
```



```
; PROCEDURE lock_block
; This procedure locks a block on the 28F016SA.
; Param fields needed:
             params.lock_addr: offset of base of 28F016SA block to lock
; Output:
             BX: GSR in high byte and BSR in low byte
             AX, DX: trash
lock block
             proc
                    near
      mov
             EDI, params.lock_addr
                                        ; Set up offset of address.
             ES: [EDI],7171H
      mov
                                        ; Read ESR command
      GSROFF EDI
                                        ; Point EDI to GSR
q_unavailable:
      mov
             AX, ES: [EDI]
      test
             AX,08H
      inz
             short q_unavailable
      ; Poll GSR while GSR.3 = 1, indicating queue unavailable.
      set_pin 56,1
                                        ; Disable write protection.
      set_pin 15,1
                                        ; Enable Vpp
      ; Wait for ramp if necessary.
             ES:[EDI],7777H
                                       ; Lock Block command
      mov
             ES:[EDI],DODOH
                                       ; Confirmation command
      mov
      mov
             ES: [EDI],7171H
                                        ; Read ESR command
WSM busy4:
      MOV
             AX, ES: [EDI]
                                        ; Read GSR
      test
             AX, 80H
             short WSM_busy4
      Ηz
      ; Poll GSR while GSR.7 = 0, indicating WSM_busy.
                                        ; Store GSR
             BH, AH
      mov
      ; Look at BSR.6 to see if block successfully locked.
                                        ; Point EDI to BSR from GSR
      BSRGSROFF
                   EDI
             AX, ES: [EDI]
                                        ; Read BSR
      mov
      mov
             BL, AL
                                        ; Store BSR
                                        ; Clear Status Registers command
      mov
             ES: [EDI], 5050H
                                        ; Reset device to read array mode
      mov
             ES: [EDI], FFFFH
      ret
                                        ; Return to calling routine.
lock_block
             endp
                                                                292126-28
```



```
; PROCEDURE lock_status_upload_to_BSR
; This procedure uploads status information into the ESR from non-volatile
; status bits.
; Param fields needed:
             params.lock_addr: offset of 28F016SA device
             BX: GSR in high byte and BSR in low byte
; Output:
             AX, CX, DX: trash
lock_status_upload_to_BSR proc
                                  near
      mov
             EDI, params.lock_addr
                                         ; Read ESR command.
      mov
             ES: [EDI],7171H
      GSROFF EDI
                                         ; Point EDI to GSR
q_unavailable1:
      mov
             AX, ES: [EDI]
                                         ; Read GSR
       test
             AX, 08H
       jnz
             short q_unavailable1
       ; Poll GSR while GSR.3 = 1, indicating queue unavailable.
      mov
              ES: [EDI], 9797H
                                         : Lock-status Upload command
      mov
             ES: [EDI], DODOH
                                         ; Confirmation command
             ES: [EDI],7171H
                                         : Read ESR command
      mov
WSM busy5:
                                     ; Read GSR
      mov
             AX, ES: [EDI]
       test
             AX,80H
       jz
              short WSM busy5
       ; Poll GSR while GSR.7 = 0, indicating WSM_busy
              AX, ES:[EDI]
                                         ; Read GSR
       mov
             BH, AL
                                         ; Store in high byte of BX
       mov
       BSRGSROFF
                    EDI
                                         ; Point EDI to BSR from GSR
       mov
             AX, ES: [EDI]
                                        : Read BSR
       mov
             BL, AL
                                        : Store BSR
       mov
              ES: [EDI], 5050H
                                        ; Clear Status Registers command
              ES:[EDI],FFFFH
                                        ; Reset device to read array mode
       mov
       ret
                                         ; Return to calling routine.
lock_status_upload_to_BSR endp
                                                                 292126-29
```

```
; PROCEDURE
            ESR word write
; This procedure writes a word to the 28F016SA.
; Param fields needed:
             params.write_base: offset of base of 28F016SA block to write
             params.data: data word to write
              params.write_addr: offset of 28F016SA address to write
              BX: GSR in high byte and BSR in low byte
 Output:
             AX, BX, CX, : trash
ESR word write proc
                    near
      push
             SI
      mov
             EDI, params.write_addr
                                          ; Set up offset of write address.
                                          ; Read Extended Status Registers
      mov
             ES:[EDI], 7171H
                                          ; command
      mov
              EBX, params.write base
                                          : Get base of block to write
       BSROFF EDI
      mov
              CX, params.word_count
      MOV
              SI, params.data
                                          ; params.data should be a pointer
                                          ; to an array of data to write to
                                          ; the flash array
q unavailable2:
      mov
              AX, ES: [EBX]
                                          ; Read BSR
       teat
              AX,08H
       ine
              short q_unavailable2
       ;Loop while BSR.3 of target address = 1, meaning queue full.
       mov
              ES:[EDI], 1010H
                                          ; Write Byte command
       movew
                                          ; write data and increment EDI,
                                          ; SI
                                          ; loop until CX = 0
       loop
              q unavailable2
                                          : Set up offset of block base
       mov
              EDI, params.write base
                                          ; in case we wrote to the end of
                                          ; the device, in which case EDI
                                          ; will now be 2 bytes past the
                                          ; device
              ES: [EDI],7171H
                                          ; Read ESR command
       mov
       BSROFF EDI
                                          ; Point EDI to BSR
block_busy:
       mov
              AX, ES: [EDI]
                                        ; Read BSR
       test
              AX,0080H
              short block busy
       ; Poll BSR while BSR.7 of target address is 0, meaning block busy
       mov
                                          ; Store BSR in BL
              BL, AL
                                          ; Point EDI to GSR from BSR
       GSRBSROFF
                     EDI
              BH, ES: [EDI]
                                          ; Read GSR and store in BH
       mov
              ES:[EDI],5050H
                                         ; Clear Status Registers command
       mov
              ES:[EDI], OFFFFH
                                         ; Reset device to read array mode
       mov
       pop
              SI
       ret
                                          ; Return to calling routine.
ESR_word_write endp
                                                                  292126-30
```





```
; PROCEDURE
             two_byte_write
; This routine is used when BYTE# is low, i.e. the 28F016SA
; is in byte mode, to emulate a word write.
; Param fields needed: (assume existence of byte fields data_high and
 data low)
              params.write_base: offset of base of 28F016SA block to write
              params.data_high: high data byte to write
              params.data_low: low data byte to write
              params.write_addr: offset of 28F016SA address to write
              BX: GSR in high byte and BSR in low byte
; Output:
              AX, CX, DX: trash
two_byte_write proc
                     near
       mov
              EDI, params.write_base
                                          ; Set up offset of address.
       mov
              ES: [EDI], 0071H
                                          ; Read ESR command
       BSROFF EDI
                                          ; Point EDI to BSR
       mov
              CX, params.word count
                                          ; use word count as byte count
q_unavailable3:
              AX, ES: [EDI]
       mov
                                           : Read BSR
       test
              AX, 08H
       inz
              short q_unavailable3
       ; Loop while BSR.3 of target address is 1, meaning queue full.
       mov
              ES:[EDI],00FBH
                                          ; Two-byte write command
       ; Write low byte of data word
       mov
              EDI, params.write_addr
                                           ; Set up offset of address.
       mov
              ES: [EDI], params.data_high
              ES: [EDI], params.data_low
       mov
; 28F016SA automatically loads alternate byte of data register and
; initiates write. Now we check for successful completion.
              ES: [EDI],7171H
                                           ; Read ESR command
       mov
       mov
              EDI, params.write_base
       BSROFF EDI
                                           ; Point EDI to BSR
block_busy2:
       mov
              AX, ES: [EDI]
                                           ; Read BSR
       test
              AX, 80H
              short block_busy2
       jz
       ; Poll BSR while BSR.7 of target address is 0, meaning block busy.
                                           ; Read BSR
       mov
              BH, ES: [EDI]
       GSRBSROFF
                     EDI
                                           ; Point EDI to GSR from BSR
       mov
              BL, ES: [EDI]
                                           ; Read and store GSR
       mov
              ES: [EDI],5050H
                                           ; Clear Status Registers command
       ret
                                           ; Return to calling routine.
two_byte_write endp
                                                                   292126-31
```



```
: PROCEDURE ESR pagebuffer write
 This procedure writes from page buffer to flash.
; Param fields needed:
              params.write_base: offset of base of 28F016SA block to write
              params.pagebuffer_word_count: number of words to write to flash
              params.write_addr: offset of 28F016SA address to write
 Output:
              BX: GSR in high byte and BSR in low byte of BX
              AX, CX, DX: trash
ESR_pagebuffer_write proc
                            near
      push
                                          ; Save old SI.
              ST
       mov
              SI, params.word count
                                          ; Use SI to count words.
; Address is where in 28F016SA flash array to begin write. The lowest
; byte of this must be identical to the start address in the page buffer.
; Low byte of byte_count must be 256 or fewer, high must be 0.
; High byte exists for future Page Buffer expandability.
                                          ; Offset of block base address.
       mov
              EDI, params.write_base
       mov
              ES: [EDI],7171H
                                          ; Read ESR command
       BSROFF EDI
q_unavailable4:
              AX, ES: [EDI]
       mov
                                          ; Read BSR
       test
              AX.8
       ine
              short q_unavailable4
       ; Loop while BSR.3 of target address is 1, meaning queue full.
              ES: [EDI], OCOCH
       mov
                                          ; Page Buffer Write command
       mov
              ES:[EDI],SI
                                          ; Write count
       ;Only A0 valid here; low or high byte loaded depending on A0.
              ES:[EDI], 0
       ; AO internally complemented; alternate byte loads; write starts.
       mov
              ES: [EDI],7171H
                                          : Read ESR command
block_busy3:
              AX, ES: [EDI]
                                          ; Read BSR
       mov
       test
              AX,80H
       jΖ
              short block_busy3
       ;Loop while BSR.7 of target address is 0, meaning block busy.
       mov
              BL, ES: [EDI]
                                          : Read BSR
       GSRBSROFF
                                          ; point EDI to GSR from BSR
                                          ; Read GSR
       mov
              BH.ES: [EDI]
                                          ; Clear Status Registers command
              ES: [EDI],5050H
       mov
                                          ; Reset device to read array mode
              ES:[EDI], OFFFFH
       mov
                                          ; Retrieve old SI.
       pop
              SI
       ret.
                                          ; Return to calling routine.
ESR_pagebuffer_write endp
                                                                   292126-32
```



```
; PROCEDURE
            ESR_block erase
; This procedure erases a block on the 28F016SA.
; Param fields needed:
             params.erase_addr: offset of base of 28F016SA block to erase
: Output:
             BX: GSR in high byte and BSR in low byte
             AX, DX: trash
ESR_block_erase
                    proc
                         near
      mov
             EDI, params.erase_addr
                                        ; Set up offset of address.
      mov
             ES:[EDI],7171H
                                        ; Read ESR command
      BSROFF EDI
                                         ; point EDI to BSR
q_unavailable5:
      mov
             AX, ES: [EDI]
                                       : Read BSR
      test
             AX,08H
             short qunavailable5
      ine
       ; Loop while BSR.3 of target address is 1, meaning queue full.
      mov
             ES: [EDI], 2020H
                                         ; Block Erase command
      mov
             ES: [EDI], DODOH
                                         : Confirm command
      mov
             ES: [EDI], DODOH
                                         ; Resume command, per latest
                                        ; errata update
             ES: [EDI],7171H
                                         ; Read ESR command
       ; Note that EDI still points to BSR
block_busy4:
      mov
             AX, ES: [EDI]
                                       ; Read BSR
       test
             AX,80H
       jz
             short block_busy4
       ;Loop while BSR.7 of target address = 0, i.e. block busy.
      mov
             BL, AL
                                         ; Store BSR in BL.
      GSRBSROFF
                    EDT
                                         ; point EDI to GSR from BSR
             BH, ES: [EDI]
      mov
                                        ; Read GSR, store in BH
      mov
             ES: [EDI], 5050H
                                        ; Clear Status Registers command
      mov
             ES:[EDI], OFFFFH
                                        ; Reset device to read array mode
                                        ; Return to calling routine.
       ret
ESR block erase
                    endp
                                                                292126-33
```



```
; PROCEDURE ESR_erase_all_unlocked_blocks
 This procedure erases all the unlocked blocks on a 28F016SA.
              params.erase_addr: offset of base of device to erase
              CX: GSR in both high byte and low byte
              BX: Failure list
              AX, DX: trash
ESR_erase_all_unlocked_blocks proc
                                 near
       push
                                          ; Save old SI.
              SI
       mov
              EDI, params.erase_addr
                                          ; erase_addr should be set to
                                          ; the device address
       mov
              ES:[EDI],7171H
                                          ; Read ESR command
       BSROFF EDI
                                          ; point EDI to BSR
q_unavailable6:
       mov
              AX, ES: [EDI]
                                          ; Read BSR
              AX,08H
       test
       jnz
              short qunavailable6
       ; Poll BSR while BSR.3 of target address is 1, meaning queue full.
              ES:[EDI],A7A7H
                                          ; Full-chip Erase command
       mov
                                          ; Confirm command
       mov
              ES:[EDI],DODOH
                                          ; Read ESR command
       mov
              ES: [EDI],7171H
       GSRBSROFF EDI
                                          ; Point EDI to GSR from BSR
WSM_busy6:
              AX, ES: [EDI]
                                          ; Read GSR
       mov
       test
              AX,80H
       Ηz
              short WSM busy6
       ;loop until GSR.7 indicates WSM is ready
       mov
              AX, ES: [EDI]
                                          ; Read GSR for operation success
       test
              AX, 20H
       jΖ
              short operation_successful
       ; If GSR.5 = 1, meaning that the operation was unsuccessful,
       ; go through blocks, looking for the ones which didn't erase.
              SI,SI
                                          ; Clear SI.
       XOT
                                          ; Clear EBX for failure list
              EBX, EBX
       XOT
       mov
              EDX, 1
                                          ; use EDX as mask to set failures
                                          ; start at the beginning of the
       mov
              EDI, params.erase_addr
                                          : device
              CX, 32
                                          ; 32 blocks in 28F016SA
       BSRGSROFF
                     EDI
                                          ; point EDI to BSR from GSR
look_for_bad_erase:
       ; Looking at each BSR.3 for operation success.
              AX, ES: [EDI]
                                          ; Read BSR
       mov
       test
              AX,08H
       İΖ
              short ok_erased
; record number of bad block here
              EBX, EDX
       or
ok erased:
       shl
              EDX
                                                                   292126-34
```



add EDI, 10000H

loop look\_for\_bad\_erase

; Increment EDI to next block

operation\_successful:

mov EDI, params.erase\_address

GSROFF EDI

mov BX, ES: [EDI]

mov ES: [EDI], 5050H mov ES: [EDI], 0FFFFH

pop

ret

ESR\_erase\_all\_unlocked\_blocks endp

; reset EDI to device address

; point EDI to GSR

; Clear Status Registers command

; Reset device to read array mode

; Return to calling routine.

292126-35



```
; PROCEDURE ESR_suspend_to_read_array
; This procedure suspends an erase on the 28F016SA.
; Param fields needed:
              params.erase_addr: offset of base of erasing 28F016SA block
              params.read addr: offset of 28F016SA address to read
              BX: GSR in high byte and BSR in low byte (of erase block)
              CX: data read from flash
              AX, DX: trash
ESR_suspend_to_read_array proc
                                   near
       mov
              EDI, params, erase addr
       BSROFF EDI
                                          ; point EDI to BSR
              ES: [EDI],7171H
       mov
                                          ; Read ESR command
block busy5:
              AX, ES: [EDI]
       mov
                                          ; Read BSR
       test
              AX.80H
              block_busy5
       jΖ
       ; Loop if BSR.7 of target address is 0, meaning block busy.
       MOV
              ES:[EDI], OBOBOH
                                          ; Operation Suspend command
       GSRBSROFF EDI
                                          ; Point EDI to GSR from BSR
WSM busy7:
       mov
              AX, ES: [EDI]
                                          ; Read GSR
       test
              AX,80H
       jΖ
              short WSM busy7
       ; Poll GSR until GSR.7 indicates WSM is ready.
       test
              AX,40H
       pushf
                                          ; store result for later
       mov
              EDI, params.read_addr
                                          ; Set up offset of read address.
       mov
              ES: [EDI], FFFFH
                                          ; Write Read Flash Array command
              CX, ES: [EDI]
                                          : Read the data
       mov
       mov
              EDI, params.erase_addr
                                          ; Set up offset of erase address.
       popf
       Ήz
              short nothing_suspended
       ; If GSR.6 indicates an operation was suspended on this device,
       ; then resume the operation.
              ES: [EDI], ODODOH
                                          ; Resume command
nothing suspended:
                                          : Store GSR in BH.
       mov
              BH, AH
                                          ; Move EDI down to read BSR.
       sub
              EDI, 2
              BL, ES: [EDI]
                                          ; Read BSR and store in BL
       mov
                                          ; Clear Status Registers command
       MOV
              ES:[EDI],5050H
                                          ; Reset device to read array mode
       mov
              ES: [EDI], OFFFFH
       ret
                                          ; Return to calling routine.
ESR_suspend_to_read_array endp
                                                                   292126-36
```



```
: PROCEDURE
             ESR_automatic_erase_suspend_to_write
 This procedure writes to one block while another is erasing.
 Param fields needed:
              params.data: data word to write to 28F016SA
              params.erase_addr: offset of 28F016SA address to erase
              params.write_addr: offset of 28F016SA address to write
; Output:
              BX: GSR in high byte and BSR in low byte
              AX, DX: trash
ESR_automatic_erase_suspend_to_write proc
                                          near
              EDI, params.erase_addr
                                         ; Set up offset of address.
      mov
              ES:[EDI],7171H
      MOV
                                          ; Read ESR command
      BSROFF EDI
                                          ; point EDI to BSR
q unavailable7:
      mov
              AX, ES: [EDI]
                                          : Read BSR
       test
              AX, 08H
      inz
              short q unavailable6
       ; Loop while BSR.3 of target address is 1, meaning queue full.
              ES: [EDI], 2020H
                                          ; Write Erase Block command
      mov
      mov
              ES: [EDI], DODOH
                                          ; Erase Confirm command
              EDI, params.write_addr
                                          ; Set up offset of address.
      mov
      mov
              ES: [EDI], 4040H
                                          ; Write Word command
                                          ; Write actual data
      mov
              ES: [EDI], params.data
; Erase will suspend, write will take place, then erase resumes.
      mov
              EDI, params.erase_addr
                                          ; Set up offset of address.
      mov
              ES:[EDI],7171H
                                          ; Read ESR command
       BSROFF EDI
                                          ; point EDI to BSR
block busy6:
       mov
              AX, ES: [EDI]
       test
              AX,80H
              short block_busy6
       jΖ
       ; Loop while BSR.7 of target address is 0, meaning block busy.
       mov
              BH, ES: [EDI]
                                          ; Read BSR
       GSRBSROFF EDI
       mov
              BL, ES: [EDI]
                                          ; Read and store GSR
       mov
              ES: [EDI], 5050H
                                          ; Clear Status Registers command
       mov
              ES: [EDI], OFFFFH
                                          ; Reset device to read array mode
                                          ; Return to calling routine.
ESR_automatic_erase_suspend_to_write endp
                                                                   292126-37
```



```
; PROCEDURE
            ESR_full_status_check_for_data_write
; This procedure performs a full status check of the Extended Status
; Register
; Param fields needed:
             params.write_base: offset of base of device
; Output:
             CX : errorcode
             AX, BX: trash
ESR_full_status_check_for_data_write_proc_near
      mov
             EDI, params.write_base
             ES: [EDI], 7171H
      mov
                                         : Read ESR command
      GSROFF EDI
                                         ; Point EDI to GSR
WSM busy8:
             AX, ES: [EDI]
                                         : Read GSR
      mov
       test
             AX,80H
       ήz
             short WSM_busy8
       ; Poll GSR while GSR.7 = 0, indicating WSM busy.
      BSRGSROFF
                                         : Point EDI to BSR from GSR
      mov
             AX.ES:[EDI]
             AX, 04H
      test
                                         ; BSR.2 = 1 indicates VPP_LOW
      İΖ
             vpp_high
      mov
             CX, VPP_LOW
       qmt
             cont
vpp_high:
       test
             AX, 10H
                                         : BSR.4 = 1 indicates operation
       jΖ
             op not aborted
                                         ; was aborted
      mov
             CX, OP_ABORTED
       gmt
             cont
op_not_aborted:
       get_pin WPB
                                        ; get_pin returns output in BX
       CMD
             BX, OOH
             wpb high
                                         ; no error if WPB is low
       je
       qmt
             no_error
wpb_high:
       test
             AX, 40H
                                         ; BSR.6 indicates BLOCK_LOCKED
       İΖ
             no_error
       mov
              CX, BLOCK LOCKED
       amir
              cont
no_error:
              CX, NO_ERROR
      mov
cont:
       GSRBSROFF
                    EDI
                                         ; Point EDI to GSR from BSR
WSM busy9:
      mov
             AX, ES: [EDI]
                                                                292126-38
```



test AX, 80H

jz WSM\_busy9

; Poll GSR while GSR.7 = 0, indicating WSM busy.

mov

ES:[EDI],5050H

; Clear Status Registers command

ret

ESR\_full\_status\_check\_for\_data\_write endp

292126-39



```
; PROCEDURE ESR full status check for erase
 This procedure performs a full status check of the Extended Status
; Register
; Param fields needed:
             params.write_base: offset of base of device
; Output:
             CX : errorcode
             AX, BX: trash
ESR_full_status_check_for_erase proc near
             CX, NO_ERROR
      mov
      mov
             EDI, params.write_base
      mov
             ES:[EDI], 7171H
                                         ; Read ESR command
      GSROFF EDI
                                         ; Point EDI to GSR
WSM_busy10:
      mov
             AX, ES: [EDI]
                                         : Read GSR
       test
             AX, 80H
             short WSM busv10
       ; Poll GSR while GSR.7 = 0, indicating WSM busy.
      BSRGSROFF
                    EDI
                                         ; Point EDI to BSR from GSR
      mov
             AX.ES:[EDI]
       test
             AX, 04H
                                         ; BSR.2 = 1 indicates VPP_LOW
      jz
             vpp_high
      MOV
             CX, VPP_LOW
       dmp
             cont
vpp high:
                                       ; BSR.4 = 1 indicates operation
       test
             AX, 10H
       İΖ
             op_not_aborted
                                         : was aborted
      mov
             CX, OP_ABORTED
       jmp
             cont
op_not_aborted:
      get_pin WPB
                                         ; get_pin returns output in BX
       CMD
             BX, 00H
       jne
             no error
                                         : BSR.6 and WPB LOW indicates
       test
             AX, 40H
                                         ; BLOCK_LOCKED
      jΖ
             no_error
      mov
             CX, BLOCK_LOCKED
       qmt
             cont
no_error:
             ES:[EDI], 7070H
      mov
                                         ; Read CSR command
      mov
             AX, ES: [EDI]
       test
             AX, 10H
                                         ; CSR.4 and CSR.5 indicate
       jΖ
             cont
                                         ; command sequence error
             AX, 20H
      test
       jz
             cont
      MOV
             CX, COMMAND_SEQ_ERROR
cont:
      mov
             ES: [EDI], 7171H
                                         : Read ESR command
                                                                292126-40
```



; EDI still points to GSR

WSM\_busy11:

mov AX, ES: [EDI]

; Read GSR

test AX,80H

jz short WSM\_busy11

; Poll GSR while GSR.7 = 0, indicating WSM busy.

mov

ES: [EDI], 5050H

; Clear Status Registers command

ret

ESR\_full\_status\_check\_for\_erase endp

292126-41



```
; PROCEDURE
            single_load_to_pagebuffer
 This procedure loads a single byte or word to a page buffer.
; Param fields needed:
             params.write_base: offset of base of device
             params.data: data to be written to page buffer
             params.pagebuffer_start_addr: byte giving pb location to write
             AX: trash
single_pagebuffer_load proc
                          near
             EDI, params.write_base
                                       ; Set up offset of base address.
      mov
             ES: [EDI],7171H
                                       ; Read ESR command
      mov
      GSROFF EDI
                                       ; point EDI to GSR
wait_for_pb:
      mov
             AX, ES: [EDI]
                                       ; Read GSR
      test
             AX,04H
      İΖ
             short wait_for_pb
      ; Poll GSR until GSR.2 indicates that a page buffer is available
             ES: [EDI],7474H
                                       ; Single PB Write command
      mov
      ; Actual write to page buffer.
             EDI,params.pagebuffer_start_addr
                                                    ; Set up offset of
                                                    : address.
             ES:[EDI], params.data
      ; BP+4 is location in pb to write.
      ret
                                       ; Return to calling routine.
single_load_to_pagebuffer endp
                                                              292126-42
```



```
; PROCEDURE
             sequential_load_to_pagebuffer
; This procedure loads the page buffer.
; Param fields needed:
              params.write_addr: offset of origin of device
              params.data_addr: pointer to data to be written to pg buffer
              params.pagebuffer_word_count: number of words to write to pg
buffer
              params.pagebuffer start addr: starting pb address of data to
write
: Output:
              AX, BX, DX: trash
sequential_load_to_pagebuffer proc near
       guh
              SP.2
                                          ; Set aside room for counter.
       mov
              byte ptr [BP-1],0
                                          ; Clear high byte of counter
                                          ; word.
       nush
                                          ; Save old SI.
       mov
              SI, word_count
                                          ; Put # of words to write in SI.
       ; SP+6 must be 128 or fewer, SP+7 must be 0.
       ; High byte exists for future Page Buffer expandability.
                                       ; Set up offset of device
              EDI, params.write_addr
                                          ; address.
              ES:[EDI],7171H
                                          : Read ESR command
       mov
       ; Commands to control entire 28F016SA do not need to be written to any
       ; particular address.
       GSROFF EDI
                                          : point EDI to GSR
wait_for_pb2:
       mov
              AX, ES: [EDI]
                                          ; Read GSR
       test
              AX.4
              short wait_for_pb2
       jΖ
       ; Poll GSR until GSR.2 indicates that a page buffer is available.
              ES: [EDI], EOEOH
       mov
                                          ; Sequential Page Buffer Load
                                           ; cmd.
       ; Loads high or low byte of count register, depending on AO.
              ES:[EDI],SI
       mov
                                          ; Write
       ; Automatically loads alternate byte of count register.
              ES: [EDI], SI
                                          ; Write
       ; Loop through data, writing to page buffer.
       mov
              byte ptr [BP-1],0
                                         ; Load counter.
              short compare
       qmt
not_done:
              DX, word ptr [BP-2]
                                          ; Put current val. of counter in
                                           ; DX.
              AL, params.pagebuffer_start_addr ; Get starting address in pb.
       mov
       chw
                                          ; Convert it to a word.
       add
              AX, DX
                                          ; Add to get abs. address in pb.
                                          ; Convert AX to a double word.
       CWd
       mov
                                          ; Store segment of pb address
              BP+12,DX
                                          ; (0).
              BP+10,AX
                                          ; Store offset of pb address.
       mov
              AX, word ptr [BP-2]
                                          ; Get current value of counter.
       mov
              EBX, params.data_addr
                                         ; Get address of where data is.
       MOV
       add
              EBX, AX
                                          ; Add value of counter to it.
```



| mov AX,word ptr [BP-2] ; Get current value of count cmp AX,SI ; Compare to final value.  jl short not_done  ; End of loop.  pop SI ; Retrieve old SI. mov SP,BP ; Retrieve old SP.                                                                             | mov                        | ES, word ptr [BX]     | ; Put data at that address on           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------------|-----------------------------------------|
| mov ES:[EDI],AX ; Write inc word ptr [BP-2] ; Increment counter.  compare:  mov AX,word ptr [BP-2] ; Get current value of count cmp AX,SI ; Compare to final value.  jl short not_done  ; End of loop.  pop SI ; Retrieve old SI. mov SP,BP ; Retrieve old SP. |                            |                       | ; stack.                                |
| inc word ptr [BP-2] ; Increment counter.  compare:  mov AX,word ptr [BP-2] ; Get current value of counter.  cmp AX,SI ; Compare to final value.  j1 short not_done  ; End of loop.  pop SI ; Retrieve old SI.  mov SP,BP ; Retrieve old SP.                    | mov                        | EDI,params.write_base | ; Set up offset of address.             |
| compare:  mov AX,word ptr [BP-2] ; Get current value of count cmp AX,SI ; Compare to final value.  jl short not_done  ; End of loop.  pop SI ; Retrieve old SI. mov SP,BP ; Retrieve old SP.                                                                   | mov                        | ES:[EDI],AX           | ; Write                                 |
| mov AX,word ptr [BP-2] ; Get current value of count cmp AX,SI ; Compare to final value.  jl short not_done  ; End of loop.  pop SI ; Retrieve old SI. mov SP,BP ; Retrieve old SP.                                                                             | inc                        | word ptr [BP-2]       | ; Increment counter.                    |
| cmp AX,SI ; Compare to final value.  jl short not_done  ; End of loop.  pop SI ; Retrieve old SI.  mov SP,BP ; Retrieve old SP.                                                                                                                                | compare:                   |                       |                                         |
| ; End of loop.  pop SI ; Retrieve old SI.  mov SP,BP ; Retrieve old SP.                                                                                                                                                                                        | mov                        | AX, word ptr [BP-2]   | ; Get current value of counter.         |
| <pre>j1 short not_done  ; End of loop.     pop SI</pre>                                                                                                                                                                                                        | cmp                        | AX,SI                 | ; Compare to final value.               |
| mov SP,BP ; Retrieve old SP.                                                                                                                                                                                                                                   |                            | short not done        | • • • • • • • • • • • • • • • • • • • • |
| mov SP,BP ; Retrieve old SP.                                                                                                                                                                                                                                   | 31                         | profe not dolle       |                                         |
| , neer leve of a pri                                                                                                                                                                                                                                           | _                          | _                     |                                         |
| ret : Return to calling routine                                                                                                                                                                                                                                | ; End of loc               | op.                   | ; Retrieve old SI.                      |
|                                                                                                                                                                                                                                                                | ; End of loc               | op.                   |                                         |
| sequential_load_to_pagebuffer endp                                                                                                                                                                                                                             | ; End of loc<br>pop<br>mov | op.                   |                                         |

3



```
; PROCEDURE
             upload device information
; This procedure uploads the device revision code into the page buffer.
; Param fields needed:
             params.write_base: offset of 28F016SA device
: Output:
             DX: Device revision number
             AX, CX: trash
upload_device_information proc near
      mov
             EDI, params.write_base
                                        ; Read ESR command.
      MOV
             ES:[EDI],7171H
      inc
             EDI
                                         ; Move EDI up to GSR.
      inc
             EDI
q_unavailable8:
      mov
             AX, ES: [EDI]
                                         ; Read GSR
       test
             AX,8
       jne
              short q unavailable8
       ; Poll GSR while GSR.3 = 1, indicating queue unavailable.
WSM_busy12:
      mov
              AX, ES: [EDI]
                                         : Read GSR
       test
              AX, 80H
              short WSM_busy12
       jе
       ; Poll GSR while GSR.7 = 0, indicating WSM busy.
      mov
              ES: [EDI],9999H
                                         ; Lock-status Upload command /
      mov
              ES: [EDI], DODOH
                                         ; Confirmation command
      mov
              ES: [EDI],7171H
                                         ; Read ESR command
WSM_busy13:
      mov
              AX, ES: [EDI]
                                         ; Read GSR
       test
              AX, 80H
       jΖ
              short WSM_busy13
       ; Poll GSR while GSR.7 = 0, indicating WSM_busy
              ES:[EDI],7272H
                                         ; Swap Page Buffer command
      mov
      mov
              ES: [EDI],7575H
                                         ; Read Page Buffer command
       mov
              DX, [params.write_base+3]
                                         ; Put revision number in DX
       ; Revision number is 3 words above write base in page buffer space.
       ; GSR.5 should be checked for operation success before using revision
       ; number.
       ret
                                         ; Return to calling routine.
upload_device_information endp
                                                                 292126-45
```



```
; PROCEDURE
             RYBY_reconfiguration
; This procedure reconfigures the RY/BY# output mode
; Param fields needed:
             params.write_base: offset of 28F016SA device
             params.data: reconfiguration define
; Output:
             AX : GSR
RYBY_reconfiguration proc
                           near
             EDI, params.write_base
      mov
      mov
             ES:[EDI], 7171H
                                         ; Read ESR command
      GSROFF EDI
                                         ; Point EDI to GSR
g_unavailable9:
      mov
             AX, ES: [EDI]
                                         ; Read GSR
             AX, 8
       test
                                         ; test bit 3
       ine
             short q_unavailable9
      mov
             ES: [EDI], 9696H
                                         ; RY/BY# reconfiguration code
       CMD
             params.data, 01
       jne
             switch1
      mov
             ES:[EDI], 0101H
                                         ; Enable RY/BY# to level mode
       qmt
             break
switch1:
             params.data, 02
       CMD
       ine
             switch2
      mov
             ES:[EDI], 0202H
                                         ; Enable RY/BY# to pulse on write
       qmį
             break
switch2:
       cmp
             params.data, 03
             default.
       ine
      mov
             ES:[EDI], 0303H
                                         ; Enable RY/BY# to pulse on erase
       qmt
             break
default:
      mov
             ES:[EDI], 0404H
                                         : Enable RY/BY# to disable
break:
      mov
             ES:[EDI], 7171H
                                         ; Read ESR command
WSM_busy14:
     . mov
             AX, ES: [EDI]
                                         ; Read GSR (EDI already points to
      test
             AX, 80H
                                         ; GSR)
       jz
             short WSM busy14
      mov
             ES: [EDI],5050H
                                         ; Clear Status Registers command
      mov
             ES: [EDI], OFFFFH
                                         ; Reset device to read array mode
RYBY_reconfiguration endp
                                                                 292126-46
```



292126-47

```
; PROCEDURE
            page_buffer_swap
; This procedure swaps the page buffers.
; Param fields needed:
            params.write_base: offset of 28F016SA device
; Output:
            AX : GSR before operation in high byte, GSR in low
                byte after operation
page_buffer swap proc near
      mov
            EDI, params.write_base
      mov
            ES:[EDI], 7171H
                                     ; Read ESR command
      GSROFF EDI
                                     ; Point EDI to GSR
      mov
            AH, ES: [EDI]
                                     ; Read GSR and store in AH
      mov
            ES:[EDI], 7272H
                                     ; Page Buffer Swap command
      mov
            AL, ES: [EDI]
                                     ; Read GSR and store in AL
      mov
            ES:[EDI],5050H
                                     ; Clear Status Registers command
      mov
            ES:[EDI],OFFFFH
                                     ; Reset device to read array mode
page_buffer_swap endp
TEXT
      ends
```



## APPENDIX A FUNCTION CHANGES

| OLD FUNCTION NAME             | NEW FUNCTION NAME                    |
|-------------------------------|--------------------------------------|
| compatible_block_erase        | CSR_block_erase                      |
| compatible_suspend_to_read    | CSR_erase_suspend_to_read            |
| compatible_byte_write         | CSR_word_byte_writes                 |
| ESR_block_erase               | N/C                                  |
| ESR_status_check_after_erase* | ESR_full_status_check_for_erase      |
| ESR_status_check_after_write* | ESR_full_status_check_for_data_write |
| ESR_suspend_to_read           | ESR_suspend_to_read_array            |
| ESR_word_write                | N/C                                  |
| eraseallunlockedblocks        | ESR_erase_all_unlocked_blocks        |
| lock_block                    | N/C                                  |
| status_upload                 | lock_status_upload_to_BSR            |
| pagebuffer_write_to_flash     | ESR_pagebuffer_write                 |
| sequential_pagebuffer_load    | sequential_load_to_pagebuffer        |
| single_pagebuffer_load        | single_load_to_pagebuffer            |
| twobytewrite                  | N/C                                  |
| write_during_erase            | ESR_automatic_erase_suspend_to_write |

NOTE: \*code added in Rev 2.0.



## APPENDIX B Glossary of Terms

BSR:

Block Status Register. Each BSR reflects the status of its 64KB block.

CSR:

Compatible Status Register. The CSR reflects the status of the entire device and is identical in format

to the Status Register of the 28F008SA.

EDI:

Extended Data Index register on 80386 and higher CPUs.

ESR:

Extended Status Registers. The GSR and BSRs.

GSR:

Global Status Register. The GSR provides additional information about entire device status.

RY/BY#:

Output pin from the 28F016SA indicating status of current operation.

 $\mathbf{V_{pp:}}$ 

Voltage necessary to program the 28F016SA (12V).

WSM:

Write State Machine. On-board processor automating write, erase and other functions.



#### **APPENDIX C**

#### **ADDITIONAL INFORMATION**

| Order Number | Document                                                               |
|--------------|------------------------------------------------------------------------|
| 290489       | 28F016SA Datasheet                                                     |
| 292124       | AP-375 Upgrade Considerations from the 28F008SA to the 28F016SA        |
| 297372       | 28F016SA User's Manual                                                 |
| 292127       | AP-378 System Optimization Using the Enhanced Features of the 28F016SA |
| 294016       | ER-33 Flash Memory Technology ETOX IV                                  |
| 290528       | 28F016SV Datasheet                                                     |
| 292144       | AP-393 28F016SV Compatibility with 28F016SA                            |

#### **REVISION HISTORY**

| Number | Description                                                       |  |  |
|--------|-------------------------------------------------------------------|--|--|
| 001    | Original Version                                                  |  |  |
| 002    | Updated Version of C and ASM code, compatible with 28F016SV/XS/XD |  |  |

**AP-378** 



## APPLICATION NOTE

## System Optimization Using the Enhanced Features of the 28F016SA

SALIM FEDEL

PATRICK KILLELEA
FLASH APPLICATIONS ENGINEERING

June 1994

## System Optimization Using the Enhanced Features of the 28F016SA

| <b>CONTENTS</b> PAGE                        | C  |
|---------------------------------------------|----|
| <b>1.0 INTRODUCTION</b>                     | 6  |
| Features 3-724                              |    |
| 1.2 Glossary of Terms 3-725                 |    |
| 2.0 INNOVATIVE ARCHITECTURAL ENHANCEMENTS   |    |
| <b>3.0 ENHANCED WRITE</b>                   |    |
| 3.1 Page Buffer Writes to Flash 3-727       | -, |
| 3.2 Command Queuing 3-729                   | 7  |
| 3.3 Command Prioritization 3-729            |    |
| 3.4 Extended Status Registers 3-730         |    |
| 3.5 Automatic Erase Suspend to Write 3-730  |    |
| 3.6 Block Validity and Data Integrity 3-730 | 8  |
| 3.7 Erase All Unlocked Blocks 3-730         |    |
| 4.0 LOW POWER CONSUMPTION 3-731             | L  |
| 4.1 3.3V Operation 3-731                    | A  |
| 4.2 Page Buffer Write Operation 3-731       | A  |
| 4.3 Automatic Power Savings 3-731           | Δ  |
| 4.4 Deep Power-Down Mode 3-732              |    |
| 4.5 Sleep                                   |    |
| 4.6 Standby 3-732                           |    |
| 5.0 DENSITY IMPROVEMENT/SPACE               |    |

| CONTENTS                                          | PAGE  |
|---------------------------------------------------|-------|
| 6.0 FLEXIBLE SYSTEM INTERFACE                     | 3-733 |
| 6.1 Dual Chip Enables                             | 3-733 |
| 6.2 Dual 3.5V/5.0V Operation                      | 3-733 |
| 6.3 User-Selectable x16/x8 Bus Width              | 3-735 |
| 6.4 Open Drain RY/BY#                             | 3-735 |
| 6.5 RY/BY# Configuration Modes (Level and Pulsed) | 3-737 |
| 7.0 CODE AND DATA PROTECTION                      | 3-738 |
| 7.1 Selective Block Locking                       | 3-738 |
| 7.2 Master Write Protect                          | 3-738 |
| 7.3 Software Partitioning                         | 3-738 |
| 7.4 Reset Capability                              | 3-739 |
| 8.0 SUMMARY                                       | 3-739 |
| LIST OF APPENDICES                                | 3-739 |
| APPENDIX A COMMAND LISTINGS                       | 3-740 |
| APPENDIX B REFERENCES                             | 3-741 |
| APPENDIX C REVISION HISTORY                       | 3-742 |
|                                                   |       |



#### 1.0 INTRODUCTION

#### 1.1 Overview of Enhanced Features

The Intel family of flash memory components has a new member: the 28F016SA 16-Mbit FlashFile<sup>TM</sup> memory. The 28F016SA provides superior write performance and ultra high density, malting possible faster, smaller form-factor flash memory sub-systems than ever before. Flash memory cards and flash drives will reach higher levels of performance with the 28F016SA, while new applications will arise to take advantage

of special 28F016SA features, such as low power operation, data security, and flexibility of use.

This application note describes in detail the new features of the 28F016SA and the benefits of these features to the system designer and system end-user. Readers wishing technical specifications are referred to the 28F016SA data sheet; readers wishing usage guidelines are referred to the 28F016SA User's Manual.

The following table summarizes the enhanced features and advantages of the 28F016SA:

**Table 1. Feature vs Value Summary** 

| Feature of 28F016SA                                                      | Advantage to System Designer                                                                                                                                                           | Advantage to End-User                                                                                             |
|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| Faster Writes, Approaching Hard Disk Write Performance                   | Wider Range of Applications     Faster Installation of Embedded Code     Quicker Code Update in the Field over a     Modem Line                                                        | <ul> <li>Faster Write to Flash Cards,<br/>Flash Drives</li> <li>Faster Formatting of Cards,<br/>Drives</li> </ul> |
| Higher Density,<br>Enabling High<br>Capacity Solid State<br>Mass Storage | New Products Possible     Increased Data Acquisition Capacity     Higher Capacity Cards, Drives, Resident Flash Array (RFA)     Fewer Parts = Better Manufacturability and Reliability | Smaller Systems, Lower Weight, Lower Power Consumption     More Room for User Data on Flash Cards and RFAs        |
| Low Power<br>Consumption                                                 | Optimized System Poer Budget                                                                                                                                                           | <ul><li>Longer Battery Life</li><li>Smaller Batteries</li><li>Less Weight</li></ul>                               |
| Code/Data Protection                                                     | Opportunity to Ship Device Drivers and<br>Application Code Bundled with Cards,<br>RFAs and Embedded Systems                                                                            | User is Safe From Accidential     Modification or OS or     Application Code     Data File Security               |
| Flexible System<br>Interface                                             | More Compact Systems     Optimal Bus Loading     More Detailed Status Information                                                                                                      | 28F016SA—Based Cards Can<br>Be Used to Transfer Data<br>between 3.3V Portable and<br>5.0V Desktop PCs             |



#### 1.2 Glossary of Terms

APS: Automatic Power Savings feature of 28F016SA.

CSR: Compatible Status Register. The CSR reflects the status of the entire device and is identical in format to the Status Register of the 28F008SA.

ESR: Extended Status Registers. The GSR and BSRs.

GSR: Global Storage Register. The GSR provides additional information about entire device status.

BSR: Block Status Register. Each BSR reflects the status of its 64 KB block.

 $CE_0\#$ : Chip Enable 0.  $CE_0\#$  and  $CE_1\#$  both need to be asserted to activate the 28F016SA.

CUI: Command User Interface. Interface between the microprocessor and the internal memory operation.

FFS: FlashFile System. Software providing file structure and maintenance for mass storage with flash.

OE#: Output Enable pin.

RFA: Resident Flash Array. Array of flash components permanently resident on a motherboard.

RFX: Resident Flash XIP.

RFD: Resident Flash Disk.

RP#: Reset Power-Down pin. Master enable switch for the 28F016SA. Formerly called PWD# on 28F008SA.

RY/BY#: Configurable Ready/Busy pin, giving status of pending operations.

WE#: Write Enable pin.

WP#: Write Protect pin. Can be used to override block lock status bit in BSRs.

WSM: Write State Machine. On-board "processor" automating Write, Erase, Lock and other functions.

XIP: Execute in Place.

## 2.0 INNOVATIVE ARCHITECTURAL ENHANCEMENTS

While the 28F016SA is compatible with the 28F008SA, the 28F016SA includes hardware enhancements which provide the basis for the features described in the following sections of this document.

The hardware enhancements include:

- An improved Command User interface
- Two Page Buffers
- Queue Registers
- Extended Status Registers
- Several new pins, implementing new functions.

The Command User interface (CUI) of the 28F016SA understands 17 new commands which simplify usage or provide access to entirely new functions. The CUI is, however, still accessed in the same manner as with the 28F008SA and all of the 28F008SA commands are valid for the 28F016SA.

Two page buffers of 256-bytes each greatly increase the effective write speed. The page buffers are written at SRAM speeds. Writes from full page buffers to the flash array can be initiated with a single command and will complete independently, freeing the CPU for other tasks.

The Queue Registers can accept up to two (2) additional commands while the current command is executing. This allows a short sequence of commands to be issued quickly, regardless of whether the internal Write State Machine (WSM) is actually ready to process a command. The WSM will automatically fetch the next command from the queue when it is ready.

The Extended Status Registers provide more detailed information about the state of the 28F016SA, such as the state of the queue and which page buffer is selected. A Global Status Register and a set of thirty-two (32) Block Status Registers give the system designer the ability to use each 64-Kbyte block as an independent memory.







Figure 1. 28F016SA Block Diagram



#### 3.0 ENHANCED WRITE

The write performance of the 28F016SA is far superior to that of previous flash components. For a direct write to flash, the 28F016SA has a 6  $\mu$ s average word write time, a 33% improvement over the 28F008SA. Much more significant, however are the on-board page buffers and Auto Erase Suspend capability, which boost write performance much more by reducing system overhead.

#### 3.1 Page Buffer Writes to Flash

The 28F016SA incorporates two page buffers of 256bytes each. The page buffers can be wrirten with SRAM-like timings and will program the flash array without any CPU overhead, providing greatly increased write efficiencies for both short and long writes. For example, the 28F008SA writes a byte typically in 9.2  $\mu$ s/byte, giving a device pair an effective byte write speed of 4.6  $\mu$ s since 9.2  $\mu$ s per byte/2 devices = 4.6  $\mu$ s per byte/device.

The 28F016SA, however, can write a *word* typically in 3.8  $\mu$ s from page buffer to flash memory, giving a device pair an effective byte write speed of 0.95  $\mu$ s since 3.8  $\mu$ s per word/2 devices = 1.9  $\mu$ s per word/device = 0.95  $\mu$ s per byte/device.

This feature improves system write performance by up to 4.8 times over previous flash memory devices. When interfacing four (4) 16-Mbit devices in parallel in a 32-bit system, the sustained write speed approaches 2 MBytes/sec.



Figure 2. Page Buffer Increases Write Performance



For relatively short writes (less than 512 bytes), the CPU is free after the page buffers are loaded and the command to write to flash is issued. The 28F016SA will take care of completing the Page Buffer Write to Flash Operation. This limited form of parallel processing allows the host system to treat flash almost exactly as it would treat SRAM for short writes. For writes of less than four (4) bytes, however, it is not efficient to use the page buffers because the queue can hold three (3) simple Write commands.

For writes of more than 512 bytes, the two page buffers can be used to even greater advantage. The system can fill one buffer, issue the Write command, and then immediately begin to fill the other buffer, continuing to alternate in this way until the entire write is complete. This sort of large block writing, known as "interleaved

page mode write", is efficient because the overhead needed to set up a write from the buffers to flash is incurred only once. Also note that the write from the buffers to flash is itself faster than a write directly from the system to the flash array.

The load on the CPU is also dramatically reduced using page mode writes. While a write without the page buffer requires one setup command for every byte or word written, only 6 commands total need to be issued to set up the write of 256 bytes to a page buffer and from the page buffer to flash. While the actual write speed to the flash array is approximately 35% faster from the page buffer, there is also the benefit of huge reduction in processor overhead, with page buffer writes more than 40 times (256 commands vs. 6 commands) less of a burden on the CPU.



Figure 3. Interleaved Page Mode Write



#### 3.2 Command Queuing

While the 28F008SA requires an operation to complete before the next operation could be requested, the 28F016SA allows queuing of up to two (2) additional operations while the memory executes the current operation. As a general rule, the 28F016SA has a 3-deep command queue. This eliminates system overhead when writing several bytes in a row to the array or erasing several blocks at the same time. A subset of the command-set can be queued, while the rest of the commands are executed immediately.

There is, however, an exception to the 3-deep command queue rule, which has to do with multiple Block Erase commands. if Single Block Erase commands are the only queued operations, the queue then becomes virtually 32-commands deep. This allows the user to stack many Block Erase operations very fast before a Single Block Erase operation completes. Consult the 28F016SA User's Manual.

#### 3.3 Command Prioritization

Within the 28F016SA command queue, Write commands have higher priority than Erase commands and are executed by the WSM first, regardless of the command order. This feature helps insure that valuable data can be captured as it arrives in real time. The 28F016SA will not, however, put a write to a block ahead of an erase to the same block.

In addition, the 28F016SA prioritizes multiple Block Erase commands when queued in conjunction with Write commands. The CUI decodes the Write commands and if those commands affect a block which is in the queue for erasing, it will prioritize the Block Erase ahead of other Block Erase operations. This method allows a complete block modification to occur as fast as possible.



**Figure 4. Command Prioritization** 



#### 3.4 Extended Status Registers

The 28F016SA includes a Compatible Status Register (CSR) which is identical to the status register on the 28F008SA, a Global Status Register (GSR), which reflects the overall device status, and 32 Block Status Registers (BSRs), which are similar to the GSR except that they contain information specific to their corresponding blocks, i.e., each block has its own BSR. The value of the BSR is that it allows each block to operate essentially as an independent memory device.

Since the CPU does not have to control and monitor the details of writing a word/byte and erasing a block, it is free to perform higher priority tasks.

## 3.5 Automatic Erase Suspend to Write

Write performance is also enhanced by an erase suspend mode which is automatically invoked when a Write command to a block is issued during the erase of a different block. Since the erase of a block typically takes 600 ms to complete, suspending an erase to write to a different block can dramatically increase write performance.

Automatic Erase Suspend to Write is important to Microsoft's FlashFiling System (FFS) for flash memory cards. FFS needs to perform occasional background erases to maintain efficiency. These erases are much less noticeable when they can be suspended whenever the user desires access to the flash card.

#### 3.6 Block Validity and Data Integrity

If a particular block becomes corrupted because of an interrupted Erase operation, due to an Abort command, RP# reset action or the power supply turning off, both the Block Operation Status (BOS) and Device Operations Status (DOS) bits will be set to "1", indicating an invalid Block. This combination of status bit setting can be detected when normal operating conditions are restored and after issuing a Status Upload command, which updates certain status bits in the GSR and BSRs. If this condition occurs (BOS = DOS = 1), the user must re-issue a Block Erase command and insure successful erasure of the block by checking the appropriate GSR and BSR bits.

#### 3.7 Erase All Unlocked Blocks

All 32 blocks of the 28F016SA can be erased using a single command, the Erase All Unlocked Blocks command. When this command and the Confirm command are issued, then all of the unlocked blocks will be erased in sequence. Locked blocks will be skipped and no error code will be returned. The BSR Block Operation Status bit can then be checked for each block to determine which block failed to properly erase and the user can re-issue single Erase commands to those particular blocks. This method improves overall system write performance in large flash memory configurations when extensive data cleanup or card formatting are required.



Figure 5. Automatic Erase Suspend to Write



#### 4.0 LOW POWER CONSUMPTION

#### 4.1 3.3V Operation

For Read operations, the 28F016SA uses about 50% less energy in the 3.3V configuration than in the 5.0V configuration, making the 28F016SA an ideal choice

for mobile computing applications as well as some power-sensitive embedded applications which use the device for infrequently updatable code storage.

For Write/Erase operations such as in Resident Flash Disk applications, the 28F016SA in 3.3V mode saves 20%/40% energy respectively, versus the 5.0V mode. See Table 2 for detailed calculations.

Table 2. 28F016SA Typical\* Power Consumption and Energy Comparison

| 3.3V Operation f = 4 MHz | I <sub>CC</sub> (mA) | I <sub>PP</sub> (mA) | Power (mW)<br>I <sub>CC</sub> x 3.3V + I <sub>PP</sub> x V <sub>PP</sub> | Energy (m.W.sec)<br>Power x Time |
|--------------------------|----------------------|----------------------|--------------------------------------------------------------------------|----------------------------------|
| Read Current             | 15                   | 65 μΑ                | 49.7                                                                     | 0.41 mW. sec/Block               |
| Write Current            | 8                    | 10                   | 146.4                                                                    | 32.38 mW. sec/Block              |
| Erase Current            | 6                    | 4                    | 67.8                                                                     | 54.24 mW. sec/Block              |

| 5.0V Operation<br>f = 10 MHz | I <sub>CC</sub> (mA) | I <sub>PP</sub> (mA) | Power (mW) I <sub>CC</sub> x 5.0V + I <sub>PP</sub> x V <sub>PP</sub> | Energy (m.W.sec)<br>Power x Time |
|------------------------------|----------------------|----------------------|-----------------------------------------------------------------------|----------------------------------|
| Read Current                 | 50                   | 65 μΑ                | 250                                                                   | 0.82 mW. sec/Block               |
| Write Current                | 25                   | 7                    | 209                                                                   | 41.09 mW. sec/Block              |
| Erase Current                | 18                   | 5                    | 150                                                                   | 90 mW. sec/Block                 |

<sup>\*</sup>These numbers are based on preliminary characterization data.

Block Size = 64 KB = 32 KW

Table 3, 3,3V to 12,0V Converter

| Manufacturer      | Part<br>Number | Input (V)   | Current<br>Output | Total<br>Components<br>Needed | Est. Cost* |
|-------------------|----------------|-------------|-------------------|-------------------------------|------------|
| Maxim             | MAX732         | 1.8 to 5.0  | 30 mA             | 13                            | \$4.80     |
| Linear Technology | 1109CS8-12     | 2.5 to 11.0 | 30 mA             | 5                             | \$4.00     |

<sup>\*</sup>These cost estimates are based on published pricing at the time this Application Note was written.

#### NOTE:

This list is intended for example only, and in no way represents all companies that produce 12.0V conversion solutions. Since this industry develops many new solutions each year, Intel recommends that the designer contact the vendors for their latest products. Intel will continue to work with vendors to develop optimum solutions. Intel Corporation assumes no responsibility for circuitry others than circuitry embodied in Intel products.

At present, there are at least two manufacturers of 3.3V to 12.0V converters. Their solutions are described in Table 3. These solutions are given only for reference and may not be suitable for use in every system. Readers wishing additional information on DC to DC converters are referred to Intel's AP-357, "Power Supply Solutions for Flash Memory".

#### 4.2 Page Buffer Write Operation

In addition to providing dramatically faster writes, the page buffers also save power. While the actual power saved depends on the size of the write from the page buffer, savings are typically 35% of the energy it takes to write without the page buffer, since page buffer writes are intrinsically about 35% faster while current consumption is the same.

#### 4.3 Automatic Power Savings

Automatic Power Savings (APS) is a low power feature valid during active mode of operation. The 28F016SA incorporates "Power Reduction Control" circuitry which allows the device to put itself into a low current state when addresses are not switching (in other words, accessing the same memory location). After data is read

Typical word write speeds: 6 µs (5.0V); 6.75 µs (3.3V)

Typical block erase speeds: 600 ms (5.0V); 800 ms (3.3V)



from the memory array, the Power Reduction Control logic controls the device's power consumption by entering APS mode, where the typical  $I_{CC}$  current is 1 mA at 5.0V and 0.8 mA at 3.3V. CPUs with a slowed clock can take advantage of this feature which is entirely automatic and transparent to the user.

#### 4.4 Deep Power-Down Mode

The deep power-down mode is activated by the RP# pin transitioning low, which turns off all device circuitry. The only current consumed is diffusion leakage, transistor sub-threshold conduction, input leakage, and output leakage, totaling 1  $\mu$ A. However, all register contents are lost and the current operation terminates upon entering deep power-down mode.

The deep power-down feature, along with the sleep command (following section), gives the 28F016SA the ability to increase power savings dramatically by taking advantage of the fact that any one flash device is accessed only occasionally. When the device is not in use, it can be turned off so that scarce battery power is consumed only as needed. These power-saving functions can be implemented in ways entirely transparent to the end-user. The only change the user will notice is that batteries last much longer with a 28F016SA-based system.

#### 4.5 Sleep

The Sleep command is new with the 28F016SA. Unlike deep power-down mode, during sleep mode, the status registers, page buffers, and signature ID codes can still be read. Once in sleep mode and with applied CMOS input levels, the power of the device is reduced to deep power-down current levels. The Sleep command allows the device to complete any current or pending commands before going into sleep mode. The Device Sleep Status (DSS) bit in the GSR will indicate that the device is in sleep mode. Writing the Read Array command wakes up the device out of sleep mode.

#### 4.6 Standby

With  $CE_0\#$  or  $CE_1\#$  high, the memory will be in standby mode. This mode turns off much of the device's circuitry and reduces device power consumption. The outputs are in a high-impedance state independent

of the state of OE# pin. If the WSM is executing a command when the device is disabled, the operation is allowed to continue. During this time the power consumption remains at the non-standby level until the operation completes. The output buffers and most of the input buffers on the chip are disabled during standby mode.

## 5.0 DENSITY IMPROVEMENT/SPACE SAVINGS

The 28F016SA is twice as dense as the 28F008SA, allowing smaller systems, lower weight, and lower power consumption than ever before—crucial selling points in the highly competitive mobile PC market. Flash densities are now on a par with DRAM densities, an important step toward the use of flash as non-volatile executable memory (Resident Flash Array), which provides "instant on" boot capability and instant access to applications and data stored in flash. RFAs also reduce the amount of necessary system DRAM.

In the removable storage market, the density of the 28F016SA will make conversion to flash the most attractive option when considered along with the properties which set flash apart from other storage media, such as non-volatility, low power consumption, and ruggedness. Flash-based data and code storage media such as PCMCIA memory cards are already on the shelf, along with PCMCIA-ATA flash drives. PCMCIA cards in particular will open new distribution channels for software since cards based on the 28F016SA now have sufficient capacity for most large commercial programs. While cost/megabyte is not yet competitive with magnetic media, the XIP or "eXecute In Place" ability of flash cards provides software distributors and end-users with a compelling reason to consider flash cards.

The density of the 28F016SA is also driving entirely new applications, such as solid-state digital photography and audio recording, which require memory capacities which were not previously economical in flash.

The point to remember is that two (2) megabytes of 70 ns randomly accessible code or data can now be stored in a rewritable nonvolatile medium of less than three (3) square centimeters—a 30% improvement over the 28F008SA.





Figure 6. 28F016SA vs 28F008SA Area Comparison

#### 6.0 FLEXIBLE SYSTEM INTERFACE

#### 6.1 Dual Chip Enables

The 28F016SA implements a dual chip-enable function with two input pins,  $CE_0\#$  and  $CE_1\#$ , which together have exactly the same functionality as the regular chipenable pin on the 28F008SA. The 28F016SA uses the logical combination of these two signals to enable or disable the entire chip. Both  $CE_0\#$  and  $CE_1\#$  must be active to enable the device. If either one becomes inactive, the chip will be disabled. This feature allows the system designer to reduce the number of decoding pins used in a large array of 16-Mbit devices. For square arrays, it can be seen that the number of lines needed to control nXn chips is 2 times n. For example, in a square array of sixteen 28F016SAs, only 8 lines are needed instead of 16 (see Figure 7). For larger memory arrays, the reduction in decoding signals increases significantly.

#### 6.2 **Dual 3.3V/5.0V Operation**

The portable PC market demands that components be able to operate at 3.3V. On the other hand, most desktop systems operate at 5.0V. The 28F016SA resolves this conflict with a dual operating voltage capability. A 3/5# input pin makes it possible to use the 28F016SA in both 3.3V and 5.0V systems interchangeably. The 3/5# signal pin from the system informs the device about the supply voltage being used. This information is used by the 28F016SA to optimize itself for the input supply voltage. Data written using one supply voltage will always be valid using the other supply voltage. A 28F016SA-based flash memory card is thus able to transfer data from a 3.3V notebook or handheld PC to a 5.0V desktop PC as is illustrated by Figure 8.





Figure 7. Dual Chip Selects in a Bank Configuration





Figure 8. Dual Voltage Operation Allows Inter-Operability

#### 6.3 User-Selectable x16/x8 Bus Width

While the 28F008SA's interface to the system bus is strictly x8, the 28F016SA's BYTE# pin allows either a x8 or x16 bus interface. The system designer now has a choice between three (3) different configurations in both 16-Bit and 32-Bit systems, allowing optimization of the effective block granularity, the space required, and the minimum memory configuration. See Table 4 for details.

Note that the smallest block granularity is obtained with the 28F016SA in 16-bit mode in a xl6 system.

The most efficient and smallest memory configuration is obtained with the 28F016SA in xl6 mode in a 32-bit system.

#### 6.4 Open Drain RY/BY#

The RY/BY# pin is an open drain output pin to allow the designer to Wire-OR multiple RY/BY# pins in a large memory array, saving on the number of control pins which are dedicated to this function.



**Table 4. Configuration Options** 

| System<br>Bandwidth | Parameter             | 28F008SA (x8 only) | 28F016SA, x8       | 28F016SA, x16     |
|---------------------|-----------------------|--------------------|--------------------|-------------------|
| 16-Bit              | Effective Block size  | 128 KB             | 128 KB             | 64 KB             |
| System              | Minimum Configuration | Two Devices: 2 MB  | Two Devices: 4 MB  | One Device: 2 MB  |
| 32-Bit              | Effective Block Size  | 256 KB             | 256 KB             | 128 KB            |
| System              | Minimum Configuration | Four Devices: 4 MB | Four Devices: 8 MB | Two Devices: 4 MB |



Figure 9. Open Drain RY/BY#





Figure 10. Pulsed Mode RY/BY#

## 6.5 RY/BY # Configuration Modes (Level and Pulsed)

While the Level-Mode operation of the Ready/Busy indicator pin continuously reflects the device readiness, this type of signal will actually hinder the performance of an array of 28F016SAs if the array itself has only one ready/busy output line. This is because the array output will indicate busy when any one of its component 28F016SAs is busy, obscuring transitions to ready by any of the other devices and forcing the CPU to continuously poll the flash array to find ready devices.

A more accurate indication of the array state is obtained when each 28F016SA gives a pulsed output signal to the host system when it has finished its operation. The host system can then examine the Global Status Register of each 28F016SA to find which one has become ready and issue a Read command, or any non-queueable command, to the ready device. in this way, multiple devices can operate in parallel without the burden of continuous polling to find which ones have finished their operations.



The 28F016SA incorporates a RY/BY# pin which can be configured four ways:

- Level Mode (Default)
- Pulse-on-Write Only
- Pulse-on-Erase Only
- Disable

Level mode is the default mode. In this configuration, the state of the WSM is continuously indicated by the RY/BY# pin, which is an open drain output pin pulled high through an external pull-up resistor when the WSM is ready. This feature allows the user to OR-tie RY/BY# pins of multiple devices together in flash memory arrays such as Resident Flash Array or flash drive applications, saving control logic and simplifying board design.

Pulse-on-write mode will cause RY/BY # to pulse low at the completion of Page Buffer Write to Flash operations only. This is useful for controlling interleaved page mode writes.

Pulse-on-erase mode will cause RY/BY# to pulse low at the completion of Block Erase operations, including at the end of each Block Erase during an Erase All Unlocked Blocks operation.

The RY/BY# pin can also be disabled so that it will always report a READY condition. Disabling the RY/BY# pin has no impact on the status registers.

#### 7.0 CODE AND DATA PROTECTION

#### 7.1 Selective Block Locking

While the 28F008SA provides data security through the RP# pin (formerly PWD#) and the intrinsic non-volatility of flash, it does not have the ability to provide selective locking of some blocks while leaving others available for writing and erasing. The 28F016SA, however, provides the ability to selectively lock any 64-Kbyte block to protect critical code or data. Each

block on the 28F016SA has an associated non-volatile lock-bit which determines the lock status of that block.

#### 7.2 Master Write Protect

A WP# (Write Protect) pin activates the block lockbits, preventing any Write or Erase of blocks which have their lock-bits set. When the WP# pin is asserted (low) and a block's lock-bit is set, the user is safe from accidentally damaging or modifying the data in that block.

#### 7.3 Software Partitioning

The greatest benefit of the 28F016SA's block locking feature is that it is possible for OEMs and software developers to bundle applications or operating system code in flash memory cards or in RFAs, providing an entirely new medium for software distribution. Software distributed in this way is safe from accidental user overwrites, and yet capable of in-system updates to accommodate new versions. When 28F016SA-bundled code or data needs to be updated, raising WP# high provides a temporary override of the block locking mechanism so that locked blocks on the device may be written to.

The advantage of partitioning a 28F016SA-based memory card into locked and unlocked sections is that a user can keep an application and the files created with that application together. For example, a spreadsheet program and all of the spreadsheets a user has created with that program can be stored on one flash card. Such an arrangement gives the user a new kind of portability, one which allows him or her to carry all of the work in his or her pocket with instant access to the application and files anywhere a compatible PC is available. Hence, the data locking features of the 28F016SA complements its ability to act as executable system memory, providing the end- user with a solution which provides portability, safety, convenience, low power and high speed of access which no other medium can claim.





Figure 11. Block Locking and Code/Data Partitioning

#### 7.4 Reset Capability

The 28F016SA provides complete protection of flash contents through the Reset/Power-down (RP#) pin. RP# locks the flash array from spurious writes and places the outputs in a high impedance state. If asserted during write/erase modes, RP# low aborts the current operation in progress, cancels all pending WSM commands, flushes the command queue and clears the status registers.

RP# is used both as a power conservation feature and as a data protection feature. An example of when RP# is useful for data protection is during power-up, when other inputs to the 28F016SA may be in an indeterminate state. Holding RP# low until the power supplies reach operating levels and all input signals become stable, guarantees maximum protection for the device. The use of RP# for power conservation is discussed in Section 4.4. The reader wishing more detail on the use of the RP# pin is referred to the 28F016SA User's Manual.

#### 8.0 SUMMARY

This application note discusses the key features and benefits of the revolutionary 16-Mbit device architecture and their impact on system and software designs. End-user benefits from these enhanced features are brought to light with respect to the wide range of new applications enabled by the 28F016SA chip and 28F016SA-based system products.

#### LIST OF APPENDICES

A: Command Listings

**B**: References

C: Revision History



## APPENDIX A 28F016SA COMMAND LISTINGS

|                           | Command<br>Codes (Hex) | Device Mode                    |
|---------------------------|------------------------|--------------------------------|
|                           | 00H                    | Invalid/Reserved               |
|                           | 10H                    | Word/Byte Write                |
|                           | 20H                    | Single Block Erase             |
| Ţ                         | 40H                    | Word/Byte Write                |
| 28F008SA-                 | 50H                    | Clear Status Registers         |
| Compatible<br>Commands    | 70 <u>H</u>            | Read CSR                       |
|                           | 90H                    | Read ID Codes                  |
|                           | B0H                    | Erase Suspend                  |
| ,                         | D0H                    | Confirm/Resume                 |
| ,                         | FFH                    | Read Flash Array               |
|                           | 0CH                    | Page Buffer Write to Flash     |
|                           | 71H                    | Read GSR or BSRs               |
|                           | 72H                    | Page Buffer Swap               |
| ·                         | . 74H                  | Single Load to Page Buffer     |
|                           | 75H                    | Read Page Buffer               |
| ,                         | 77H                    | Lock Block                     |
|                           | 80H                    | Abort                          |
| 00504004                  | 96H ·                  | RY/BY# Reconfigurations        |
| 28F016SA-<br>Performance- | 01H                    | RY/BY# Enable to Level Mode    |
| Enhancement               | 02H                    | Pulse-On-Write                 |
| Commands                  | 03H                    | Pulse-On-Erase                 |
| •                         | 04H                    | RY/BY# Disable                 |
|                           | 97H                    | Upload Status Bits             |
|                           | 99H                    | Upload Device Information      |
|                           | A7H                    | Erase All Unlocked Blocks      |
|                           | E0H                    | Sequential Load to Page Buffer |
|                           | F0H                    | Sleep                          |
|                           | FBH                    | Two-Byte Write                 |
|                           |                        |                                |



### APPENDIX B REFERENCES

| DOCUMENT                                                                               | ORDER NUMBER |
|----------------------------------------------------------------------------------------|--------------|
| 28F016SA 16-Mbit (1-Mbit x 16, 2-Mbit x 8) FlashFile <sup>TM</sup> Memory Data Sheet   | 290489       |
| DD28F016SA 32-Mbit (2-MBit x 16, 4-MBit x 8) FlashFile <sup>TM</sup> Memory Data Sheet | 290490       |
| 28F016SA 16-Mbit FlashFile <sup>TM</sup> Memory User's Manual                          | 297372       |
| AP-357 Power Supply Solutions for Flash Memory                                         | 292092       |
| AP-359 28F016SA Hardware Interfacing                                                   | 292094       |
| AP-360 28F008SA Software Drivers                                                       | 292095       |
| AP-375 Upgrade Considerations from the 28F008SA to the 28F026SA                        | 292124       |
| AP-377 The 28F016SA Software Drivers                                                   | 292126       |
| ER-33 ETOX IV Flash Memory Technology                                                  | 294016       |



## APPENDIX C REVISION HISORY

| Number | Description      |  |
|--------|------------------|--|
| 1.0    | Original Version |  |



## APPLICATION NOTE

# Implementing Mobile Intel486<sup>TM</sup> SX Microprocessor PC Designs Using FlashFile<sup>TM</sup> Components

DON VERNER SENIOR APPLICATIONS ENGINEER

RAJIV PARIKH TECHNICAL MARKETING ENGINEER CHUCK BROWN SENIOR APPLICATIONS ENGINEER

TONY SHABERMAN TECHNICAL MARKETING ENGINEER

November 1994

## Implementing Mobile Intel486™ SX Microprocessor PC Designs Using Flashfile™ Components

| <b>CONTENTS</b> PAGE                                              | CONTENTS PAGE                                   |
|-------------------------------------------------------------------|-------------------------------------------------|
| <b>1.0 INTRODUCTION</b> 3-745                                     | <b>3.0 HARDWARE</b>                             |
| 1.1 Why a New Memory Architecture                                 | 3.1 Resident Flash Disk Implementation          |
| 1.2 The Flash Memory Alternative 3-746                            | 3.2 XIP DOS Implementation 3-759                |
| 1.3 The FLEXlogic* PLD                                            | 3.3 XIP GUI Implementation 3-760                |
| Advantage                                                         | 3.4 RFA Control Logic Overview 3-762            |
| 1.4 Summary 3-748                                                 |                                                 |
| 2.0 SOFTWARE DESIGN 3-748                                         | <b>4.0 SOFTWARE UTILITIES</b> 3-769             |
|                                                                   | 4.1 Diagnostic 3-769                            |
| 2.1 XIP Operating System 3-748                                    | 4.2 Binary Loader 3-769                         |
| 2.2 DOS in Flash Implementation 3-750                             | <b>5.0 SUMMARY</b> 3-769                        |
| 2.3 Resident Flash Disk 3-752                                     | 3.0 30MMAH 1 3-709                              |
| 2.3.1 MICROSOFT'S FLASH FILE SYSTEM                               | 6.0 ADDITIONAL PUBLICATIONS 3-770               |
| 2.4 Resident Flash Disk and the ExCA™ Standard Architecture 3-753 | APPENDIX A: MS DOS ROM Image Description        |
| 2.4.1 ExCA™ STANDARD ARCHITECTURE SOFTWARE INTERFACE              | APPENDIX B: ROMDISK CONFIG.SYS and AUTOEXEC.BAT |
| 2.4.2 RFD SOCKET SERVICES 3-755                                   | APPENDIX C: Windows 3.1                         |
| 2.5 XIP Graphical Users Interface                                 | <b>CONTENTS.ROM</b> 3-773                       |
| Overview 3-756                                                    | APPENDIX D: PLD EQUATIONS 3-778                 |
| 2.6 XIP GUI Implementation 3-757                                  |                                                 |
| 2.7 Pon Extensions 2.759                                          |                                                 |



#### 1.0 INTRODUCTION

As personal computers migrate to platforms that are easily held with one hand, a revolutionary system architecture is required to meet space and power requirements.

- An architecture that is not bound by what has been done before with existing memory architecture, but free to meet the demanding requirements of mobile end-users.
- An architecture free to adapt and accommodate new technological advances in software and hardware, while protecting end-users initial base hardware investment.

Implementing this new system architecture requires traditional PC storage media such as ROM, DRAM, floppy disk and hard disk to move aside and make room for the latest in memory storage, Intel's FlashFile<sup>TM</sup> memory (see architecture comparison in Figure 1).

| Application | Data<br>Manipulation | Code<br>Execution | File & Code<br>Storage                                    |
|-------------|----------------------|-------------------|-----------------------------------------------------------|
| Desktops    | DRAM                 | DRAM/ROM          | FDD/HDD                                                   |
| Portables   | DRAM                 | FLASH             | FLASH<br>- Resident Disk<br>- Flash Card<br>- Flash Drive |

Figure 1. Architecture Comparison

By combining FlashFile memory with new system architecture, completely new types of computers are now possible that fit in the palm of your hand and replace or integrate many of the code or storage functions of older memory types. Moreover, FlashFile memory enables hand-held computers to last many hours on just a couple of AA batteries. FlashFile memory can be used for storing eXecute-In-Place (XIP) code in the system's memory map, while additionally functioning like a disk for file and program storage. Since this type of design features FlashFile memory resident on the PC's motherboard and is typically arranged in an array, it is

described as a Resident Flash Array (or RFA). To further differentiate the two tasks of an RFA, the file store task is called a Resident Flash Disk (RFD), while the XIP task is called Resident Flash for XIP (or RFX) code storage.

The FlashFile memory is also used in card form as specified by the Personal Computer Memory Card International Association (PCMCIA). Flash memory cards provide file and program storage similar to an RFD, but add the feature of removability, increasing or adding to ease-of-use for the end-user. The PCMCIA specification addresses both the memory and I/O card's physical, electrical and mechanical characteristics, while leaving the host PC implementation relatively free for interpretation. Enhancing the PCMCIA specification, Intel developed the Exchangeable Card Architecture (ExCATM standard), which defines the host PC system card interface. ExCA standard architecture further refines the PCMCIA specification and provides for card exchangeability and inter-operability for both memory and I/O cards.

Memory and I/O cards complement this new mobile architecture by integrating many of the common, but functionally separate, tasks used by today's mobile professional in either electronic or paper form. Some of these tasks are schedule keepers, phones, address books, checkbooks, credit cards, fax, pagers, personal voice storage, task managers/schedulers, paperless form reports, scratch pads, and notepads.

#### 1.1 Why a New Memory Architecture?

The ideal hand-held memory system is:

- Power Conscious (prolongs battery life and reduces heat)
- Dense (stores lots of code and data in a small amount of space but weighs very little)
- Updateable (allows in-situ code enhancements)
- Fast (lets you read and write data quickly)
- Inexpensive (low cost-per-megabyte)
- Reliable (retains data when exposed to extreme temperature and mechanical shock)

Since the PC's introduction over 10 years ago, designers have grappled with how to construct memory systems that meet the above criteria. Portable computing makes the system design even tougher with more stringent requirements for low power, low volume and less



weight. The best combination available for portable designs in their infancy was the same as used for the desktop; solid-state memory and magnetic storage, i.e., SRAMs, DRAMS plus magnetic hard disks. DRAMs are dense and inexpensive, yet slower than the processors they serve, and they are volatile. SRAMs, although fast enough to keep pace with processors, are relegated to caching schemes (compensating for DRAM's slowness) due to low density and high cost while also being volatile. Magnetic hard disks, the nonvolatile appendage to DRAM and SRAM, are dense, inexpensive on a cost-per-megabyte basis and nonvolatile, but are slow, power hungry, take up a sizable amount of volume and are susceptible to damage from physical shock.

Mobile computing designs cannot depend on hard drives as do portable notebook PCs. Volume (4" x 8" x 0.5" or less), power (two AA batteries), and shock constraints preclude using even the 1.3" hard drives available today. Furthermore, vitally important data such as credit card numbers or transactions, signatures, or checkbook information demands reliability of the highest order.

#### 1.2 The Flash Memory Alternative

#### **High Density**

Intel's ETOXTM III Flash Memory Cell is 30% smaller than equivalent DRAM cells; therefore it will closely track DRAM density. Intel's 28F016SV FlashFile memory can store 16 megabits, or two megabytes, of data. Flash memory is more scaleable than DRAM because the flash storage cell is not sensitive to soft error failure; therefore it can have a more simple cell structure. Thus as density increases and process lithography continues to shrink, flash memory will pace, and ultimately overtake, the DRAM technology treadmill.

#### SmartVoltage Technology

The 28F016SV incorporates Intel's SmartVoltage technology, providing  $V_{CC}$  operation at both 3.3V and 5.0V and program and erase capability at  $V_{PP}=12.0V$  or 5.0V. Operating at  $V_{CC}=3.3V$ , the 28F016SV consumes approximately one-third the power consumption at 5.0V  $V_{CC}$ , while 5.0V  $V_{CC}$  provides the highest read performance.  $V_{PP}=5.0V$  operation eliminates the need for a separate 12.0V converter, while  $V_{PP}=12.0V$  maximizes write/erase performance In addition to the flexible program and erase voltages, the dedicated  $V_{PP}$  gives complete code protection with  $V_{PP} \leq V_{PPLK}$ .

Internal 3.3V or  $5.0V\ V_{CC}$  detection automatically configures the device for optimized 3.3V or  $5.0V\ Read/$  Write operation.

#### Updateable

ROMs and EPROMs may offer lower device costs, but if time to market or servicing the customer or end-user is important to an OEM, overall system cost must be factored in. Although ROMs and EPROMs are nonvolatile, changing the code within them is either very difficult (in the case of EPROMs), or entirely impossible (in the case of ROMs). Whole inventories of ROMs could be lost in the event of a catastrophic bug, while an innovative design with FlashFile memory can be updated in the factory or by end-users via networks, OEM Bulletin Board Systems, or other memory cards. Updating systems could actually become a second source of income for OEMs and Independent Software Vendors (ISVs), enhancing the quality of the product while increasing end-user satisfaction.

#### **Power Conscious**

Intel's FlashFile memory provides a deep power-down mode, reducing power consumption to typically less than 0.2  $\mu$ A. Typical read current is only 20 mA, while typical standby current (flash memory not being accessed with CE# high) is only 30  $\mu$ A. Additionally, FlashFile architecture devices operating at 3.3 V<sub>CC</sub> are available for state-of-the-art low-power consumption designs.

#### Fast

Don't be misled by technology-to-technology speed comparisons. Architecting a system around FlashFile memory bypasses the code/data bottleneck created by connecting slow mechanical serial memory (such as disks) to a high-performance, parallel-bussed processor system. For example, data seek time for a 1.8" magnetic hard disk is 20 ms, plus an 8 ms average rotational delay, while flash memory access time is less than 0.1 ms. At the chip level, read speeds for FlashFile memory are about 85 ns. Therefore, either direct execution of code from flash memory or downloading to system RAM will dramatically enhance overall system performance.

#### Nonvolatile

Unlike DRAM or SRAM, FlashFile memory requires no battery back-up. Further, Intel's flash devices retain data typically for over 100 years, well beyond the useful lifetime of even the most advanced computer.



#### Rugged and Reliable

On average, today's hard-disk drives can withstand up to 10 Gs of operating shock. Intel's FlashFile memory can withstand as much as 1000 Gs. FlashFile components can operate beyond 70°C while magnetic drives are limited to 55°C. Intel's FlashFile memory can be cycled at least 100,000 times per block or segment. Even beyond that cycle level, FlashFile architecture does not fail or lock up like EEPROM devices, it just tends to take longer to erase blocks and program bytes than the times specified in the data sheet. By employing wear-leveling techniques, a 10-KB file written every 5 minutes, 24-hours a day to a 20-MB flash array takes 1.2 million hours, or 136 years, before reaching the 10,000 cycle level.

#### 1.3 The FLEXIogic Advantage

The mobile processor market lacks the legacy that exists in the other markets. As a result, standard chipsets are not available to help design products for the mobile market. This situation makes the job of mobile system designs more difficult than it might otherwise be. Many of the same subsystems need to be designed for mobile systems as for other markets, but no off-the-shelf components are available.

Altera's EPX780 FLEXlogic PLD allows the systems designer to quickly implement and test new mobile designs. Since the EPX780 is a programmable device, the design described in this application note provides a standard building block for mobile systems that allows customization for different memory subsystems, processor variations and applications. The RFA memory controller requires only about 65% of the macrocells in the EPX780, thus allowing additional logic functions to be integrated with no additional space requirement.

The EPX780 also satisfies the needs of mobile systems by providing:

#### High Performance & Deterministic Timing

The EPX780 offers a fast, deterministic 10 ns tpD from any input or I/O to any I/O. It can be operated in-system at speeds of up to 80 MHz. Unlike other field programmable gate array architectures, the FLEXlogic family offers very deterministic timing and may reduce the need for extensive design, simulation and timing analysis.

#### High Density and Flexibility

The EPX780 offers 80 macrocells of logic grouped into eight Configurable Function Blocks (CFBs). Each CFB can be independently configured as a 24V10-type PLD or as a 128-deep x 10-bit-wide bank of SRAM.

When configured as a 24V10 logic, an identity compare of up to 12 bits can be performed in parallel to the SOP logic for each CFB. Each macrocell can implement registered or combinatorial logic with a variety of clocking and control options, providing the system's designer with greater flexibility.

#### In-Circuit Reconfigurable and Programmable

Although some simple PLDs offer re-programmability, changing the logic design in-circuit is either very difficult or entirely impossible. In contrast, the EPX780 offers in-circuit reconfiguration through an industry standard IEEE 1149.1 JTAG interface. This capability can significantly reduce the time required for proto-typing new designs.



#### Low Power, Mixed-Voltage

The FLEXlogic PLDs provide reduced power consumption compared with simple PLDs or other FPGA devices. Typical operating current is only 1.5 mA/MHz, while standby current for the EPX780Z is 1 mA. Additionally, the outputs of the EPX780 can be operated at 5.0V levels or 3.3V levels. Inputs responds to 2.0V as a logic high, regardless of the output swing. This allows the EPX780 to be used in state-of-the-art 3.3V designs or mixed voltage environments commonly found today.

#### High I/O

cuit. ·

To meet the high I/O demands of a 32-bit system, the 132-pin PQFP EPX780 offers 80 I/Os and 22 dedicated inputs for a total of 102 I/Os. This satisfies the I/O demands of an RFA controller, and allows support for additional logic requirements.





#### 1.4 Summary

Many applications benefit from ROMed or XIP versions of code, particularly hand-held personal computers, vertical application pen-based clipboards, and industrial control and data accumulation equipment. These applications pose system design constraints requiring small form factor, low-power consumption, and rugged construction due to active mobile users or harsh environments. Exposure to shock, vibration, or temperature extremes is common, precluding the use of rotating media. Flash memory provides an excellent code storage choice for such system designs featuring thin TSOP packaging, low (deep power-down mode) or zero (capability to shut off power without losing data) power consumption, 1000 G shock resistance and extended temperature products. Additionally flash memory provides remote or end-user update capability, allowing OEM's to service their products more efficiently and add new software features and applications after the sale.

The features of Intel's FlashFile memory and Altera's FLEXlogic PLDs truly enable new, compact and portable system architectures. This application note discusses implementing an Intel486<sup>TM</sup> SX CPU mobile design using the following components: Intel's boot block flash memory; Intel's FlashFile components (28F016SV) for extended memory eXecute-In-Place (XIP) code store, disk-like functionality for file and program storage, and BIOS code storage; and Altera's FLEXlogic PLD (EPX780) as a memory controller.

#### **Related Publications**

The following data books and reference manuals provide valuable information for developing an RFA-based design:

- Intel 28F016SV 16-Mbit (1 Mbit x 16, 2 Mbit x 8)
   FlashFile<sup>TM</sup> Memory Data Sheet, order number 290528
- Intel 28F016SA 16-Mbit FlashFile<sup>TM</sup> User's Manual, order number 297372
- Microsoft MS-DOS\* 5.0 ROM Technical Specification and OEM Adaptation Kit (OAK)
- Microsoft Flash Filing System OAK
- Microsoft Windows\* 3.1 ROM Technical Specification and OAK

For additional information on flash memory and power supply solutions, see section 6.0.

#### 2.0 SOFTWARE DESIGN

Software design is considered first for solid-state designs because the software functionality desired affects in large part how the hardware design is implemented. Many software products exist for solid-state systems:

- DOS operating systems from Microsoft, Novell's Palm DOS and Datalight's ROM-DOS
- A Graphical User Interface (GUI) operating system in Windows 3.1 ROM version
- Application software from Microsoft such as Word, Excel and MS-Works and Lotus 1-2-3 Version 2.2.

Because no standardization exists, implementation differs from package to package or vendor to vendor. Therefore, this application note describes a system using MS-DOS 5.0 ROM Version, MS Flash File System, Windows 3.1 ROM Version plus Pen extensions. All are readily available applications today and offer the highest inter-compatibility. However, the hardware and software design concepts presented here work just as well with Novell's (formally DRI) Palm DOS.

#### 2.1 XIP Operating System

The first decision one must make for a solid-state software design is the operating system. Many alternatives exist for small hand-held computer systems. Any solution depends on what requirements are placed on desktop compatibility, software compatibility, and ease of developing applications. In the pen-based market, DOS compatibility is not necessarily a requirement. This is evident by the multiple emerging entries of pen-based GUIs. However, data transfer using a medium such as memory cards between desktop systems and hand-held computers depends on an agreed file format. At least for now, DOS is still the major operating system of choice for the largest number of desktop systems. Therefore, DOS compatibility is still a necessity for many hand-held computing systems and is incorporated in this design.

To insure compatibility and easy system integration, MS-DOS 5.0 ROM Version is the easiest choice. With this version, an XIP DOS implementation can be configured to as small as 64 KB, using just the Runtime Kernel and a minimized command interpreter. If CONFIG.SYS and AUTOEXEC.BAT processing is required, an additional 56 KB are required, plus a ROM DISK large enough to hold AUTOEXEC.BAT, CONFIG.SYS, and any drivers and files that are referenced by either file.



Microsoft provided the capability for additional XIP DOS applications to be added to an MS-DOS XIP implementation by supplying two new DOS functions, "Find First ROM Program" and "Find Next ROM Program." This allows DOS-based XIP applications (such as OEM-specific utilities and applications or ROMed DOS applications) to easily be added to the MS-DOS 5.0 ROM build.

Many different memory configurations of MS-DOS ROM are possible by distributing various software pieces (Microsoft refers to them as granules) between different ROM locations below and above the 1-MB address space. Certain restrictions exist on individual granules requiring them to appear below 1 MB. The granules and address location requirements are specified in a table within the MS-DOS ROM 5.0 OAK. Approximately 43 KB of granules must be located below the first 1 MB of address space. Other granules can be located either below or above 1 MB. The total size of all granules in this design is approximately 128 KB.

#### How MS-DOS ROM Boots Up

For system startup and booting DOS without a disk, MS-DOS 5.0 ROM must intercept the INT 19h call made by the BIOS. This is accomplished by locating a granule as an adapter ROM within adapter space (C0000h-EFFFFh). This granule contains the ROM scan identifier "55AAh" which must appear on a 2-KB boundary and identifies the module as a ROM to the BIOS during Power On Self-Test (POST), and also identifies the MS-DOS 5.0 ROM INT 19h interceptor. When the BIOS POST code identifies the ROM, control is turned over to the ROM for its initialization. At this time, the MS-DOS 5.0 ROM redirects the INT 19h vector to the MS-DOS 5.0 ROM code and control returns back to the BIOS POST code. When the BIOS is completely finished testing and initializing, it issues INT 19h, and the MS-DOS 5.0 ROM INT 19h handler gains control. The handler loads the MS-DOS 5.0 ROM bootstrap loader into RAM and passes control to it. If the bootstrap loader includes the "Multi-Boot" option, a list of menu boot options are presented to the user if an OEM-defined key is being pressed. The menu might look like Table 1:

#### Table 1. Multi-Boot Menu

#### **Booting from a Disk**

- 1. Boot from floppy disk.
- 2. Boot from hard disk.

#### **Booting from ROM:**

- Floppy is default; process start-up files.
- 4. Hard drive is default; process start-up files.
- Floppy is default; do not process start-up files
- 6. Hard drive is default; do not process start-up
- ROM drive is default; process start-up files.

The menu is activated by pressing the ALT key during the system memory scan, which is the default provided in the OAK. Other types of keys may be selected by the OEM for their specific implementation. Selecting the options under "Booting from a Disk" will bypass the ROM system completely. Selecting the options under "Booting from ROM" will invoke MS-DOS 5.0 ROM and whatever the option specifies for processing the startup files, CONFIG.SYS and AUTOEXEC.BAT.

If the Multi-Boot option is not available or is not activated by the user, the MS-DOS 5.0 ROM bootstrap loader reads a byte from CMOS RAM to determine boot options. The byte is defined in Table 2.

If the system is to boot from ROM by either selecting the Multi-Boot option or reading the CMOS byte, the MS-DOS 5.0 ROM bootstrap loader loads BIOS (note: not system BIOS, but the BIOS layer of MS-DOS) and DOS initialization granules into RAM, records the addresses of the resident BIOS and DOS code granules in the BIOS data area, records boot options (default drive, CONFIG.SYS and AUTOEXEC.BAT processing) in the BIOS data area, and passes control to BIOS initialization. Just before the end of BIOS initialization, control is passed to SYSINIT which moves itself and DOS data and initialization code to high memory where both SYSINIT and DOS initialization takes place. Next SYSINIT then reads and processes the CONFIG.SYS file where installed drivers called in CONFIG.SYS and additional elements of the DPB chain will be placed in memory following the existing DOS structures as well as system buffers allocated. System bootstrap is finished and the command interpreter is started using the DOS call to execute ROM utilities. If a full command processor is chosen, the user will now see "C:>" prompt.



#### **Table 2. CMOS Byte Definitions**

| Reserved | Default Drive if ROM Boot | Default Drive if ROM Boot | ROM<br>CONFIG.SYS<br>Processing | Default Boot |
|----------|---------------------------|---------------------------|---------------------------------|--------------|
| 7 to 4   | 3                         | 2                         | 1                               | 0            |

Default Boot Bit 0:

- 0- Boot from ROM
- 1- Normal disk boot operation (first is drive 00, then drive 80)

**ROM Configuration Processing Bit 1:** 

- 0- Process CONFIG.SYS and AUTOEXEC.BAT from default drive
- 1- Do NOT Process CONFIG.SYS or AUTOEXEC.BAT files

Default Drive if ROM Boot Bits 2 & 3

- 00- First Floppy Drive (0h)
- 01- First Hard Drive (80h)
- 10- ROM Drive

#### 2.2 DOS in Flash Implementation

For this particular implementation, a full version of MS-DOS with the full Command processor was chosen. This configuration uses 64 KB of adapter space (upper memory) at E0000h to EFFFFh for MS-DOS 5.0 ROM, and a combination 32-KB XIP binary file and a 256-KB ROM Disk binary file located in extended memory at FB8000h. See Figure 2. ROM DOS and ROM Disk Memory Maps. This location is just after the end of the XIP GUI code block. The XIP Binary contains the transient portion of COMMAND.COM and the DOS BIOS initialization and is created during the build of the MS-DOS 5.0 ROM system, while the 256-KB ROM Drive contains the necessary files for bringing up the system and loading the flash file system drivers which are addressed in the next section.

The E0000h segment was chosen because it happens to be free on the flash BIOS storage chip. Also, later on in this design we will be adding an RFD, which takes up 16 KB of the DC000h segment, and the ExCA standard architecture, which requires 16 KB of adapter space that we located at D4000h (see Figure 2 for a

memory map). The ROM disk image location was chosen because there was room available in the extended XIP portion. The XIP portion is located at C00000h (12 MB). A copy of the ROM image description file is included in Appendix B.

The following summarizes the steps taken for building a ROM version of DOS is taken from the MS-DOS 5.0 ROM OAK. Please refer to the MS-DOS 5.0 ROM OAK for specific details.

There are a set of compile options specified in the MS-DOS 5.0 ROM OAK that need to be defined by the OEM for their particular implementation and are contained in the OAK file named "VERSION.INC." The compile options used for this example are listed as follows:

ROMDOS equ TRUE
POWER equ FALSE
ROMDRIVE equ TRUE
CMOS equ TRUE
CONFIGPROC equ TRUE





Figure 2. ROM DOS & ROM Disk Memory Maps

For this application this means that for:

"ROMDOS" - a ROMDOS build (as opposed to DISK build simulation) is used.

"POWER" - the MS-DOS APM and power management are NOT used.

"ROMDRIVE" - the compiler will use the internal ROMDRIVE drivers,

"CMOS" - forces MS-DOS 5.0 ROM to look at the CMOS byte if the Multi-Boot option is not chosen.

"CONFIGPROC" - normal CONFIG.SYS and AUTOEXEC.BAT processing will be used.

Since we are planning to use a ROM DRIVE, MS-DOS 5.0 ROM needs to know where the ROM DRIVE exists. To set the ROM drive base address, the MS-DOS 5.0 ROM OAK file ROMRDHI.ASM must be modified. Edit the file and set the ROMDRIVERBASE\_LO equal to 0000h and the ROMDRIVERBASE\_HI equal to 0FAh, or 64 KB above the base address of the extended memory XIP module.

Now the MS-DOS ROM binaries are ready for building. Using the NMK utility, 3 separate binary files are compiled based on the requirements and addresses specified in the MS-DOS ROM Image Description file

in Appendix B. ROM binary files 1 and 2 can be combined into one 64-KB binary image as follows:

copy /b ROM1.BIN+ROM2.BIN ROMDOS5.BIN

Once the XIP binaries are built, the rest of the ROM disk needs to be built. First, specify a RAM Drive within your build or development PC using the MS-DOS RAMDRIVE.SYS device driver as follows:

device = RAMDRIVE.SYS 256 /e

After rebooting your PC, copy the files needed for your particular application. For an example of CON-FIG.SYS and AUTOEXEC.BAT files, see Appendix C. Change the drive label as per the MS-DOS 5.0 OAK instructions and then use the MS-DOS IMGET utility to capture the image of the RAM drive into a binary file. Next, concatenate the ROM3.BIN binary image created by the NMK with the ROM Disk image captured from the RAM drive by using the MS-DOS Copy command as stated earlier:

copy /b ROM3.BIN+RDISK.BIN ROMDSK.BIN

This will create a 327-KB binary file with both XIP DOS code and the ROM Disk code for a single load into flash memory.



Loading the ROMDOS5.BIN file into the system's flash BIOS chip requires the use of a BIOS Independent Software Vendor's (ISV) Flash Update Utility. Most major BIOS ISVs now offer such utilities. If your particular system design uses a BIOS developed internally, refer to Intel's AP-341 "Designing an Updateable BIOS Using Flash Memory" (order number 292077) for more information on flash BIOS designs and related software. Loading the ROMDISK.BIN file requires developing a DOS-based utility to access flash memory in "protected mode." Creating this utility is discussed under Section 4.0, Software Utilities, Subsection 4.2, Binary Loader.

#### 2.3 Resident Flash Disk

Once a DOS-based, XIP operating system is in place, the next area to work on is file storage for flash memory. File storage is possible with either FlashFile components or FlashFile memory-based cards, since they appear the same to file system software. However, the characteristics of flash memory are very unlike magnetic storage media characteristics.

File Allocation Table (FAT)-based systems rely on the fact that the operating system has unrestricted Write capability and/or access to the media, particularly when updating the FAT for a file creation, update or deletion. Flash memory on the other hand, does not necessarily allow write access 100% of the time. When the flash memory media is completely erased (all FFh's), writing data to the media can occur at any time and at any location. Additional data writes within the same block but at different locations can also occur. However, once a bit is written to a zero (0b), erasure of the whole block is required (taking the bits to a Logic 1 condition) before allowing that particular bit to change back to zero. This asymmetrical characteristic of flash memory prevents using a straight implementation of the FAT-based file architecture and requires an alternative file system implementation.

#### 2.3.1 MICROSOFT'S FLASH FILE SYSTEM

To enhance the use of flash memory as a disk, Microsoft created the flash file system. This file system operates as a list of linked lists while keeping track of individual block erasure and file deletions, using minimal system overhead. File allocation structures use indirectly linked lists, allowing the file system to update files and data within the files without first requiring the area where the file is located to be erased and then updated. During file deletion, a file's header structure is written to mark the file as deleted, removing the file from the

file allocation listing. Once a block contains a majority of deleted files, the file system performs a (background) clean-up operation and copies good files out to a free block and erases the block with all the deleted files. This achieves the goal of user being able to use flash memory the same as they would use any other mass storage media without doing anything different.

Three distinct parts comprise the file system organization and implementation:

- A File System Redirector, whose job is to intercept the disk operations passed to MS-DOS by an application and translate them into generic file operations, passing them on to the File System Driver.
- A File System Driver, which accepts generic file operations passed to it from the File System Redirector, implements the architecture and logic of the Microsoft flash file system, and passes low-level commands such as Read, Write, Copy, and Erase to the device driver.
- A Device Driver, which accepts low-level commands from the File System Driver and interfaces to the host system hardware implementation.

The File System Redirector performs a task analogous to a network redirector for LAN (Local Area Network) systems and appends itself to MS-DOS. Applications then think they are running from a networked drive. Some classes of applications and utilities will not operate via this interface. Specifically, those applications that issue the INT 13h disk BIOS I/O call, INT 25h DosAbsRead, or INT 26h DosAbsWrite calls will not work properly with the flash file system, just as they would not work over a network LAN. The File System Driver treats the flash media as a collection of large blocks, all identical in size. Individual block statistics are kept within a variable length structure at the top of the block with the remainder of the space available for directory, file control structures and file data storage. The File System Driver also determines when de-allocated space (deleted files or directories) within a block is reclaimed for re-use.

The device driver portion is OEM-modifiable and needs to be written for the specific hardware used. The only MS flash file system hardware requirement is a single window available per socket in a system's adapter space that addresses all the flash memory to be used. Window size and base address are left to the system designer to decide, based on system design requirements.



#### Hardware Guidelines:

- Window size of either 8, 16, or 32 KB
- Base address in adapter space (C0000h to DFFFFh)

For more detailed information on Microsoft's flash file system, consult the Microsoft flash file system OAK.

#### 2.4 Resident Flash Disk (RFD) and the ExCA Standard Architecture

Many systems which use an RFA will also want to incorporate PCMCIA memory and I/O cards. If an RFD uses the same software architecture used for PCMCIA cards, less software duplication is present in systems containing both cards and RFDs. This section discusses the ExCA standard architecture as it applies to an RFD and a flash file system.

Most of this section was excerpted from the "ExcA Standard Specification." The reader is encouraged to obtain that document for more details not revealed in this discussion. Also refer to "PCMCIA PC Card Standard, Release 2.1," "PCMCIA Card Services Interface Specification," and "PCMCIA Socket Services Interface Specification, Release 2.1."

The ExCA standard architecture specifies a standard host system hardware and software interface for 68-pin, PCMCIA/JEIDA memory and I/O cards. The "ExCA Standard Specification" defines the minimum hardware and software interfaces that card and system designers can rely on for basic compatibility across PC Cards, systems, and related software. By defining these interfaces, the ExCA standard architecture makes the PCMCIA goal of PC Card inter-operability a reality.

## 2.4.1 Exca Standard Architecture Software Interface

The primary purpose of the ExCA standard architecture software interface is to explicitly define a minimal set of socket control and resource access functions upon which higher-level PC Card Client device drivers can rely. A PCMCIA implementor may incorporate a range of functions beyond the basic Memory Card Interface specified in PCMCIA 1.0. For PCMCIA 2.1, three primary functional extensions to the specification exist. They are: I/O devices, L-XIP-mapped memory ("L" stands for LIM or Lotus, Intel, Microsoft), and E-XIP-mapped memory ("E" stands for Extended or protected mode memory). While basic memory requirements can be met with a single, small memory-mapped window or even via an I/O approach, both XIP modes require direct-mapping interface capability, with very specific boundaries in the L-XIP mode. Without an ExCA standard architecture-like hardware and software support for direct-mapped memory, XIP-formatted cards cannot function. The ExCA standard architecture socket hardware and software specifications define basic, clear compatibility definitions for PC cards, software drivers, and host systems.

ExCA standard architecture allows PC Cards and sockets to be accessed by multiple PCMCIA-aware device drivers, configuration utilities and applications, with efficient and non-conflicting use of system resources. An architectural diagram of ExCA standard architecture functionality is shown in Figure 3. The primary components of the software interface are Socket Services, Card Services, and Memory Technology Drivers (MTDs). Socket Services provide the lowest-level function set for socket hardware adapter control. Card Services allocates resources and coordinates PC Cardrelated activities for higher-level client device drivers. MTDs provide basic program/erase algorithms.





Figure 3. MS FFS and ExCA™ Standard Architecture
Adding an RFD Requires only one Software Addition - RFD Socket Services

#### **ExCA Standard Architecture Socket Services**

ExCA standard architecture Socket Services is the lowest-level software interface that directly controls PC Card sockets. Socket Services defines a software interface to manipulate socket adapter hardware in a way that is independent of hardware implementation. Socket Sérvices defines several abstract resources which can be manipulated. An Adapter is the hardware that supports connecting one or more 68-pin PCMCIA Sockets to a host system, or in the case of a resident flash disk, the hardware that supports a memory interface only. A Socket is the hardware that supports a single 68-pin PCMCIA connector. A Window is the hardware that supports mapping a region of system memory or I/O address space to a region of card memory or I/O address space. A Card is a PCMCIA card that is inserted into a socket. Example functions are: configure a socket for an I/O or memory interface, control socket power voltages and make callbacks for PC Card insertion and status changes.

Socket Services code size is small, enabling it to fit within a ROM-BIOS. The Socket Services interface can be used during POST, and must be ROM-resident to support booting from a PC Card. The interface is accessed via an 8086-compatible register-based protocol, and invoked through software interrupt 1Ah, with functions starting at 80h. This interrupt is shared with the real-time CMOS Clock Driver. The Socket Services software interrupt is called with the proper settings in the host processor's registers. The functions returns status via the Carry flag and registers specific to the function invoked.

Multiple hardware socket adapter interfaces can be supported by chaining multiple Socket Services handlers. This includes providing Socket Services support for motherboard-resident flash memory arrays by treating the control circuitry and memory array as if it were a PC Card single socket/card combination.



#### **ExCA Standard Architecture Card Services**

Card Services is the interface used to manipulate ExCA standard architecture-related system resources. Card Services is sub-divided into five functional categories: Client Services, Resource Management, Client Utilities, Bulk Memory Services, and Advanced Client Services. Client Services provide for client initialization and the callback registration of clients. Resource Management provides basic access to available system resources. combining knowledge of the current status of system resources with the underlying Socket Services adapter control functions. Client Utilities perform common tasks required by clients so that functions, such as CIS (Card Information Structure) tuple access, do not need to be duplicated in each of the client device drivers. Bulk Memory Services provide read, write, copy, and erase memory functions for use by file systems or other generic memory clients that need to be isolated from memory hardware details. Advanced Client Services provide specific functions for clients with special needs.

Card Services provide a packet-based request interface (i.e., uses a block of RAM for passing inputs and outputs between the caller and the interface) which provides a standard protocol for PC Card client device drivers to access cards and their required system resources. It provides separate registration and callbacks for card insertion and card status change event notifications, allowing associated client device drivers to take the appropriate actions. For file system Read, Write, Erase and Copy operations, a special interface is provided for Memory Technology Drivers (MTDs) which can handle the details of different memory technologies.

Resource Management provides a protocol for sharing resources within an environment, where previously the end-user was responsible for resolving resource conflicts. Resource Management resolves resource contentions without end-user interaction.

Advanced Client Services contains a ReturnSSEntry function which is essentially a direct bypass to Socket Services. Card Services require Socket Services to manipulate PC Cards and socket hardware. ExCA standard architecture client drivers should typically interact directly with Card Services and not Socket Services.

Card Services is typically implemented as a device driver. Card Services provides function number AFh in the Socket Services interrupt 1Ah interface for real-mode operation. During initialization, Card Services determines the state of the host environment. This includes determining available system memory, available I/O ports, IRQ assignments, installed PC Cards and socket state. How this is performed is implementation-specific.

#### Memory Technology Driver

The PCMCIA standard supports many types of memory devices used in PC cards. While all PC memory cards can be read from, writing or erasing memory cards may require special programming algorithms. Card Services hides these details of writing or erasing various memory cards from Client Device drivers, like Microsoft's Flash File System, by using a Memory Technology Driver (MTD). Each MTD contains the specific algorithms required by the memory card manufacturer for programming or erasing their cards. Implementation of MTD support in Card Services is recommended. It is not required for ExCA standard architecture compliance at this time.

#### 2.4.2 RFD SOCKET SERVICES

RFD "Socket Services" functions similar to ExCA standard architecture Socket Services in that the software interface to manipulate socket adapter hardware is preserved, but an RFD Socket Services does not control any sockets or cards or respond to card removal and insertion events. RFD Socket Services allows a resident flash disk implementation, through chip-set logic or additional external logic, to appear to ExCA standard architecture software and the system as another Adapter using a single Window mechanism, accessing permanently installed flash memory on a motherboard. All the rest of ExCA standard architecture Socket Services functions are kept as they relate to this definition. An example of a non-working RFD Socket Services function is using it to configure an I/O card. If requested to complete such an operation, RFA Socket Services will respond with "Function not supported."

For more information on the specific hardware design used for a Resident Flash Disk, refer to Section 3.0.



# 2.5 XIP Graphical Users Interface (GUI) Overview

Many GUIs exist today, but not all are configured to run in a minimized XIP mode for portables. Some designs may implement a simple DOS-based pen interface on top of an XIP DOS, like Communications Intelligence Corporation's PenDOS\*, and add a single application like a forms recorder. Other designs may not use XIP DOS at all and the system design revolves around the XIP GUI requirements alone.

Microsoft leads the rest of the software industry in XIP GUI development, releasing the Windows 3.1 ROM Development Kit in September of 1992 and, recently, the Modular Windows Development Kit in January of 1993. Both are XIP GUI implementations of the Windows GUI Operating System and are fully modularized for OEM configuration. Modularization assists OEMs by simplifying the streamlining of an O/S's suitability to task by allowing the OEM to choose which functions are important and required for a particular design and which functions can be left out. Benefits to the OEM are:

- Preserved API for using existing Windows applications or new application development
- Reduced development time and costs by using standard Windows application development tools and a wide choice of Windows software developers
- Ease of use for end-user

#### **Modular Windows**

Microsoft's Modular Windows Operating System uses a subset of the Windows 3.1 Operating System and includes extensions supporting TV-based multimedia players. Target market is home entertainment, but could easily be adapted for machine control on factory floors. The differences between Modular Windows and Windows 3.1 ROM are summarized below:

- Reduced support for the Windows 3.1 application programming interface (API)
- Reduced support for Windows 3.1 extension libraries
- New user-interface controls (instead of pull-down menus)
- New support for hand-control input devices

#### **Software Requirements:**

• MS-DOS 5.0 in XIP form

#### **System Requirements:**

- 80286 or greater CPU
- 1-MB RAM minimum
- 1 MB of XIP memory (flash, EPROM, or ROM)

Since the focus of this application note is personal computers, sub-notebooks and below, Modular Windows implementations will not be discussed. However, many of the principles of putting Modular Windows code in flash memory (memory maps, software tools, flash updateability, etc.) are the same here as the Windows 3.1 ROM example which is discussed later in this section.

#### Windows 3.1 ROM Version

Computers running Windows in ROM or XIP mode are very similar to standard PC running disk-based Windows. The only major exception is the presence of a large amount of XIP code storage in extended memory from which Windows executes, and a smaller amount of XIP code storage in adapter space. For the rest of this discussion, the Windows XIP code stored in extended memory is referred to as HIROM.BIN and the small amount of Windows XIP code stored in real mode space is referred to as LOROM.BIN.

Two modes of operation are possible for XIP Windows; "standard and enhanced," just as on disk-based PCs. However, each require different system resources for the XIP Windows version.

For standard mode, Windows executes fully in ROM, leaving almost all the system RAM available for user programs. This means that all Windows "core code" including DOSX.EXE, USER.EXE, GDI, the Windows kernel and all drivers run from XIP storage space. Also, all shell programs, applets, fonts and other Windows resources are stored in and run from XIP storage space without being loaded into RAM.

Enhanced mode Windows must execute partially from RAM. enhanced mode components such as WIN386.EXE and VxDs (virtual device drivers) must be loaded into RAM from some type of disk (a flash disk, ROM disk, or flash card) for execution, as their code writes back to their execution location from time to time and creates errors if loaded into XIP code storage such as flash memory. Components shared between modes, specifically USER.EXE, GDI, the kernel and drivers, continue to run from their stored locations in XIP address space.



Additionally, for either standard or enhanced modes, all Windows 3.1 features are supported in XIP Windows. The only limiting factors are the amounts of available RAM, XIP storage and, in the case of enhanced mode, disk space.

#### **Adding Applications**

The Windows 3.1 ROM Development Kit (RDK) can add any Windows executable program or application into the main XIP binary image file HIROM.BIN. The application must conform to the XIP application requirements specified in the Windows 3.1 Technical Specification. Microsoft is capable of supplying XIP versions of Word for Windows, Excel, Microsoft Mail and Microsoft Works but must be developed between an OEM and Microsoft on a platform-by-platform basis.

Once the O/S and application functionality is determined and the build script CONTENTS.ROM edited, the RDK produces two binary images: the large HI-ROM.BIN extended mode image containing O/S and application code, and the small "real mode" LO-ROM.BIN image containing the listing of all the XIP code contained in HIROM.BIN. After both XIP Windows binary files are loaded into flash memory and the system is up and running, clicking on an application causes the XIP Windows kernel to search its internal listing (LOROM.BIN) for an XIP image module first. If the image is not found within the XIP listing, the Windows kernel then searches the file paths present at runtime to try and load the application from its current file directories. If the program is not found within file directories, XIP Windows returns "Application missing, file not found." Additions of other extensions to the XIP image such as multimedia support and Pen Windows are added in a similar manner.

#### 2.6 XIP GUI Implementation

As mentioned earlier, XIP Windows requires two modules; a small amount of XIP storage in device adapter space called LOROM.BIN, and a larger amount of XIP storage called HIROM.BIN in extended memory space. The LOROM.BIN file contains information about the modules loaded in the HIROM.BIN XIP (see Figure 4) image and must be accessed in real mode by three modules, WIN.COM, RSWAP.EXE, and WIN386.EXE. Additionally, portions of the DOS extender (DOSX.EXE) must be able to run in real mode and are therefore located in the LOROM.BIN XIP image. The information the three modules look for is

contained in the ROM Table Of Contents (ROMTOC), also located in LOROM.BIN and contains general information about both XIP images (small and large), entry point addresses for initialization, and a list of the executables stored in the large XIP image.

The extended memory XIP image contains the bulk of the system's code and data segments, EXE headers, and a prototype Local Descriptor Table (LDT) which is a data structure defining the addresses, sizes and types of segments used by 80286, Intel386TM, or Intel486 processors. For more information on a Windows 3.1 XIP-based system, please refer to the Microsoft Windows 3.1 ROM Development Kit.



Figure 4. 16-Mbyte XIP GUI Memory Map

#### Software Requirements:

- MS-DOS 5.0 or equivalent in XIP mode
- Software Utility to load both small and large XIP images into flash memory
- For enhanced mode disk space requirements, MS Flash File System 2.0 combined with ExCA standard architecture software for a Resident Flash Disk.

3



#### **System Requirements:**

- 80286 CPU or greater
- RAM: Minimum of 1 MB for standard mode or 2 MB for enhanced mode
- XIP Store: Minimum of 2 MB for standard mode, 3+ MB for enhanced mode
- Flash Disk Store: Zero for standard mode, 2 MB for enhanced mode

For this particular design example, enhanced mode functionality is used to show a full implementation of Windows. An RFD is used to load WIN386.EXE, VxDs and all the \*.INI and \*.GRP files. A complete listing of the CONTENTS.ROM file used by the Windows ROM Image Builder utility to create an XIP Windows system is shown in Appendix C. The Windows RDK Enhanced Full sample CONTENTS.ROM file is used as a template and edited to locate the LOROM.BIN file at D8000h and is a total of 16 KB. The HIROM.BIN file is located at C00000h and is a total of 3.7 MB.

#### 2.7 Pen Extensions

Microsoft's Windows for Pen Computing is an extension to Microsoft Windows version 3.1 and has its own SDK. Pen Windows Extensions do not require any changes to existing Windows 3.1 applications and a selection of pen recognizer drivers come bundled in the SDK provide for fast development of a pen-based system. In particular, the Wacom PL-100V pen tablet and VGA graphics card can be added to an ISA bus slot for early debug and pen software development.

All the Pen Windows extensions are directly executable within the HIROM XIP image and can be added to the CONTENTS.ROM listing.

#### 3.0 HARDWARE

This section describes the general hardware requirements for an RFA design, then discusses a specific implementation using the Intel486 SX, FlashFile Memory (28F016SV) and an EPX780 PLD architecture as an example.

# 3.1 Resident Flash Disk Implementation

As stated in Section 2.3, the MS flash file system requires a hardware mapping window in adapter space that interfaces directly to flash memory. This window is similar in function to an EMS mapping window, but unlike EMS this window is configured via a Sliding Window Address Register located in the I/O space and has a fixed base address of DC000h and a fixed size of 16 KB. By setting the correct address in the register, the full 16-MB ISA memory address space is viewable in 16-KB increments.

The hardware requirements for the Flash Disk implementation are simply:

- A Window base address that appears in real mode memory somewhere in adapter space (C0000h to DFFFFh).
- 2. A Window size that is either 4, 8, 16, or 32 KB.

These two options provide a level of flexibility for an OEM's system implementation and reduces the memory footprint in adapter space.

The flash disk address mapping in Figure 5 shows the flash disk and ISA bus address maps together. The implemented sliding window scheme allows 16-KB blocks of the flash disk address space to be mapped into the real mode area from DC000h to DFFFFh for access by the MS flash file system.

For some ideas on how to implement an external logic flash disk implementation, see Intel Application Note-343, "Solutions for High Density Applications Using Flash Memory," order number 292079. The application note describes a complete design for an ISA Bus add-in card. A local bus design can be derived from the ISA Bus implementation or from design given in the Schematic Overview section.





Figure 5. Flash Disk Mapping

#### 3.2 XIP DOS Implementation

As stated in Section 2.2, DOS in Flash Implementation, MS-DOS 5.0 ROM Version is built assuming the E0000h segment location and also consists of a ROM Disk located in extended memory at FC0000h.

#### **ROM DOS Storage**

This design example uses Intel's 2 Mb, 28F200BX-T boot block flash memory. This device is organized with varying sized blocks starting with a 16-KB hardware locked boot block at the top of the device, followed by two 8 KB, separately erasable Parameter Blocks, then a separately erasable 96-KB block followed by a 128 KB code block. All the blocks except the boot block are erasable/programmable when V<sub>PP</sub> is high. The boot

block is unlocked by applying a second 12.0V input (in addition to Vpp) to the RP# pin, which allows programming and erasure within the boot block. The second 12.0V input guarantees hardware protection of the boot block code against unwanted or inadvertent programming or erasure. The benefit of using the boot block architecture is, that in the event something happens during a BIOS code update, the system can recover using the code within the locked boot block to bring up the system and initiate a BIOS code recovery from either the floppy drive, serial port or parallel port.

Using the 2-Mb (256-KB) device enables the design to use a single memory chip for four, separate code modules: a standard AT compatibility BIOS (64 KB), MS DOS 5.0 ROM (64 KB), Video BIOS (32 KB) and Power Management Code (16-32 KB). However, the sum of all four modules is greater than 128 KB, and if



mapped straight down from the top of the 1-MB DOS address space, would cover the BIOS space and all available adapter space, leaving no room for any additional upper memory space. Additionally, ROM DOS must be placed within adapter space at boot time so it can be scanned as an adapter ROM by the BIOS, and hook the INT 19h system boot call. To accommodate a 2-Mbit BIOS, this design physically places the 28F200BX-T at the top of the 1-MB ISA address map, and uses a paging mechanism created by using an XOR gate tied to the highest address bit of the 28F200BX-T. The other XOR gate input is a general purpose I/O line (GPIO) named FLIP#.

At system boot time, the FLIP# signal is defaulted to the Boot recovery mode (logic 0) placing the boot block at the top of the 1-MB address map shown in Figure 6, under Boot Recovery Configuration. The Boot recovery code first checks for valid video BIOS code by looking for a Video BIOS checksum. If the Video BIOS is valid, it is copied or shadowed to DRAM at C0000h to C7FFFh. If the Video BIOS is invalid, the Boot recovery code will initiate a Video BIOS update. The same scenario works for the power management code, it just gets copied to a different location in memory.

Next, to determine if a valid Basic AT BIOS is present, the Boot recovery code copies itself into DRAM, sets the FLIP# bit high placing the device in the Operating Configuration shown in Figure 6 with the Basic AT BIOS and MS-DOS ROM on top in the E0000h to FFFFFh memory map and the boot block positioned out of the E0000h-FFFFFh memory map. The recovery code then proceeds to check the Basic AT BIOS and ROM DOS code checksums. If valid, the recovery code starts the normal AT BIOS boot process and ROM DOS is scanned in as an adapter ROM during the Power-On Self Test or POST. If the Basic AT BIOS code is invalid, the BIOS recovery code indicates a BIOS update by beeping or some other OEM defined way. Next the recovery code determines if the ROM DOS code is valid. If it is not, the BIOS recovery code erases the whole block and initiates a BIOS plus ROM DOS update from either the serial port or parallel port and loads the BIOS code into the rest of the block. If the ROM DOS code is valid, the recovery code copies it into DRAM, erases the 128-KB block, copies the ROM DOS code back in and initiates a BIOS update just as

By taking advantage of the boot block's locked block architecture, a solid-state design can always accomodate a BIOS or ROM DOS code update without fear of making the system totally inoperable.

#### **ROM Disk Storage**

As stated earler, the ROM disk portion of MS-DOS 5.0 ROM Version uses some of the XIP GUI storage area consisting of Intel's 28F016SV FlashFile memory located at FC0000h (Figure 2). The ROM Disk portion required is about 256 Kbytes, and consists of CON-FIG.SYS and AUTOEXEC.BAT files, and all the PCMCIA software drivers. For a listing of contents of CONFIG.SYS and AUTOEXEC.BAT see Appendix C. The hardware needed to implement this is the same listed in Section 3.3, XIP GUI Implementation.

#### 3.3 XIP GUI Implementation

As stated earlier, Windows 3.1 ROM Version takes up about 3.6 MB of extended address space (HIROM.BIN) and 16 KB of real mode adapter address space (LOROM.BIN). HIROM.BIN can be located anywhere above 1 MB and should probably be high enough above the DRAM address space to allow additional DRAM to be added to the system by the end-user. Ideally, the system design should be able to cache the area where the Windows HIROM XIP code is located. This allows the system to take advantage of XIP code locality since XIP code should produce a very high cache hit ratio. Since the 28F016SV FlashFile memory is a x16 device, x32 access is accomplished by pairing two devices for a LOW Word/HIGH Word configuration. This creates an erasable block size of 128 KB.

The LOROM.BIN file has a couple of implementation options. One method is to use a spare block out of the extended memory XIP region. This method requires external logic to decode the specific adapter space address dedicated to the LOROM function, and generate a chipselect to the last block of flash memory. Since the LOROM.BIN file size is only 16 KB and the smallest erasable block size is 128 KB, 112 KB of the block is left unused. Given that the HIROM and LOROM files are updated together, the HIROM file could feasibly use the extra space if necessary.



Another option for the LOROM file is to use some free storage space within the 2-Mb boot block flash memory chip. The file could then be copied to the correct adapter space shadow RAM location at boot time. Copying the LOROM.BIN file can occur at the same time that Video BIOS and Power Management code are copied. This method provides update capability while reducing external logic requirements. The only hinge factor is

getting the system's BIOS code to copy the file before or during POST.

Either option is possible. The choice is dependent on determining which is easier, modifying hardware or modifying a BIOS boot-up process.



Figure 6. Boot Block Mapping



#### 3.4 RFA Control Logic Overview

This section describes the logic design for the RFA controller. Timing analysis is also provided to draw special attention to some of the difficulties and their resolutions. Lastly, a discussion of possible future enhancements is presented.

As shown in the block diagram, Figure 7, the EPX780 provides the interface between the CPU and the flash memory. The following components are utilized in this sub-system design:

- 25 MHz 3.3V 486 SX CPU
- Altera's EPX780-132 PLD
- 4 28F016SV-75 1M x 16-bit flash memory devices
- 32-bit Transceiver (4 x 8-bit or 2 x 16-bit, tpD < 15 ns)

The signal names used in the diagrams are described in Table 3



Figure 7. RFA Block Diagram



**Table 3. Signal Name Descriptions** 

| Signal name | Signal Description                                                   |
|-------------|----------------------------------------------------------------------|
| CLK         | Clock input to the subsystem, assumed 25 MHz                         |
| ADS#        | Address Strobe from the CPU                                          |
| W/R#        | Write/Read# signal from CPU                                          |
| M/i/o#      | Memory/i/o# signal from CPU                                          |
| D/C#        | Data/Code# signal from CPU                                           |
| WE#         | Write Enable# signal from EPX780 to flash memory                     |
| OE#         | Output Enable # signal from EPX780 to flash memory                   |
| RDY#        | Ready# signal from EPX780 to CPU                                     |
| KEN#        | Cache Enable# signal from EPX780 to CPU                              |
| DT/R#       | Data Transmit/Receive# signal from EPX780 to transceiver             |
| ABUSi       | Address Bus, A23-2 from CPU to EPX780                                |
| ABUSo       | Address Bus, A21-2 from EPX780 to flash memory                       |
| BSEL#       | Byte Enable # signals, BE0-3# from CPU to EPX780                     |
| CE#         | Chip Enable # signals, CEH0-1 # & CEL0-1 from EPX780 to flash memory |
| DBUS        | Data Bus, D31-0 from CPU to EPX780 and transceiver                   |
| FLASH DBUS  | Data Bus, D31-0 from transceiver to flash memory                     |
| ADSWREG     | Sliding Window Register select                                       |
| ADS14       | Address Strobe delay flip-flop chain                                 |
| SWREG       | Sliding Window Register                                              |

#### NOTE:

A "#" after the name means inverted or active low.

#### Logic Design

The logic design (see Figure 8) for the EPX780 RFA controller was split into the following three subdivisions from a design standpoint:

- Sliding Window Address Register interface
- ROM Stub Window mapping function
- Chip enable logic for memory devices

#### Sliding Window Address Register Interface

The necessary address decoding for the actual loading of the Sliding Window Address Register with the base address of the window on the data bus is done using a simple AND function. Similarly, allowing the address bits to propagate out of the register to the address bus upon access to the window is done using a 2x1 mux for each bit with the address decode as the select.



#### **ROM Stub Window Mapping Function**

This function is also implemented using 2x1 muxes. Here, one of the inputs to the mux is tied to the destination address. Since the two muxes are in series, they are combined into a single set of equations. These equations are minimized taking into account the constant address input to the second mux.

#### Chip Enable Logic

The chip enable logic and other control signals to the flash devices are first implemented simply from a functional perspective. The timing accuracy for this logic is derived via a flip-flop chain transferring the ADS# pulse for three clocks, thus allowing for the four clock read cycle. The equations for the KEN# and the RDY# are generated after determining the timing of the other signals.

#### Byte Writes

In the current implementation, BYTE# is tied high, putting the 28F016SV into x16 mode. In this mode, the flash devices will only accept word writes. Byte writes to the flash array requires software to write an [FFh] to the unused byte in order to prevent the corruption of data. When verifying the byte write it will then be necessary to ignore the unused byte after reading in the corresponding word.

#### **Timing Analysis**

All the signals are analyzed for timing accuracy. Since the flow of information is initiated by the ADS pulse, a three flip-flop chain is connected to the ADS line. This chain-stores the state of the machine. The state is then used in all the enable equations and in the two signals that talk to the CPU (KEN# and RDY#). The two signals, the KEN# and the RY/BY# require further attention. The KEN# is generated but only for code read access to the flash disk or XIP. The RY/BY# is actually not implemented in the EPX780. It is suggested that the system designer simply tie the RY/BY# to an interrupt line on the CPU or poll the flash device for the status of the Write or the Erase operation.

Timing diagrams for the resulting design are shown in Figures 9, 10 and 11 for the register load cycle, a flash read cycle and a flash write cycle. The register load cycle requires 2 clocks, the memory read requires 4 clocks while the write cycle requires 4 clocks for command plus 4 for each word written. The acknowledgment for the write from the flash device is in the form of an interrupt to the CPU via the RY/BY# line.

#### Enhancing the Design

The design is implemented to optimize the power usage and thus uses the 3.3V Intel486 SX CPU, a low power CMOS transceiver and the 28F016SV-75. For a higher performance design, a 5.0V Intel486 SX CPU and 28F016SV-65 memory can be used. Similar 5.0V transceivers are also available. The transceivers specified in the diagram are high speed devices with typical delays of about 5-6 ns; however, a 15 ns delay is allowed for in the design of the interface, so higher performance designs may be utilized. With 5.0V operation it is possible to eliminate one wait state during the read and write cycle. However, a complete timing analysis would be required.

The EPX780 has 102 I/O and 2 clock pins of which 81 are used by the current design. Also available are 80 macrocells, of which 50 are utilized by the RFA design.

Further enhancements to the design can easily be implemented using the remaining cells and I/Os in the EPX780. Possible improvements include making the window size, as well as the base address of the window in the lower 1-MB space user-definable. The ROM Windows Stub window can also be converted to a more flexible mapping. The remaining resources on the PLD allow the designer to customize the design to the needed requirements.



Figure 8. Logic Diagram

The logic for the Sliding Window, the ROM Stub Window and the Chip Enable functions in the EPX780 RFA controller is shown here along with the flash configuration.





Figure 9. Sliding window Register Load Cycle

The signals from the CPU transition between 3 ns and 20 ns after the clock. There is a 10 ns delay for the logic to propagate through the EPX780 to prepare for latching the data on D9-0 (DBUS). In the next clock, the ADS# is deasserted by the CPU, and the RDY# is asserted by the EPX780. During the clock that the CPU latches the RDY# signal, the data is latched by the EPX780. Thus, RDY# is asserted before the EPX780 latches the data and the operation requires only two clock cycles.

Note: Black areas indicate don't care. Grey areas indicate propagation delay.





Figure 10. Flash Memory Read Cycle

In this cycle, the flash memory will guarantee data on the flash data bus 75 ns after the control signals are presented. The control signals are guaranteed valid after 30 ns. Thus the data from the flash memory is guaranteed to be on the CPU's data bus after 120 ns allowing for a 15 ns transceiver delay. Since this particular read cycle is a code memory read cycle, the KEN# is asserted during the third clock so the CPU can latch it in the fourth clock. The RDY# is asserted exactly one cycle after the KEN#, thus allowing for the CPU to latch the data on the rising edge of the fifth clock following the request.





Figure 11. Flash Memory Write Cycle

The write cycle is actually composed of two separate write requests. The first is a "write" command presented on the data bus while the WE# is asserted and the chip enable is valid. The second bus cycle transfers the actual address and data to be written. In the write cycle, the RDY# is latched on the rising edge of the fifth clock. The write completion is signaled by the RY/BY# output of the flash memory which should be connected to an interrupt line on the CPU.



#### 4.0 SOFTWARE UTILITIES

#### 4.1 Diagnostic

It is highly recommended that system designers develop simple diagnostic tools to test the hardware at a very low level (i.e., Write Byte, Write Word, Read Word, Erase Block). Such a tool proves invaluable when debugging new hardware and software designs and resolving hardware and software conflicts.

#### 4.2 Binary Loader

The RFA Binary files HIROM.BIN, LOROM.BIN, and ROM Disk must all be loaded into protected mode from real mode. This can be accomplished a number of ways:

- Use a DOS Extender. This provides a quick method to create a utility using the tools a DOS Extender provides. However, licensing may prove to be difficult or expensive.
- Using BIOS-based extended memory calls. These actually worked quite nicely and reliably, but proved to be slow and doubled the time to erase and program HIROM.BIN.
- Use XMS Calls. This method depends on the existence of the MS-DOS file HIMEM.SYS to access the XMS handler, and was the fastest of all.

For lab testing, our binary loader used a simple file name plus command line parameters. A system for endusers would need a more elaborate user interface to guide them through the software update. Some basic software requirements outside of the basic file Read/ Write capabilities and command line parsing for the flash memory Binary Loader are:

- Incorporate basic flash memory program and erasure commands. These software drivers are available for both ASM86 and "C" in Intel's Application Note-360, "28F016SA FlashFile<sup>TM</sup> Software Drivers," order number 292095. This application note addresses things like read device identifier, Vpp ramp time, x8 and x16 parallel programming and block erasure by providing proven, tested routines for each.
- Choose a method of protected mode access that makes the most sense for you.
- Allow for specific base addresses to be entered by the user, while within the program automatically determining what block and the number of blocks to be erased from the base address and binary file size.

#### 5.0 SUMMARY

This application note discussed a new system architecture based on solid-state software and hardware design concepts. This new architecture is based on using flash memory for the following; BIOS + DOS code storage, a nonvolatile RAM disk or RFD, and as XIP GUI code storage or RFX. Specific flash memory component and PCMCIA card information is found in their respective data sheets. Contact your local Intel or distribution sales office for more information or to obtain assistance in evaluating boot block or FlashFile memory components, as well as Intel's product line of PCMCIA flash memory cards.



#### 6.0 ADDITIONAL INFORMATION

| Order Number | Document                                                                          |
|--------------|-----------------------------------------------------------------------------------|
| 292092       | AP-357 "Power Supply Solutions for Flash Memory"                                  |
| 292094       | AP-359, "28F008SA Hardware Interfacing"                                           |
| 292095       | AP-360, "28F008SA Software Drivers"                                               |
| 292097       | AP-362, "Implementing Mobile PC Designs Using High Density FlashFile™ Components" |

# APPENDIX A MS-DOS ROM IMAGE DESCRIPTION

RFA ROM DOS Description File # ROM image description file for 64K of ROM space at E0000-EFFFF and one 256K ROMDISK module at F90000 # Actual file sizes created: Three 32K modules ROM1=Int 19 hook and Resident DOS Code ROM1SIZE=8000 ROM1MAX=7FFF ROMITYPE=SEG ROM1ADDR=E000 ROM1CHKSUM=YES ROM1NUMBLOCKS=40 ROM1FILES=..\romhead\romboot.bin ..\dos\resdos.16 ROM2=COMMAND ROM Hdr Res. BIOS Code Bootstrap loader Resident Command Code ROM2SIZE=8000 ROM2MAX=7FFF ROM2TYPE=SEG ROM2ADDR=E800 ROM2CHKSUM=YES ROM2NUMBLOCKS=40 ROM2FILES=..\cmd\command\romhead.bin ..\bios\resbio.16 \ ..\romload\romload.sys ..\cmd\command\rescom.16 ..\dos\romdos.sys ROM3=Command interpreter ROM3SIZE=10000 ROM3MAX=FFFF ROM3TYPE=BASE ROM3ADDR=F90000 ROM3FILES=..\cmd\command\command.16 ..\bios\rombio.sys 292149-12

3



# APPENDIX B ROMDISK CONFIG.SYS AND AUTOEXEC.BAT

#### AUTOEXEC.BAT

@echo off
prompt \$P\$G
set path=c:\:\d:\rdk10\build\disk;d:\utils;d:\diags;
c:\doskey
doskey d=dir \$1 \$2
d:\rdk10\build\disk\smartdrv.exe 1024 1024
set TEMP=d:\
ver /r
echo "MS-DOS ROM, Card & Flash Disk SS 2.0, MS FlashFile System 2,"
echo "and Windows 3.1 ROM "

#### **CONFIG.SYS**

Device=C:\mti2p.exe Device=C:\ms-flash.sys Device=C:\cardid.exe

292149-13



# APPENDIX C WINDOWS 3.1 CONTENTS.ROM

NOTE: Semi-colons denote a commented-out line which is NOT added to the HIROM Binary file.

: Windows 3.1 ROM Development Kit (RDK) 1.0

; Sample ROM Description File

; Copyright Microsoft Corporation, 1992

; Enhanced Mode, Full

; 10/20/92 Removed TT Fonts

#### ROMS

; Specifies length of ROMs and the linear addresses

; at which they are to appear.

; Name Address Length (max)

LoROM 0C8000 004000 ; 16k

HiROM C00000 390000 ; 3.7 MB

#### **TABLES**

; Specifies information for tables to reside in ROM.

ROMTOC 100 LoROM

; ROMTOC entries

NUMFILENT 14 LDT 1024 HiROM 256 ; FILES entries

: WINFLAGS 13

; Local Descriptor Table ; 286 version; Value is in HEX

WINFLAGS 15

; 386 version; Value is in HEX

; SYSDIR system

; Windows directory on disk (optional)

ROMVERSION 1000

; 1 = masked ROM, 000 = OEM version

#### MODULES

; Specifies modules to be loaded into ROM.

; Format is as follows:

; Module SEG File ROM Flags Comments

292149-14



| ; Kernel                                                                                                                                                                                      | :<br>                               |                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| ; KERNEL.EXE %ROMFILES%krnl286.exe<br>KERNEL.EXE %ROMFILES%krnl386.exe                                                                                                                        | HIROM<br>HIROM<br>HIROM<br>HIROM    | EXEHDR ; Std mode MS-DOS extender<br>; DXDGROUP - Copy from ext with INT 15h<br>; DXPMCODE<br>; 286 kernel<br>; 386 kernel (ROM version) |
| ; Drivers (Replaceable)                                                                                                                                                                       |                                     |                                                                                                                                          |
| SYSTEM.DRV %ROMFILES%system.drv<br>KEYBOARD.DRV %ROMFILES%keyboard.drv<br>SEG 10 COMP                                                                                                         |                                     | ; System<br>; Keyboard<br>; Do not remove!<br>; Display                                                                                  |
| ; VGAROM2.DRV %ROMFILES%vgarom2.drv<br>VGAROM3.DRV %ROMFILES%vgarom3.drv<br>; SVGAR2.DRV %ROMFILES%svgar2.drv<br>; SVGAR3.DRV %ROMFILES%svgar3.drv                                            | HiROM                               | ; 286 VGA<br>; 386 VGA<br>; 286 SuperVGA<br>; 386 SuperVGA                                                                               |
| MOUSE.DRV %ROMFILES%mouse.drv<br>SEG 2 RAM COMP NORELOC<br>; NOMOUSE.DRV %ROMFILES%nomouse.drv                                                                                                |                                     | ; Mouse<br>; Do not remove!<br>; No mouse                                                                                                |
| COMM.DRV %ROMFILES%comm.drv<br>SEG 2 RAM COMP NORELOC<br>SEG 3 COMP                                                                                                                           | HiROM                               | ; COM, LPT<br>; Do not remove!<br>; Do not remove!                                                                                       |
| MMSOUND.DRV %ROMFILES%mmsound.drv                                                                                                                                                             | HiROM                               | ; Sound                                                                                                                                  |
| ; Core                                                                                                                                                                                        |                                     |                                                                                                                                          |
| GDI.EXE %ROMFILES%gdi.exe USER.EXE %ROMFILES%user.exe SEG 3 RAM COMP NORELOC                                                                                                                  |                                     | ; ROM version<br>; ROM version<br>; Do not remove!                                                                                       |
| ; Non-Replaceable System DLLs                                                                                                                                                                 |                                     | ·                                                                                                                                        |
| SHELL.DLL %ROMFILES%shell.dll<br>LZEXPAND.DLL %ROMFILES%lzexpand.dll<br>WIN87EM.DLL %ROMFILES%win87em.dll                                                                                     | HiROM<br>HiROM<br>HiROM             | ; Shell APIs<br>; Expansion<br>; Math emulator                                                                                           |
| ; Replaceable System DLLs                                                                                                                                                                     |                                     | -                                                                                                                                        |
| COMMDLG.DLL %ROMFILES%commdlg.dll OLECLI.DLL %ROMFILES%olecii.dll OLESVR.DLL %ROMFILES%olesvr.dll TOOLHELP.DLL %ROMFILES%toolhelp.dll DDEML.DLL %ROMFILES%ddeml.dll VER.DLL %ROMFILES%ver.dll | HiROM STU<br>HiROM STU<br>HiROM STU | B ; OLE Client B ; OLE Server B ; Tool Help DLL                                                                                          |
| ; Multimedia Extensions                                                                                                                                                                       |                                     |                                                                                                                                          |
| MMSYSTEM.DLL %ROMFILES%mmsystem.dl<br>SND.CPL %RETAIL%snd.cpl<br>MPLAYER.EXE %RETAIL%mplayer.exe<br>SOUNDREC.EXE %RETAIL%soundrec.exe                                                         | HiROM                               |                                                                                                                                          |
|                                                                                                                                                                                               |                                     |                                                                                                                                          |



| ; Advanced Power Management (APM)                                                                                                                                                                      | •••••                                                                         |                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| ; POWER.DRV %RETAIL%power.drv                                                                                                                                                                          | HiROM                                                                         | ; APM driver                                                                                               |
| ; Shell Programs                                                                                                                                                                                       |                                                                               |                                                                                                            |
| PROGMAN.EXE %RETAIL%progman.exe WINFILE.EXE %RETAIL.%winfile.exe TASKMAN.EXE %RETAIL%taskman.exe WINHELP.EXE %RETAIL.%winhelp.exe WINTUTOR.EXE %RETAIL.%wintutor.exe                                   | HIROM<br>HIROM<br>HIROM<br>HIROM<br>HIROM                                     | ; Program Mgr<br>; File Manager<br>; Task Manager<br>; Windows Help<br>; Tutorial                          |
| ; Control Panel                                                                                                                                                                                        |                                                                               |                                                                                                            |
| DRIVERS.CPL %RETAIL%drivers.cpl<br>MAIN.CPL %ROMFILES%main.cpl<br>CONTROL.EXE %RETAIL%control.exe                                                                                                      | HiROM<br>HiROM<br>HiROM                                                       | ; Drivers icon<br>; Main icons<br>; Control Panel                                                          |
| ; Printing Support                                                                                                                                                                                     |                                                                               |                                                                                                            |
| ; PRINTMAN.EXE %RETAIL%printman.exe<br>; UNIDRV.DLL %ROMFILES%unidrv.dll<br>; DMCOLOR.DLL %ROMFILES%dmcolor.dll                                                                                        | HiROM<br>HiROM<br>HiROM                                                       | ; Print Mgr<br>; Uni driver<br>; Uni driver                                                                |
| ; System Fonts                                                                                                                                                                                         |                                                                               |                                                                                                            |
| VGASYS.FON %RETAIL%vgasys.fon<br>VGAFIX.FON %RETAIL%vgafix.fon<br>VGAOEM.FON %RETAIL%vgaoem.fon                                                                                                        | HiROM<br>HiROM<br>HiROM                                                       | ; System (VGA)<br>; Fixed pitch<br>; OEM                                                                   |
| ; Bitmap Fonts                                                                                                                                                                                         |                                                                               |                                                                                                            |
| COURE.FON %RETAIL%coure.fon<br>SERIFE.FON %RETAIL%serife.fon<br>SMALLE.FON %RETAIL%smalle.fon<br>SSERIFE.FON %RETAIL%sserife.fon<br>SYMBOLE.FON %RETAIL%symbole.fon                                    | HIROM<br>HIROM<br>HIROM<br>HIROM<br>HIROM                                     | ; Courier (VGA) ; MS Serif (VGA) ; Small (VGA) ; MS Sans Serif (VGA) ; Symbol (VGA)                        |
| ; Plotter Fonts                                                                                                                                                                                        |                                                                               |                                                                                                            |
| MODERN.FON %RETAIL%modern.fon<br>ROMAN.FON %RETAIL%roman.fon<br>SCRIPT.FON %RETAIL%script.fon                                                                                                          |                                                                               |                                                                                                            |
| ; TrueType Fonts                                                                                                                                                                                       |                                                                               | -                                                                                                          |
| ; COUR.FOT %RETAIL%cour.fot<br>; COURBD.FOT %RETAIL%courbd.fot<br>; COURBI.FOT %RETAIL%courbi.fot<br>; COURI.FOT %RETAIL%couri.fot<br>; SYMBOL.FOT %RETAIL%symbol.fot<br>; TIMES.FOT %RETAIL%times.fot | HIROM<br>HIROM<br>HIROM<br>HIROM<br>HIROM<br>HIROM<br>HIROM<br>HIROM<br>HIROM | ; Courier New ; Courier New Bold ; Courier New Bold Italic ; Courier New Italic ; Symbol ; Times New Roman |
| ; TIMESBD.FOT %RETAIL%timesbd.fot                                                                                                                                                                      | HiROM                                                                         | ; Times New Roman Bold 292149-16                                                                           |



| ; TIMESBI.FOT %RETAIL%timesbi.fot<br>; TIMESI.FOT %RETAIL%timesi.fot<br>WINGDING.FOT %RETAIL%wingding.fot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HiROM<br>HiROM<br>HiROM                                                                                           | ; Times New Roman Bold Italic<br>; Times New Roman Italic<br>; WingDings                                                                             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| ; MS-DOS App Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                   |                                                                                                                                                      |
| VGA.3GR %RETAIL%vga.3gr<br>WINOLDAP.MOD %RETAIL%winoldap.mod<br>SEG 2 RAM COMP NORELOC<br>WINOA386.MOD %RETAIL%winoa386.mod<br>SEG 1 RAM COMP NORELOC<br>SEG 2 RAM COMP NORELOC<br>SEG 5 RAM COMP NORELOC                                                                                                                                                                                                                                                                                                                                                                                           | HiROM<br>HiROM<br>HiROM                                                                                           | ; Enh mode grabber ; Std mode MS-DOS app support ; Do not remove! ; Enh mode MS-DOS app support ; Do not remove! ; Do not remove! ; Do not remove!   |
| DOSAPP.FON %RETAIL%dosapp.fon<br>EGA80WOA.FON %RETAIL%ega80woa.fon<br>EGA40WOA.FON %RETAIL%ega40woa.fon<br>CGA80WOA.FON %RETAIL%ega80woa.fon<br>CGA40WOA.FON %RETAIL%cga40woa.fon                                                                                                                                                                                                                                                                                                                                                                                                                   | HiROM<br>HiROM<br>HiROM<br>HiROM<br>HiROM                                                                         | ; MS-DOS app window fonts                                                                                                                            |
| ; Applets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                   |                                                                                                                                                      |
| CALC.EXE %RETAIL%calc.exe CALENDAR.EXE %RETAIL%calendar.exe CARDFILE.EXE %RETAIL.%cardfile.exe CHARMAP.EXE %RETAIL%charmap.exe CLIPBRD.EXE %RETAIL%clipbrd.exe CLOCK.EXE %RETAIL%clock.exe NOTEPAD.EXE %RETAIL.%notepad.exe PACKAGER.EXE %RETAIL.%packager.exe PBRUSH.DLL %RETAIL.%pbrush.dll PBRUSH.EXE %RETAIL.%pbrush.exe PIFEDIT.EXE %RETAIL.%pifedit.exe RECORDER.DLL %RETAIL.%pifedit.exe RECORDER.EXE %RETAIL.%recorder.dll RECORDER.EXE %RETAIL.%recorder.exe SOL.EXE %RETAIL.%sol.exe ; TERMINAL.EXE %RETAIL.%terminal.exe WINMINE.EXE %RETAIL.%winmine.exe WRITE.EXE %RETAIL.%winmine.exe | HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM HIROM | ; Notepad applet ; Packager applet ; for Paintbrush ; Paintbrush ; Pif Editor ; for RECORDER.EXE ; Recorder ; Solitaire ; Terminal ; WinMine ; Write |
| ; Applications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                   |                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                   |                                                                                                                                                      |
| FILES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                   |                                                                                                                                                      |
| ; Specifies optional files to be installed into ROM.<br>; TrueType TTF font files are specified in this sect<br>;<br>; ROM Name Path ROM                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                   |                                                                                                                                                      |
| ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                   |                                                                                                                                                      |
| ; TrueType Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                   | <del></del>                                                                                                                                          |
| ARIAL.TTF %RETAIL%arial.ttf ARIALBD.TTF %RETAIL%arialbd.ttf ARIALBI.TTF %RETAIL%arialbi.ttf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | HiROM<br>HiROM<br>HiROM                                                                                           | ; Arial<br>; Arial Bold<br>; Arial Bold Italic                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                   | 292149–17                                                                                                                                            |



| ARIALITTF %RETAIL%ariali.ttf      | HiROM | ; Arial Italic                |
|-----------------------------------|-------|-------------------------------|
| : COUR.TTF %RETAIL%cour.ttf       | HiROM | ; Courier New                 |
| COURBD.TTF %RETAIL%courbd.ttf     | HiROM | ; Courier New Bold            |
| COURBITTF %RETAIL%courbi.ttf      | HiROM | ; Courier New Bold Italic     |
| : COURI.TTF %RETAIL%couri.ttf     | HiROM | ; Courier New Italic          |
| ; SYMBOL.TTF %RETAIL%symbol.ttf   | HiROM | ; Symbol                      |
| : TIMES.TTF %RETAIL%times.ttf     | HiROM | ; Times New Roman             |
| : TIMESBD.TTF %RETAIL%timesbd.ttf | HiROM | ; Times New Roman Bold        |
| : TIMESBI.TTF %RETAIL%timesbi.ttf | HiROM | ; Times New Roman Bold Italic |
| : TIMESI.TTF %RETAIL%timesi.ttf   | HiROM | ; Times New Roman Italic      |
| WINGDING.TTF %RETAIL%wingding.ttf | HiROM | ; WingDings                   |
|                                   |       | 292149-18                     |
|                                   |       | 252145-10                     |



#### APPENDIX D PLD EQUATIONS

Included below are the equations for the EPX780.

#### EPX780-10 PLD

```
; Functional model for Simulation of Resident Flash Array design
Title
        486SX RFA design
Pattern
Revision 4.0
         Rajiv Parikh
Author
           Intel Corporation
Company
        9/20/94
Date
OPTIONS DRIVE_LEVEL = 3VOLT; Default voltage is 3 Volts
              NFX780_132
CHIP UI
; Pinlist
; inputs
PIN
           CLK
                            ; main clock (used by register)
; Control signals from CPU
PIN
                            : Write/Read# from CPU
            W_R
                            ; M/i/o# from CPU
PIN
           M IO
           /ADS
                            ; ADS# from CPU
PIN
                            ; D/C# from CPU
PIN
           D_C
                            ; Address lines from CPU, 0,1,24-31 not used
PIN
            A[23:2]
PIN
           /BE[3:0]
                            ; Byte Enable lines from CPU
; Control signals from PLD to memory
; outputs
           B[23:2]
                            ; Address lines out of PLD to memory (23,22 NC)
PIN
PIN
           /CEH[1:0]
                            ; Chip enable out of PLD to memory high word
PIN
           /CEL[1:0]
                            ; Chip enable out of PLD to memory low word
PIN
           /WE
                            ; Write Enable# from PLD to memory
PIN
           OE/
                            ; Output Enable# from PLD to memory
; Other signals
; input
PIÑ
           RY_BY
                            ; Ready/Busy# from memory to PLD/486
; outputs
PIN
            /RDY
                            ; Ready# from PLD to CPU
                            ; Cache enable# from PLD to CPU
PIN
           /KEN
                                                                                         292149-19
```



DT R ; DT/R# signal from PLD to Transceiver PIN ; Data signals - only 10 bits go into the PLD. ; inputs PIN D[9:0] : Data bus from CPU to PLD R[9:0] REGFBK NODE NODE IO17 ADSWREG1 ;pin#s required for prioritizing in v3.1 NODE IO39 ADSWREG2 NODE ADS1 REGFBK ; Registers in the ads delay chain ADS2 REGFBK NODE NODE ADS3 REGFBK STRING SUBSTITUTIONS STRING EN '((ADS+ADS1+ADS2+ADS3)\*M\_IO)' ; Memory access enable STRING WESW '( W\_R \* /M\_IO \* D\_C \* ADS1)' ; Write Enable for sliding window reg. ;STRING SWAD '( /A23 \* /A22 \* /A21 \* /A20 \* SWAD shows address of sliding window's /A19 \* /A18 \* /A17 \* /A16 \* I/O register (not used in equations) A15 \* A14 \* /A13 \* A12 \* A11 \* A10 \* /A9 \* /A8 \* /A7 \*/A6 \*/A5 \* /A4 \* /A3 \*/A2 )' STRING ADSWREG '(ADSWREG1\*ADSWREG2)' ; Select sliding window register STRING OESW '(EN \* : Output Enable for sliding window reg. /A23 \* /A22 \* /A21 \* /A20 \* ; address 0DC000h - 0DFFFFh A19 \* A18 \* /A17 \* A16 \* A15 \* A14)' STRING WSME '(EN \* ; MS Windows Stub Window Enable

#### **EQUATIONS**

; Setup register

; address decode logic - comparators

/A23 \* /A22 \* /A21 \* /A20 \*

A19 \* A18 \* /A17 \* A16 \*

A15 \* /A14 )'

ADSWREG1.CMP = [A23,A22,A21,A20,A19,A18,A17,A16,A15,A14,A13,A12]==[GND,GND,GND,GND,GND,GND,GND,VCC,VCC,GND,VCC] ADSWREG2.CMP = [A11,A10,A9, A8, A7, A6, A5, A4, A3, A2]

292149-20

: address 0D8000h - 0DBFFFh



```
==[VCC,VCC,GND,GND,GND,GND,GND,GND,GND,GND]
; Data bus feeds the register upon selection
R[9:0].D := (ADSWREG *WESW) * D[9:0] + (/WESW+/ADSWREG) * R[9:0]
R[9:0].CLKF = CLK
; Setup the ADS delay chain
 ADS1.D := ADS
 ADS1.CLKF = CLK
 ADS2.D := ADS1 * (OE + WE)
 ADS2.CLKF = CLK
 ADS3.D := ADS2
 ADS3.CLKF = CLK
; Output address
 B23 = WSME + /WSME * (OESW * R9 + /OESW * A23)
 B22 = WSME + /WSME * (OESW * R8 + /OESW * A22)
 B21 = WSME + /WSME * (OESW * R7 + /OESW * A21)
 B20 = WSME + /WSME * (OESW * R6 + /OESW * A20)
 B19 = WSME + /WSME * (OESW * R5 + /OESW * A19)
          /WSME * (OESW * R4 + /OESW * A18)
 B18 =
          /WSME * (OESW * R3 + /OESW * A17)
 B17 =
 B16 = WSME + /WSME * (OESW * R2 + /OESW * A16)
                                                          ; 1
 B15 = WSME + /WSME * (OESW * R1 + /OESW * A15)
                                                          : 1
          /WSME * (OESW * R0 + /OESW * A14)
                                                          ; 0
                                                          ; pass through
 B[13:2] = A[13:2]
; chip enable for each of four chips
                                                          ; two pairs of high and
 CEH0 = EN * (B23 * /B22) * (BE3 + BE2)
 CEH1 = EN * ( B23 * B22) * (BE3 + BE2)
                                                          low words
 CEL0 = EN * (B23 * /B22) * (BE1 + BE0)
 CEL1 = EN * (B23 * B22) * (BE1 + BE0)
                                                          ; OE# for mem
 OE = EN * /W_R
  WE = M_IO * W_R * (ADS1 + ADS2)
                                                          ; WE# for mem
                                                                                292149-21
```



```
DT R = /M_IO + W_R + /(ADS1 + ADS2 + ADS3)
                                                         ; Tranceiver signal
 RDY = WESW
                                                         ; After reg loading
    +/W R * M IO * ADS3
                                                         ; after reading
    + W_R * M_IO * ADS3
                                                         ; after writing
 KEN = /W R * /D_C * M_IO * ADS2
                                                         : cache code reads only
: Simulation section
SIMULATION
VECTOR DBUS := [ D9 D8 D7 D6 D5 D4 D3 D2 D1 D0 ]
VECTOR ABUSI:= Î A23 A22 A21 A20 A19 A18 A17 A16 A15 A14 A13 A12 A11 A10 A9 A8 A7 A6
A5 A4 A3 A2 ]
VECTOR ABÚSO:= [ B23 B22 B21 B20 B19 B18 B17 B16 B15 B14 B13 B12 B11 B10 B9 B8 B7 B6 B5
B4 B3 B2 1
VECTOR BSEL := [ BE3 BE2 BE1 BE0 ]
VECTOR CE := [ CEH1 CEH0 CEL1 CEL0 ]
VECTOR SWREG:= [ R9 R8 R7 R6 R5 R4 R3 R2 R1 R0 ]
; Specify signals to be traced.
TRACE_ON CLK W_R M_IO ADS D_C DBUS ABUSI ABUSO BSEL CE SWREG WE OE
RY_BY RDY KEN DT_R ADSWREG1 ADSWREG2
;Initialize inputs
SETF CLK W_R M_IO /ADS D_C /RY_BY ABUSI := 0X00000 BSEL := 0X0 DBUS := 0X000
PRLDF /R9 /R8 /R7 /R6 /R5 /R4 /R3 /R2 /R1 /R0
; Idle clocks
CLOCKF CLK
CLOCKF CLK
; Do a read from memory of two 32-bit words at 800000h
FOR READ2_32 := 0x200000 TO 0x200001 DO
  BEGIN
  SETF ABUSI := READ2_32 /W_R ADS
                                                : Validate Address
  CLOCKF CLK
                                                ; Remove ADS
  SETF/ADS
  CLOCKF CLK
  CLOCKF CLK
  CLOCKF CLK
  CLOCKF CLK
  END
                                                                                292149-22
```



; Sliding window load and read test:

; Write address 0X800000 in swreg then try to read from window

SETF DBUS := 0X200 ABUSI := 0X03700 ; 0X0DC00 >> 2 ; Validate Address

SETF/M\_IO W\_R ADS

CLOCKF CLK

SETF/ADS

**CLOCKF CLK** 

CLOCKF CLK **CLOCKF CLK** 

CLOCKF CLK SETF M\_IO /W\_R /D\_C ADS ABUSI := 0X037000

CLOCKF CLK

SETF/ADS

**CLOCKF CLK CLOCKF CLK** 

CLOCKF CLK

; now test the win stub mapping SETF ABUSI := 0X36000

SETF ADS /W\_R BSEL := 0X0

CLOCKF CLK SETF/ADS

CLOCKF CLK

CLOCKF CLK

; DONE!!! TRACE\_OFF

; set to memory CODE read

; Remove ADS

; Remove ADS

; read code! see cache line,etc

; 0X0D8000 >> 2

; Validate Address

: Remove ADS

292149-23



### ENGINEERING REPORT

# The Intel 28F008SA Flash Memory

ALAN BUCHECKER
JERRY KREIFELS
MEMORY COMPONENTS DIVISION

October 1993

## The Intel 28F008SA Flash Memory

| CONTENTS PAGE                                                |
|--------------------------------------------------------------|
| DEVICE CHARACTERIZATION 3-79                                 |
| AC and DC Parameters 3-79;<br>Energy/Power Consumption 3-79; |
| Byte-Write/Block-Erase Times 3-79                            |
| DEVICE RELIABILITY 3-79                                      |
| Data Protection                                              |
| <b>SUMMARY</b> 3-79                                          |
| OTHER REFERENCES 3-798                                       |
| <b>SUPPLEMENTARY INFORMATION</b> 3-794                       |
|                                                              |
|                                                              |
|                                                              |
|                                                              |
|                                                              |



#### INTRODUCTION

The ETOX III (EPROM tunnel oxide) 28F008SA is a high-density product offering from Intel's second generation of flash memory devices. This 1,048,576 x 8 memory with its symmetrical blocking (16 blocks x 64 Kbytes), very high cycling endurance, on-chip write/erase automation, and erase-suspend/resume capability can be termed a block-alterable non-volatile RAM. In addition to selective block erasure, integrated Command User Interface (CUI), Write State Machine (WSM), Status Register, and deep power-down capability, the 28F008SA adds a dedicated READY/BUSY output (RY/BY #). This new feature provides immediate hardware signaling of byte-write/block-erase completion and erase-suspend/resume actuation.

Flash memories combine inherent non-volatility with in-system alterability of device contents. Advances in process control have allowed development of a double-polysilicon single-transistor flash memory capable of 100,000 write/erase cycles per block. The 28F008SA electrically erases all bits in a block via electron tunneling. The EPROM programming mechanism of hotelectron injection is employed for high-performance electrical byte write as required for file and data storage applications.

The Command User Interface and Status Register interface to power-up/down protection, address/data latches, and the Write State Machine (which in turn controls internal byte write, block erase, cell-margin circuits, and the dedicated READY/BUSY status output). These features augment prior flash memory circuitry to optimize Intel's 28F008SA for microprocessor-controlled byte write and block erase.

Read timing parameters are comparable to those of CMOS DRAMs, SRAMs, EPROMs, and EEPROMs. The 85 ns access time results from a memory cell-current of approximately 70  $\mu$ A, low-resistance polysilicide wordlines strapped with metal, advanced scaled periphery transistors, and an optimized data-out buffer.

The dense one-transistor cell structure, coupled with high array efficiency, yields a one-megabyte die measuring 539 by 286 mils.

#### **TECHNOLOGY OVERVIEW**

Intel's ETOX III flash memory technology incorporates advances from ETOX I and ETOX II processes and leverages over two decades of EPROM manufacturing experience. Using advanced 0.8  $\mu$ m double-polysilicon N-well/P-well CMOS technology, the 1,048,576 x 8-bit flash memory employs a 2.5  $\mu$ m x 2.9  $\mu$ m single-transistor cell affording array density equivalent to comparable EPROM technology, and twice that of Intel's ETOX II process. The ETOX III flash memory cell is identical to EPROM, with an additional source implant which optimizes erase performance. Figure 1 shows a cross-section of the flash memory cell.

High-quality tunnel oxide under the single floating polysilicon gate promotes electrical erasure. All cells within the selected block are simultaneously erased via Fowler-Nordheim tunneling. Applying 12V to block source junctions and grounding the control gates erases all cells within that block. The internal WSM controls the automated block-erase algorithm, including preerase conditioning (i.e., pre-programming all block bits) and margin verification, in response to user requests relayed by the CUI. WSM-controlled block erasure, including pre-programming, typically requires 1.6 seconds.

Byte write is accomplished with the standard EPROM mechanism of channel hot-electron injection from the cell drain junction to the floating gate. Bringing both the control gate and the cell drain to high voltage initiates programming. The WSM regulates the internal byte-write algorithm, including margin verification, after the correct command sequence is written and decoded. Byte write typically requires 9  $\mu$ s.



Figure 1. ETOX Flash Memory Cell



#### **DEVICE ARCHITECTURE**

#### **Array Organization**

The 28F008SA is a 1,048,576 x 8 memory comprised of 2048 rows by 8192 columns. Array layout is segmented as four quadrants, each 1024 rows by 2048 columns. Access time is reduced by limiting column length to 1024 cells. The polysilicon row is strapped in metal every 512 columns to reduce wordline delay. Two row decoders run vertically between quadrants, and column decoders run horizontally between quadrants. Figure 2 shows block placement and array organization. A die photo of the chip is shown in Figure 30.

Each quadrant is subdivided into four 64-Kbyte blocks. Each block source is electrically isolated from the source of other blocks. This allows individual block erase without altering data in the remaining 15 blocks.

Each block is further subdivided into eight Input/Outputs. Data for  $I/O_0$  is stored in the left-most 64 columns, with the next 64 storing data for  $I/O_1$ , etc.

Rows in the upper quadrants are numbered 0-1023 from top to bottom; lower quadrant rows similarly 1024-2047.

Addresses A<sub>9</sub>-A<sub>0</sub> select one of 1024 rows. while A<sub>19</sub> selects upper or lower decoder. Row address lines are decoded sequentially for selection. Row address bitmaps are listed in Table 3.

Columns are numbered 0-8191 from left to right, top to bottom. Addresses  $A_{19}$ - $A_{16}$  select one of 16 blocks, while  $A_{15}$ - $A_{10}$  select eight of the 512 columns within that block. These ten address lines are also decoded sequentially to access all 8192 columns. Block address bitmaps are listed in Table 4; column address bitmaps are listed in Table 5.

#### **Write/Erase Automation**

Intel's 28F008SA contains an on-chip Command User Interface, Write State Machine, Status Register, and address/data latches to dramatically simplify user interface. This combination of functional units reduces microprocessor control complexity of byte-write, blockerase, erase-suspend/resume, Status Register read/clear, ID read, and array read operations. Figure 3 shows the 28F008SA block diagram.



Figure 2. 28F008SA Block Placement and Array Organization



#### **Command User Interface (CUI)**

The CUI consists of a command decoder and command register. User requests are decoded and latched in a microprocessor write cycle controlled by Chip Enable (CE#) and Write Enable (WE#). Status Register read/clear, ID read, and array read commands are directly handled by the CUI. The CUI also accepts bytewrite, block-erase, and erase-suspend/resume commands. WE#'s rising edge latches address, command and data-in registers, and requests WSM initiation of the selected operation. These on-chip address, command, and data latches controlled by the CUI minimize system interface logic, and free the system bus.

#### Write State Machine (WSM)

The WSM processes byte-write, block-erase, and erase-suspend/resume requests received from the CUI. The WSM rejects byte-write and block-erase requests if the WSM is currently busy, if V<sub>PP</sub> is not at high voltage (12V), or if the Low V<sub>PP</sub> Status Register flag is set (i.e., not cleared from a previous low-voltage condition).

The WSM consists of an integrated oscillator and control circuitry. It generates signals which control the byte-write, block-erase, erase-suspend/resume, and verify circuits. It also receives feedback from these circuits allowing Status Register update. The WSM and associated circuits perform the equivalent of first-generation flash memory program and bulk-erase algorithms automatically. This eliminates the need for system timers, and frees the microprocessor to service interrupts or perform other functions during device byte-write or block-erase operations.

The WSM provides feedback to the CUI to determine when a given command is valid. Although nearly all commands are available when the WSM is inactive, only status read is valid while the WSM performs a byte-write operation. During block erase, only the readstatus and erase-suspend commands are available. Read-array, read-status, and erase-resume commands are valid with the WSM in an erase-suspended state. Invalid operations are interpreted as the read-array command when the WSM is inactive or erase-suspended, and as the read-status command when the WSM is active in byte write or block erase.



Figure 3. 28F008SA Block Diagram



#### **Status Register**

The internal Status Register contains a full complement of activity status bits. These bits and their meaning (1,0) are:

SR.7: WSM status (READY/BUSY)

SR.6: Erase-suspend status (ERASE SUSPENDED/ ERASE IN PROGRESS OR COMPLETED)

SR.5: Block-erase status (ERROR/SUCCESS)

SR.4: Byte-write status (ERROR/SUCCESS)

SR.3: Vpp status (LOW/OK)

All bits are set by the WSM, and read via the CUI. The WSM can only set SR.3, SR.4, and SR.5; it cannot clear them. They remain set until the CUI processes a clear Status Register command. There are two reasons for operating in this fashion.

First is synchronization; the WSM does not know when the host CPU has read the Status Register, therefore does not know when to clear it.

Secondly, allowing system software to control reset adds flexibility to the way this device may be used. The CPU may write several bytes or erase several blocks back-to-back while monitoring RY/BY# or polling SR.7 to determine when the next byte-write or block-erase command can be given. When all bytes are written, or all blocks erased, the system polls the other status flags to determine if all operations were successful or if an error occurred. While other approaches require the controlling microprocessor to watch for non-completion of write or erase within a specified time to indicate an error, this implementation requires no external system timers or software timing loops. As such, the system can reduce its polling overhead while still identifying any potential error conditions.

Status Register contents are driven to device outputs on the falling edge of CE# or Output Enable (OE#), whichever occurs last in the read cycle. CE# or OE# must be toggled to update Status Register contents.

#### Ready/Busy Indication (RY/BY#)

A dedicated output pin, RY/BY#, provides additional indication of WSM activity. This capability allows both hardware signal of status and/or software polling to determine activation, completion, or suspension of internal byte-write/block-erase operations. Hardware signaling minimizes both CPU overhead and system power consumption.

#### **Internal Oscillator**

The WSM is designed using clocked logic circuits. An on-chip ring oscillator generates the clock signals. The frequency of a standard ring oscillator varies with processing, temperature and supply voltage. An improved design, used on the 28F001BX and 28F008SA, minimizes these variations.

The switching current of each stage in the ring oscillator is controlled by a current reference which varies linearly with  $V_{CC}$ . The trip point of each ring oscillator inverter also varies linearly with  $V_{CC}$ . These two effects offset each other, and the resulting oscillator period is proportional to RC with only a small dependence on  $V_{CC}$ .

An on-chip resistor sets the value of R. The gate capacitance of the inverters in the ring oscillator sets the value of C. Process variations in these values are reduced by trimming the period of each oscillator during manufacturing. The resistor is the only source of temperature variation.

#### **Supply Voltage Sensing**

The LOWV $_{CC}$  and LOWV $_{PP}$  generation circuit is shown in Figure 4. Power supply voltages ( $V_{CC}$  and  $V_{PP}$ ) are divided down and compared to a reference voltage. If  $V_{REF}$  is greater than the divided power supply voltage, the LOWV $_{CC}$  or LOWV $_{PP}$  signal is driven high. The generated  $V_{REF}$  level is supply-voltage independent to the first order.

Positive power to the circuit is supplied by M1 and M2. M1 and M2 sources are pulled up to the higher of  $(V_{PP} - V_{tn})$  or  $(V_{CC} - V_{tw})$ .  $V_{tn}$  is the threshold of an implanted N-channel device, about 0.9V.  $V_{tw}$  is the threshold of a native N-channel device, about 0V. This scheme ensures that the circuit works regardless of the applied supply voltages.



**Figure 4. Low Power Detector Circuit** 



The LOWV $_{\rm CC}$  signal is used by the byte-write and block-erase circuits, as well as the CUI and WSM. If LOWV $_{\rm CC}$  is active, the CUI will not accept user writes and resets to an array read condition. The WSM is similarly reset by LOWV $_{\rm CC}$ . The LOWV $_{\rm PP}$  signal is used by the WSM; if V $_{\rm PP}$  drops below the high-voltage detector trip point during byte write or block erase, the Status Register's low V $_{\rm PP}$  bit is set and WSM operation halts. The system must clear the Status Register before any subsequent byte-write or block-erase operations can succeed.

#### Reset/Power-Down

The 28F008SA incorporates a deep power-down mode that reduces  $I_{CC}$  and  $I_{PP}$  to typically 0.20  $\mu A$  and 0.10  $\mu A$  respectively. RP# low selects deep power-down mode. When RP# is high, the device can be placed in an active or standby mode depending on CE#'s state.

Deep power-down is similar to standby except that all circuits excluding the RP# buffer are turned off. This mode greatly reduces power consumption, but requires more time to transition the device into an active mode. A read wake-up time (tpHQV) is required from RP# switching high until output and sense circuitry become fully functional and data can be read from the part. Similarly, a write wake-up time (tpHWL) is needed before the CUI recognizes writes. After this interval, normal operation is restored; the CUI is reset to read-array mode and the Status Register is cleared to 80H.

A diagram of the power-down circuit is shown in Figure 5. The TTL buffer formed by M1-M3 disables the low-power detect circuits, the redundancy-address flash bits, and the CE# TTL buffer formed by M4-M6. In previous Intel flash devices, these circuits were always enabled. Turn-on delays of these circuits determine RP# access time and write specifications.

RP# functions properly with TTL-level inputs. However, to attain lowest possible power consumption, full CMOS levels must be used. If the voltage on the gate of M3 rises above its 0.9V threshold M3 will turn on and draw current. Input voltages in the 0.7V-0.9V range

could cause enough subthreshold conduction in M3 to exceed the  $I_{CC}$  deep power-down current ( $I_{CCD}$ ) specification. This is why RP#'s input voltage is specified as GND  $\pm 0.2V$ .

RP# also functions as a hardware reset to the WSM and CUI. If RP# is driven active during byte-write, block-erase, or erase-suspend operation, that operation is aborted leaving the addressed memory locations in an unknown state. The Status Register is cleared, and CUI is set to array read. The aborted operation (byte write or block erase) must be repeated with RP# inactive to obtain a valid condition in the memory array.

Reset using RP# should be restricted to system reset only (as in the case of power supply failure), and should not be used as a software means to terminate byte-write or block-erase operations.



Figure 5. Power-Down and Reset Functions





Figure 6. Array Erase Blocking

#### **Block Erase**

Block erasure is achieved by a two-step write sequence. The erase-setup code is written to the CUI in the first cycle. Erase confirm is written in the second cycle. The address supplied with the erase-confirm command is latched and decoded internally by the 28F008SA; erase is subsequently enabled in that block. The second WE# rising edge initiates the operation (WE#-controlled write).

The WSM triggers the high-voltage flash-erase switch connecting the 12V supply to the source of all bits in the specified block, while all wordlines are grounded. Figure 6 shows organization of the block source switches. Fowler-Nordheim tunneling results in simultaneous erasure of all bits in the selected block.

The block source switch controls the source voltage of all bits in a particular block. This circuit is shown in Figure 7. During block erase, M2 is off and M1 pulls the source to Vpp. When not in erase, M1 is off and M2

pulls the source to ground. The high-voltage latch formed by M4-M7 converts the low-voltage ERASE signal to a high-voltage signal that controls M1.

The tunneling that occurs during block erase requires only a small amount of current. However, the initial current required to charge the block's large source capacitance to the erase voltage is significant. M1 is sized to limit this current yet still apply sufficient source voltage to achieve fast block-erase time.

The LOWV<sub>CC</sub> signal protects the array from erasure when  $V_{PP}$  is at a high voltage but  $V_{CC}$  is below the write/erase lockout voltage ( $V_{LKO}$ ). When this occurs, M3 pulls the block source to ground. The high-voltage latch is forced by M8 into the state that turns M1 off.

V<sub>PP</sub> is continually monitored during all phases of the block-erase operation. If V<sub>PP</sub> falls below the trip point of its high-voltage detect circuitry, erasure will not occur (or halts) and Status Register V<sub>PP</sub> status (SR.3), block-erase status (SR.5) and WSM status (SR.7) bits are set to "1".



Figure 7. Block Source Switch



If SR.3 (Low V<sub>PP</sub>) is set, WSM operation is inhibited. The WSM will not execute further byte-write or blockerasure sequences until the Status Register has been reset by system software. Byte-write or block-erase requests with error flags SR.4 or SR.5 set are not inhibited, but the system loses the ability to determine success. The clear Status Register command resets these bits.

After receiving the block-erase command sequence, the WSM automatically controls block pre-condition (programming all bytes to 00H within the chosen block), erase pulses and pulse repetition, timeout delays, and byte-by-byte verification of all block addresses (sequentially checked via the address counter) using an alternative sensing reference to verify margin. The internal erase and verify operations continue until the entire block is erased. A read cycle applied to the part following the block-erase command sequence outputs Status Register contents; system software can poll the Status Register to determine when block erase is complete, and if it was successful. Alternately, the system can monitor RY/BY # until that output is driven high, and then poll the Status Register to determine success. Following block erasure, the device remains in Status Register read mode; a read-array command must be written to the device to access array data.

If the erase-setup command is followed with a command other than erase confirm, the device will not erase. The WSM sets both byte-write status and blockerase status bits in the Status Register to indicate an invalid sequence.

#### **Erase Suspend/Resume**

Erase suspend allows the system to interrupt block erase to read data from another array block. The ability to suspend erase and read data from another block offers the flexibility required for file system applications. Upon receiving the erase-suspend command, the CUI requests that the WSM pause at one of several predetermined points in the algorithm. Upon reaching a suspend point, the WSM sets SR.6 (erase-suspend status) and SR.7 to "1", and drives the RY/BY# pin high. The system must poll the Status Register to determine if the suspend has been processed or the block erase has actually completed. Block-erase completion is indicated by SR.6 cleared to "0" and SR.7 set to "1". Read bus cycles default to Status Register read after issuing the erase-suspend command.

Once suspended, the WSM asserts a signal to the CUI which allows response to the read-array, read-status, and erase-resume commands. The system can write the read-array command allowing read access to blocks other than that which is suspended. The WSM continues to run idling in a suspended state, regardless of all control inputs except RP#. RP# driven low immediately shuts down the WSM, aborting the suspended erase operation.

The erase-resume command must be issued upon completion of reads from other array blocks to continue block-erase operation. The WSM then clears SR.6 and SR.7, drives RY/BY# low, and resumes erase operation from the suspension point. Read cycles following the erase-resume command output Status Register data.

#### **Byte Write**

Byte write follows a flow similar to block erase. The byte-write setup command is first written to the CUI. A second write cycle loads address and data latches. The rising edge of the second WE# pulse requests that the WSM initiate activity, applying high voltage to the gates and drains of all bits to be written. Unlike block erase, byte write will proceed regardless of what data is applied on the second CUI write cycle; however, applying data FFH does not modify memory contents.

Like block erase, the WSM controls program pulses and pulse repetition, timeout delays and byte verification. Byte write and verify (with alternate sensing reference and internally-generated verify voltage) continue until the byte is written. Internal byte-write verify checks that all bits written to zero have been correctly modified; it does not check bits specified as one. Byte write cannot change existing zeros to ones; this can only be accomplished by erase.

Read bus cycles following byte write operations output Status Register data. System software, polling the Status Register, is informed of status through bits SR.3, SR.4, and SR.7. The RY/BY# output can also be monitored to determine completion. The read-array command must be written to the CUI following byte write to access array data.

In a scenario similar to that described under block erasure, byte write does not occur (or halts) if Vpp is detected low. In such a case SR.3, SR.4, and SR.7 are set high, and no further writes can take place until the Status Register is cleared by the clear Status Register command.



#### **DEVICE CHARACTERIZATION**

#### **AC and DC Parameters**

Figures 9 through 24 show graphs of several device parameters as a function of temperature and supply voltage. The graphs illustrate that the 28F008SA has significant margin to data sheet specifications.

In particular, note Figure 9 which shows typical read performance  $t_{AVQV}$  ( $t_{ACC}$ ) of the 28F008SA as a function of  $V_{CC}$  and ambient temperature.  $t_{ELQV}$  ( $t_{CE}$ ) in Figure 10 and  $t_{GLQV}$  ( $t_{OE}$ ) in Figure 11 are also of particular interest. Access times  $t_{AVQV}$ ,  $t_{ELQV}$ , and  $t_{GLQV}$  are specified and tested with an output load of 100 pF; additional output load capacitance slows device operation.

Table 1 shows typical supply currents at room temperature for several operating modes.

**Table 1. RMS Current Values** 

| Mode            | I <sub>CC</sub><br>(V <sub>CC</sub> = 5.0V,<br>CMOS Inputs) | l <sub>pp</sub><br>(V <sub>PP</sub> = 12V) |  |  |
|-----------------|-------------------------------------------------------------|--------------------------------------------|--|--|
| Read            | 20 mA                                                       | 100 μΑ                                     |  |  |
| Byte Write      | 10 mA                                                       | 12 mA                                      |  |  |
| Block Erase     | .10 mA                                                      | 12 mA                                      |  |  |
| Standby         | 40 μΑ                                                       | 100 μΑ                                     |  |  |
| Deep Power-Down | 0.20 μΑ                                                     | 0.07 μΑ                                    |  |  |

#### **Energy/Power Consumption**

The system designer is primarily concerned with power consumption during block erase and byte write. Typical curves for I<sub>CC</sub> and I<sub>PP</sub> during block erase are shown in Figure 25. I<sub>CC</sub> and I<sub>PP</sub> for byte write are illustrated in Figure 26.

#### **Byte-Write/Block-Erase Times**

The 28F008SA advances byte-write and block-erase performance compared to previous flash memories. The on-chip algorithm is improved over the 28F001BX to take advantage of process enhancements. This improvement is most apparent when compared to first-generation flash parts with externally controlled algorithms. First-generation device times shown in Table 2 assume optimal system overhead, and as such are absolute best case.

Table 2. Byte-Write and Block-Erase Performance vs Previous Devices

| Device     | Byte-Write<br>Time                                    | Block-Erase<br>Time/# Bytes |                    |  |  |  |  |  |  |  |
|------------|-------------------------------------------------------|-----------------------------|--------------------|--|--|--|--|--|--|--|
| Second-G   | Second-Generation Flash Memory Devices <sup>(1)</sup> |                             |                    |  |  |  |  |  |  |  |
| 28F008SA   | 9 μs                                                  | 1.5s/64K                    | 23 ms              |  |  |  |  |  |  |  |
| 28F001BX   | 18 μs                                                 | 3.8s/112K                   | 34 ms              |  |  |  |  |  |  |  |
|            | •                                                     | 2.1s/8K                     | 256 ms             |  |  |  |  |  |  |  |
|            | ,                                                     | 2.1s/4K                     | 513 ms             |  |  |  |  |  |  |  |
| First-Gene | ration Flash                                          | n Memory Device             | ces <sup>(2)</sup> |  |  |  |  |  |  |  |
| 28F020     | 16.5 μs                                               | 6.8s/256K                   | 27 ms              |  |  |  |  |  |  |  |
| 28F010     | 16.5 μs                                               | 3.9s/128K                   | 30 ms              |  |  |  |  |  |  |  |
| 28F512     | 16.5 μs                                               | 2.4s/64K                    | 37 ms              |  |  |  |  |  |  |  |
| 28F256A    | 16.5 μs                                               | 1.6s/32K                    | 51 ms              |  |  |  |  |  |  |  |

#### **NOTES:**

- 1. Typical measured time.
- Times calculated based on typical erase and precondition pulse requirements, with minimum write timings. Calculations are described in Figure 8.

Figure 27 shows block-write and block-erase times at 0°C and 70°C over cycling.

#### **DEVICE RELIABILITY**

#### **Byte-Write/Block-Erase Cycling**

One of the most important reliability aspects of the 28F008SA is its capability of 100,000 write/erase cycles per block. Destructive oxide breakdown has been a limiting factor in extended cycling of thin-oxide EEPROMs. Intel's ETOX III flash memory technology extends cycling performance through:

- Improved tunnel-oxide processing that increases charge-carrying capability tenfold.
- Significantly reduced oxide area under stress that minimizes probability of oxide defects in the region.
- Reduced oxide stress due to a lower peak electric field (lower erase voltage than EEPROM).

Reliable byte-write/block-erase cycling requires proper selection of the maximum erase threshold voltage  $(V_t)$ , and maintenance of a tight distribution. Maximum erase  $V_t$  is set to 3.4V via the internal block-erase algorithm and verify circuits. Tight erase  $V_t$  distribution gives an order of magnitude of erase-time margin to the fastest erasing cell, with virtually identical erase  $V_t$  distributions at 1 and 10,000 cycles (Figure 28). Program  $V_t$  distribution is similarly consistent over cycling (Figure 29).

28F008SA array architecture enhances cycling capability by reducing gate disturb conditions on cells in unrelated blocks during byte write and erase pre-conditioning. First, only one of the two row decoders is active at any time (selected by  $A_{19}$ ). Rows in the other two quadrants are grounded. Secondly, two separate internally-switched voltages supply the left and right quadrants. Only one supply (selected by block address  $A_{18}$ ) is switched to programming voltages while the other remains at read voltages. This  $A_{19}-A_{18}$  row decoding ensures that during byte write, 12 of the 16 blocks have a gate voltage below that required for programming.

#### **Data Protection**

The 28F008SA offers protection against accidental block erasure or byte write during power transitions. Internal circuitry creates a device insensitive to  $V_{PP}/V_{CC}$  supply power-up sequencing.  $V_{PP} \leq V_{PPL}$  locks out byte-write and block-erase circuits.  $V_{CC} \leq V_{LKO}$  disables CUI command writes, resets the CUI to array read mode, and holds the WSM inactive. The system designer must still guard against spurious command writes for  $V_{CC} > V_{LKO}$  when  $V_{PP} > V_{PPL}$ .

Several strategies are available to prevent data modification in the 28F008SA. The CUI provides a degree of software write protection since memory alteration occurs only after successful completion of a two-step write sequence. WE# and CE# must both go active to perform this sequence; driving either high inhibits command/data writes. Secondly, the system can place the device in deep power-down mode (RP# =  $V_{IL}$ ) to disable command writes, reset the CUI to array read

mode, and hold the WSM inactive, effectively protecting array data. Finally, the system designer may hardwire  $V_{PP}$  to  $V_{PPH}$ , or switch it to  $V_{PPH}$  only when memory updates are required. Since byte-write and block-erase circuits are disabled by  $V_{PP} \leq V_{PPL}$ ,  $V_{PP}$  switching adds another level of data security.

#### SUMMARY

The 28F008SA is the first flash memory with features optimized for solid-state systems and file storage. These features include symmetrical block-erase, automation of byte write and block erase, erase suspend for data read, a reset/power-down mode, a write/erase Status Register, and a dedicated RY/BY# status pin. With simple microprocessor interfacing and software command sequences, the 28F008SA is the non-volatile storage solution of choice for today's designs.

#### OTHER REFERENCES

Related documents of interest to readers of this engineering report:

28F008SA Data Sheet (order #290429)

28F008SA-L Data Sheet (order #290435)

AP-359 "28F008SA Hardware Interfacing" (order #292094)

AP-360 "28F008SA Software Drivers" (order #292095)

AP-364 "28F008SA Automation and Algorithms" (order #292099)

ER-28 "ETOX III Flash Memory Technology" (order #294012) 3



#### SUPPLEMENTARY INFORMATION

#### FORMULA:

b = # bytes in a block (256K, 128K, 64K, 32K)

n = # of erase pulses required (90 pulses)

 $w = time for a write cycle (150 ns, t_{AVAV})$ 

 $v = time to verify (6055 ns, t_{WHGL} + t_{GLOV})$ 

p = program pulse width (10 μs, t<sub>WHWH1</sub>) one pulse programming assumed

 $e = erase pulse width (10 ms, t_{WHWH2})$ 

Precondition and precondition verify time is: b (2w + p + v)

Erase/verify, each loop where some byte does not pass verify:

$$(n - 1) (2w + e + v)$$

Last erase pulse:

$$(1)(2w + e)$$

Passing erase-verify, all bytes:

$$b(w + v)$$

Total time can be summarized as:

$$b(3w + p + 2v) + n(2w + e + v) - (v)$$

or substituting in times for write, verify, program and erase pulse widths:

b (22.56 
$$\times$$
 10<sup>-6</sup>) + n (10.006355  $\times$  10<sup>-3</sup>)  
- (6.055  $\times$  10<sup>-6</sup>) Seconds

Figure 8. Erase Time Calculations for First-Generation Flash Memories



Figure 10. t<sub>ELQV</sub> (t<sub>CE</sub>) vs V<sub>CC</sub> and Temperature



Figure 9. t<sub>AVQV</sub> (t<sub>ACC</sub>) vs V<sub>CC</sub> and Temperature



Figure 11. t<sub>GLQV</sub> (t<sub>OE</sub>) vs V<sub>CC</sub> and Temperature





Figure 12. t<sub>DVWH</sub> (t<sub>DS</sub> WE#) vs V<sub>CC</sub> and Temperature



Figure 14. t<sub>AVWH</sub> (t<sub>AS</sub> WE#) vs V<sub>CC</sub> and Temperature



Figure 13. t<sub>EHDX</sub> (t<sub>DH</sub> CE#) vs V<sub>CC</sub> and Temperature



Figure 15. t<sub>WHAX</sub> (t<sub>AH</sub> WE#) vs V<sub>CC</sub> and Temperature



Figure 16. t<sub>AVEH</sub> (t<sub>AS</sub> CE#) vs V<sub>CC</sub> and Temperature



Figure 18. t<sub>WLWH</sub> (t<sub>WP</sub>) vs V<sub>CC</sub> and Temperature

294011-17



Figure 17. t<sub>AHEX</sub> (t<sub>AH</sub> CE#) vs V<sub>CC</sub> and Temperature



Figure 19. t<sub>WHRL</sub> vs V<sub>CC</sub> and Temperature



Figure 20. Dynamic V<sub>IL</sub> vs V<sub>CC</sub> and Temperature



Figure 21. Dynamic V<sub>IH</sub> vs V<sub>CC</sub> and Temperature



Figure 22.  $I_{OH}$  TTL vs  $V_{CC}$  and Temperature ( $V_{OH} = 2.4V$ )



Figure 24.  $I_{OL}$  vs  $V_{CC}$  and Temperature  $(V_{OL} = 0.45V)$ 



Figure 23.  $I_{OH}$  CMOS vs  $V_{CC}$  and Temperature  $(V_{OH} = V_{CC} - 0.4V)$ 





Figure 25. I<sub>CC</sub> and I<sub>PP</sub> under Block-Erase Operation



Figure 26. I<sub>CC</sub> and I<sub>PP</sub> under Byte-Write Operation



Figure 27. Write and Erase Times vs Cycling





Figure 28. Erase Vt vs Cycles



Figure 29. Program V<sub>t</sub> vs Cycles





Figure 30. 278F008SA Die Photo





Figure 31. PSOP Lead Configuration





Figure 32. TSOP Lead Configuration



Wordlines are numbered sequentially from top to bottom. Addresses  $A_9$ - $A_0$  sequentially decode wordlines: block address  $A_{19}$  selects between upper and lower row-decoder. Wordlines 0–1023 serve the left and right quadrants at top of device; 1024–2047 serve the lower quadrants.

**Table 3. Row Address Bitmap** 

|                 | Table 3. Row Address Bitmap |                |                |                |                |                |                |                |                |                |          |
|-----------------|-----------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------|
| A <sub>19</sub> | A <sub>9</sub>              | A <sub>8</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | Wordline |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0        |
| 0               | Ó                           | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1        |
| 0               | 0                           | 0.             | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 2        |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 3        |
| 0               | 0                           | Ō              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 4        |
| 0 -             | 0                           | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 5        |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 6        |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 7        |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | . 8      |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | . 0            | 0              | 1              | . 9      |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 0              | 10       |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 1              | 1              | 11       |
| 0               | 0                           | 0              | 0              | 0              | 0              | .0             | 1              | 1              | 0              | 0              | 12       |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 1              | 13       |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 0              | 14       |
| 0               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 1              | 15       |
| 0               | 0                           | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 16       |
| 0               | 0                           | 0              | 0              | 0              | 0              | 1              | 0              | . •            | •              | •              | . •      |
| 0               | 0                           | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 1              | 1              | 31       |
| 0               | •                           | •              | 9              | •              | •              | •              | 0,             | •              | •              | •              | •        |
| Ö               | 1                           | 1              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              | 1008     |
| 0               | 1                           | 1              | 1              | 1              | 1              | 1              | •              | •              | •              | •              | •        |
| 0               | 1                           | 1              | 1              | . 1            | 1              | 1              | 1              | 1              | 1              | 1              | 1023     |
| 1               | 0                           | 0              | 0              | 0              | 0              | 0              | 0              | ,0             | 0              | 0              | 1024     |
| 1               | 0                           | 0              | 0              | 0              | 0              | 0              | •              | •              | •              | •              | •        |
| 1               | 0                           | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 1              | 1039     |
| 1               | 0                           | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 1040     |
| 1               | •                           | •              | •              | 6              | 0              | •              |                | •              | •              | •              | •        |
| 1               | 1                           | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 2047     |



Blocks are numbered sequentially right to left, top to bottom. Columns within a block are numbered left to right. I/Os within a block are numbered from 0-7 left to right.

**Table 4. Block Address Bitmap** 

| A <sub>19</sub> | A <sub>18</sub> | A <sub>17</sub> | A <sub>16</sub> | Block | Columns   |
|-----------------|-----------------|-----------------|-----------------|-------|-----------|
| 0               | 0               | 0               | 0               | 0     | 0-511     |
| 0               | 0               | 0               | 1               | 1     | 512-1023  |
| 0               | 0               | 1               | 0               | 2     | 1024-1535 |
| 0               | 0               | 1               | 1               | 3     | 1536-2047 |
| 0               | 1               | 0               | 0               | 4     | 2048-2559 |
| 0               | 1               | 0               | 1               | 5     | 2560-3071 |
| 0               | 1               | 1               | 0               | 6     | 3072-3583 |
| 0               | 1               | 1               | 1               | 7     | 3584095   |
| 1               | 0               | 0               | 0               | 8     | 4096-4607 |
| 1               | 0               | 0               | 1               | 9     | 4608-5119 |
| 1               | 0               | 1               | 0               | 10    | 5120-5631 |
| 1               | 0               | 1               | 1               | 11    | 5632-6143 |
| 1               | 1               | 0               | 0               | 12    | 6144-6655 |
| 1               | 1               | 0               | 1               | 13    | 6656-7167 |
| 1               | 1               | 1               | 0               | 14    | 7168-7679 |
| 1               | 1               | 1               | 1               | 15    | 7680-8191 |

Columns are numbered from left to right across the top quadrants, and left to right across the bottom quadrants. Addresses A<sub>15</sub>-A<sub>10</sub> sequentially count columns. Columns are listed for block 0; other blocks are counted similarly.

Table 5. Column Address Bitmap

|                 |                 |                 |                 |                 |                 |      |      |      | Colu             | mn İn |      |      |      |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|------|------|------|------------------|-------|------|------|------|
| A <sub>15</sub> | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>11</sub> | A <sub>10</sub> | 1/00 | 1/01 | 1/02 | I/O <sub>3</sub> | 1/04  | 1/05 | 1/06 | 1/07 |
| 0               | 0               | 0               | 0               | 0               | 0               | 0    | 64   | 128  | 192              | 256   | 320  | 384  | 448  |
| 0               | 0               | 0               | 0               | 0               | 1               | 1    | 65   | 129  | 193              | 257   | 321  | 385  | 449  |
| 0               | 0               | 0               | . 0             | 1               | 0               | 2    | 66   | 130  | 194              | 258   | 322  | 386  | 450  |
| 0               | 0               | 0               | 0               | 1               | 1               | 3    | 67   | 131  | 195              | 259   | 323  | 387  | 451  |
| 0               | 0               | 0               | 1               | 0               | 0               | 4    | 68   | 132  | 196              | 260   | 324  | 388  | 452  |
|                 | •               | •               | •               | •               | •               | •    | •    | •    | •                | •     | . •  | •    | • 1  |
| 1               | 1               | 1.              | 1               | 1               | 0               | 62   | 126  | 190  | 254              | 318   | 382  | 446  | 510  |
| 1               | 1               | 1               | 1               | 1               | 1               | 63   | 127  | 191  | 255              | 319   | 383  | 447  | 511  |

#### **REVISION HISTORY**

-002 — Renamed  $\overline{PWD}$  as RP# to match JEDEC conventions.



# **Boot Block Components**

4





# 8-Mbit (512K X 16, 1M X 8) SmartVoltage BOOT BLOCK FLASH MEMORY FAMILY

- Intel SmartVoltage Technology
  - 5V or 12V Program/Erase
  - 3.3V or 5V Read Operation
  - 60% Faster Typical Programming at 12V Vpp
- Very High Performance Read
- Low Power Consumption
- x8/x16-Selectable Input/Output Bus
  - 28F800 for High Performance 16- or 32-bit CPUs
- **Optimized Array Blocking Architecture** 
  - One 16-KB Protected Boot Block
  - Two 8-KB Parameter Blocks
  - One 96-KB Main Block
  - Seven 128-KB Main Blocks
  - Top or Bottom Boot Locations
- Absolute Hardware-Protection for Boot Block
- Software EEPROM Emulation with Parameter Blocks
- Extended Temperature Operation — -40°C to +85°C
- Extended Cycling Capability
  - 100,000 Block Erase Cycles (Commercial Temperature)
  - 10,000 Block Erase Cycles (Extended Temperature)

- Automated Word/Byte Write and Block Erase
  - Industry Standard Command User Interface
  - Status Registers
  - Erase Suspend Capability
- ☑ SRAM-Compatible Write Interface
- Automatic Power Savings Feature
  - 1 mA Typical I<sub>CC</sub> Active Current in Static Operation
- Reset/Deep Power-Down Input
  - 0.2 μA I<sub>CC</sub>Typical
  - Provides Reset for Boot Operations
- Hardware Data Protection Feature
  - Erase/Write Lockout during Power Transitions
- Industry-Standard Surface Mount Packaging
  - 40-Lead TSOP
  - 44-Lead PSOP: JEDEC ROM Compatible
  - 48-Lead TSOP
- □ Footprint Upgradable from 2/4 Mbit
- □ ETOX™ IV Flash Technology



290539-9





#### 1.0 PRODUCT FAMILY OVERVIEW

This datasheet contains product preview information about the upcoming 8-Mbit SmartVoltage boot block flash memory component.

# 1.1 New Features in the SmartVoltage Products

The new SmartVoltage boot block flash memory family offers identical operation as the current BX/BL 12V program products, except for the differences listed below. All other functions are equivalent to current products, including signatures, write commands, and pinouts.

- WP# pin has replaced a DU pin. See Table 2 and 3 for details.
- 5V Program/Erase operation has been added that uses proven program and erase techniques with 5V ± 10% applied to V<sub>PP</sub>.
- Enhanced circuits optimize performance at 3.3V V<sub>CC</sub>.

If you are designing with existing BX/BL 12V V<sub>PP</sub> boot block products today, you should provide the capability in your board design to upgrade to these new SmartVoltage products.

Follow these guidelines to ensure compatibilty:

- Connect WP# (DU on existing products) to control signal or to V<sub>CC</sub> or GND.
- If adding a switch on V<sub>PP</sub> for write protection, switch to GND for complete write protection.
- Allow for connecting 5V to V<sub>PP</sub> and disconnect 12V from V<sub>PP</sub> line, if desired.

#### 1.2 Main Features

Intel's SmartVoltage technology provides the most flexible voltage solution in the industry. SmartVoltage provides two discrete voltage supply pins, V<sub>CC</sub>

for read operation, and  $V_{PP}$  for program and erase operation. Discrete supply pins allow system designers to use the optimal voltage levels for their design. The 28F800BV provides read capability at 3.3V or 5V, and program/erase capability at 5V or 12V. Since many designs read from the flash memory a large percentage of the time, 3.3V  $V_{CC}$  operation can provide great power savings. If read performance is an issue, however, 5V  $V_{CC}$  provides faster read access times. For program and erase operations, 5V  $V_{PP}$  operation eliminates the need for in system voltage converters, while 12V  $V_{PP}$  operations where 12V is available, such as manufacturing or designs where 12V is in-system.

The 28F800 boot block flash memory family is a very high-performance, 8-Mbit (8,388,608 bit) flash memory family organized as either 512 Kwords of 16 bits each or 512 Kbytes of 8 bits each.

Separately erasable blocks, including a hardware-lockable boot block (16,384 bytes), two parameter blocks (8,192 Bytes each) and main blocks (one block of 98,304 bytes and seven blocks of 131,072 bytes) define the boot block flash family architecture. See Figures 5 and 6 for memory maps. Each block can be independently erased and programmed 100,000 times at commercial temperature and 10,000 times at extended temperature.

The boot block is located at either the top (denoted by -T suffix) or the bottom (-B suffix) of the address map in order to accommodate different microprocessor protocols for boot code location. The hardware-lockable boot block provides complete code security for the kernel code required for system initialization. Locking and unlocking of the boot block is controlled by WP# and/or RP# (see Section 2.3 for details).

The Command User Interface (CUI) serves as the interface between the microprocessor or microcontroller and the internal operation of the boot block flash memory products. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verifications, thereby unburdening the microprocessor or microcontroller of these



tasks. The Status Register (SR) indicates the status of the WSM and whether it successfully completed the desired program or erase operation.

Program and Erase Automation allows program and erase operations to be executed using an industry-standard two-write command sequence to the CUI. Data writes are performed in word or byte increments. Each byte or word in the Flash memory can be programmed independently of other memory locations, unlike erases, which erase all locations within a block simultaneously.

The 8-Mbit SmartVoltage boot block flash memory family is also designed with an Automatic Power Savings (APS) feature which minimizes system battery current drain, allowing for very low power designs. To provide even greater power savings, the boot block family includes a deep power-down mode which minimizes power consumption by turning most of the Flash memory's circuitry off. This mode is controlled by the RP# pin.

Additionally, the RP# pin provides protection against unwanted command writes due to invalid system bus conditions that may occur during system reset and power-up/down sequences. Also, when the Flash memory powers-up, it automatically defaults to the read array mode, but during a warm system reset, where power continues uninterrupted to the system components, the flash memory could remain in a non-read mode, such as erase. Consequently, the system Reset pin should be tied to RP# to reset the memory to normal read mode upon activation of the Reset pin.

For the 28F800, byte-wide or word-wide input/out-put is controlled by the BYTE# pin. Please see Table 3 for a detailed description of BYTE# operations, especially the usage of the DQ<sub>15</sub>/A<sub>-1</sub> pin.

The 28F800 products are available in a ROM/EPROM-compatible pinout and housed in the 44-Lead PSOP (Plastic Small Outline) package and the 48-Lead TSOP (Thin Small Outline, 1.2 mm thick) package.

The 28F008 boot block products are available in the 40-lead TSOP.

#### 2.0 OPERATIONAL DETAILS

#### 2.1 Intelligent Identifier

The intelligent identifiers of the SmartVoltage boot block components are identical to the boot block

#### 8-MBIT SmartVoltage BOOT BLOCK FAMILY

products that operate only at 12V V<sub>PP</sub>. The manufacturer and device codes are read via the CUI or by taking the A<sub>9</sub> pin to V<sub>ID</sub>. Writing 90H to the CUI places the device into intelligent identifier read mode. In this mode, A<sub>0</sub> = 0 outputs the manufacturer's identification code and A<sub>0</sub> = 1 outputs the device code. When BYTE# is at a logic low, only the lower byte of the above signatures is read and DQ<sub>15</sub>/A<sub>-1</sub> is a "don't care" during intelligent identifier mode. For x8 only products only the lower byte is read. See the table below for product signatures. A Read Array command must be written to the memory to return to the read array mode.

Table 1. Intelligent Identifier Table

|         |         | De         | vice ID       |
|---------|---------|------------|---------------|
| Product | Mfr. ID | -Т         | -B            |
|         |         | (Top Boot) | (Bottom Boot) |
| 28F800  | 0089 H  | 889C H     | 889D H        |

#### 2.2 Memory Organization

#### 2.2.1 BLOCKING

This product family features an asymmetrically blocked architecture providing system memory integration. Each erase block can be erased independently of the others up to 100,000 times at commercial temperature or up to 10,000 times at extended temperature. The block sizes have been chosen to optimize their functionality for common applications of nonvolatile storage. For the address locations of the blocks, see the memory maps in Figures 5 and 6.

#### 2.2.1.1 Boot Block - 1 x 16 KB

The boot block is intended to replace a dedicated boot PROM in a microprocessor or microcontroller-based system. The 16-Kbyte (16,384 bytes) boot block is located at either the top (denoted by -T suffix) or the bottom (-B suffix) of the address map to accommodate different microprocessor protocols for boot code location. This boot block features hardware controllable write-protection to protect the crucial microprocessor boot code from accidental erasure. The protection of the boot block is controlled using a combination of the Vpp, RP#, and WP# pins, as is detailed in Section 2.3.



#### 2.2.1.2 Parameter Blocks - 2 x 8 KB

The boot block architecture includes parameter blocks to facilitate storage of frequently updated small parameters that would normally require an EEPROM. By using software techniques, the byterewrite functionality of EEPROMs can be emulated. These techniques are detailed in Intel's AP-604, "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM." Each boot block component contains two parameter blocks of eight Kbytes (8,192 bytes) each. The parameter blocks are not write-protectable.

### 2.2.1.3 Main Blocks - 1 x 96 KB + 7 x 128 KB

After the allocation of address space to the boot and parameter blocks, the remainder is divided into main blocks for data or code storage. Each 8-Mbit device contains one 96-Kbyte (98,304 byte) block and seven 128-Kbyte (131,072 byte) blocks. See the memory maps for each device for more information.

#### 2.3 Boot Block Locking

The boot block family architecture features a hardware-lockable boot block so that the kernel code for the system can be kept secure while the parameter and main blocks are programmed and erased independently as necessary. Only the boot block can be locked independently from the other blocks.

### 2.3.1 V<sub>PP</sub> = V<sub>IL</sub> FOR COMPLETE PROTECTION

For complete write protection of all blocks in the flash device, the  $V_{PP}$  programming voltage can be held low. When  $V_{PP}$  is below  $V_{PPLK}$ , any program or erase operation will result in a error in the Status Register.

## 2.3.2 WP# = V<sub>IL</sub> FOR BOOT BLOCK LOCKING

When WP# =  $V_{IL}$ , the boot block is locked and any program or erase operation to the boot block will result in an error in the Status Register. All other blocks remain unlocked in this condition and can be programmed or erased normally. Note that this feature is overridden and the boot block unlocked when RP# =  $V_{HH}$ .

# 2.3.3 RP# = $V_{H\dot{H}}$ OR WP# = $V_{I\dot{H}}$ FOR BOOT BLOCK UNLOCKING

Two methods can be used to unlock the boot block:

1. WP# =  $V_{IH}$ 

2.  $RP# = V_{HH}$ 

If both or either of these two conditions are met, the boot block will be unlocked and can be programmed or erased. The truth table below clearly defines the write protection methods available.

Table 2. Write Protection Truth Table for SmartVoltage Boot Block Family

| V <sub>PP</sub>     | RP#             | WP#               | Write Protection<br>Provided |
|---------------------|-----------------|-------------------|------------------------------|
| V <sub>IL</sub>     | Х               | Х                 | All Blocks Locked            |
| ≥ V <sub>PPLK</sub> | V <sub>IL</sub> | Х                 | All Blocks Locked (Reset)    |
| ≥ V <sub>PPLK</sub> | $V_{HH}$        | Х                 | All Blocks Unlocked          |
| ≥ V <sub>PPLK</sub> | V <sub>IH</sub> | V <sub>IL</sub>   | Boot Block Locked            |
| ≥ V <sub>PPLK</sub> | V <sub>IH</sub> | · V <sub>IH</sub> | All Blocks Unlocked          |

In the 44-lead PSOP package, the WP# pin is replaced by A<sub>18</sub> due to a lack of available pins on that package. For this package only, the boot block can only be unlocked by placing 12V on RP#. All other packages retain the WP# pin for controlling boot block locking with a logic-level signal.



#### 3.0 PINOUTS



Figure 1. The 40-Lead TSOP Offers the Smallest Form Factor for Space-Constrained Applications



#### NOTE:

For the 8-Mbit device, pin 2 has been changed to A<sub>18</sub> (WP# on 2/4-Mbit). Designs planning on upgrading to the 8-Mbit density from the 2/4-Mbit density in this package should design pin 2 to control WP# functionality at the 2/4-Mbit level and allow for pin 2 to control A<sub>18</sub> after upgrading to the 8-Mbit density.

Figure 2. The 44-Lead TSOP Offers a Convenient Upgrade from JEDEC ROM Standards





Figure 3. The 48-Lead TSOP Offers the Smallest Form Factor for x16 Operation



#### 3.1 Pin Descriptions

Table 3. 28F800 Pin Descriptions

| Symbol                            | Туре         | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>18</sub>   | INPUT        | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                                                                                     |
| A <sub>9</sub>                    | INPUT        | <b>ADDRESS INPUT:</b> When $A_9$ is at $V_{HH}$ the signature mode is accessed. During this mode, $A_0$ decodes between the manufacturer and device IDs. When BYTE# is at a logic low, only the lower byte of the signatures are read. $DQ_{15}/A_{-1}$ is a don't care in the signature mode when BYTE# is low.                                                                                                                                                |
| DQ <sub>0</sub> -DQ <sub>7</sub>  | INPUT/OUTPUT | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a Program command. Inputs commands to the Command User Interface when CE# and WE# are active. Data is internally latched during the Write cycle. Outputs array, Intelligent Identifier and Status Register data. The data pins float to tri-state when the chip is de-selected or the outputs are disabled.                                                                       |
| DQ <sub>8</sub> -DQ <sub>15</sub> | INPUT/OUTPUT | <b>DATA INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a Program command. Data is internally latched during the Write cycle. Outputs array data. The data pins float to tri-state when the chip is de-selected or the outputs are disabled as in the byte-wide mode (BYTE# = "0"). In the byte-wide mode DQ <sub>15</sub> /A <sub>-1</sub> becomes the lowest order address for data output on DQ <sub>0</sub> -DQ <sub>7</sub> . |
| CE#                               | INPUT        | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low. CE# high de-selects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                                                                                   |
| OE#                               | INPUT        | <b>OUTPUT ENABLE:</b> Enables the device's outputs through the data buffers during a read cycle. OE # is active low.                                                                                                                                                                                                                                                                                                                                            |
| WE#                               | INPUT        | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                                                                  |
| RP#                               | INPUT        | RESET/DEEP POWER-DOWN: Uses three voltage levels (V <sub>IL</sub> , V <sub>IH</sub> , and V <sub>HH</sub> ) to control two different functions: reset/deep power-down mode and boot block unlocking. It is backwards-compatible with the BX/BL parts.                                                                                                                                                                                                           |
|                                   |              | When RP# is at logic low, the device is in reset/deep powerdown mode, which puts the outputs at High-Z, resets the Write State Machine, and draws minimum current.                                                                                                                                                                                                                                                                                              |
|                                   | ·            | When RP# is at logic high, the device is in standard operation. When RP# transitions from logic-low to logic-high, the device defaults to the read array mode.                                                                                                                                                                                                                                                                                                  |
|                                   | ·            | When RP# is at V <sub>HH</sub> , the boot block is unlocked and can be programmed or erased. This overides any control from the WP# input.                                                                                                                                                                                                                                                                                                                      |



#### Table 3. 28F800 Pin Descriptions (Continued)

| Symbol          | Туре  | Name and Function                                                                                                                                                                                                                                                                                                                     |
|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WP#             | INPUT | WRITE PROTECT: Provides a method for unlocking the boot block in a system without a 12V supply. WP# must be driven high or low, not left floating.                                                                                                                                                                                    |
|                 |       | When WP# is at logic low, the boot block is locked, preventing program and erase operations to the boot block. If a program or erase operation is attempted on the boot block when WP# is low, the corresponding status bit (bit 4 for Program, bit 5 for Erase) will be set in the Status Register to indicate the operation failed. |
|                 |       | When WP# is at logic high, the boot block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                |
|                 |       | NOTE:                                                                                                                                                                                                                                                                                                                                 |
|                 |       | This feature is overridden and the boot block unlocked when RP# is at V <sub>HH</sub> . See Section 2.3 for details on write protection.                                                                                                                                                                                              |
| BYTE#           | INPUT | BYTE# ENABLE: Controls whether the device operates in the byte-wide mode (x8) or the word-wide mode (x16). BYTE# pin must be controlled at CMOS levels to meet the CMOS current specification in the standby mode.                                                                                                                    |
|                 |       | When BYTE # is at logic low, the byte-wide mode is enabled, where data is read and programmed on DQ $_0$ –DQ $_7$ and DQ $_{15}$ /A $_1$ becomes the lowest order address that decodes between the upper and lower byte. DQ $_8$ -DQ $_{14}$ are tri-stated during the byte-wide mode.                                                |
|                 |       | When BYTE # is at logic high, the word-wide mode is enabled, where data is read and programmed on DQ <sub>0</sub> -DQ <sub>15</sub> .                                                                                                                                                                                                 |
| V <sub>CC</sub> |       | <b>DEVICE POWER SUPPLY:</b> 5.0V ± 10%, 3.3V ± 0.3V                                                                                                                                                                                                                                                                                   |
| V <sub>PP</sub> |       | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block, a voltage either of 5V $\pm$ 10% or 12V $\pm$ 5% must be applied to this pin. When V <sub>PP</sub> $<$ V <sub>PPLK</sub> all blocks are locked and protected against Program and Erase commands.                                       |
| GND             |       | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                   |
| NC              |       | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                       |



#### 4.0 MEMORY MAPS

| FFFFFH           | <u></u>                               | FFFFFH           |                                         |
|------------------|---------------------------------------|------------------|-----------------------------------------|
| FC000H           | 16-Kbyte BOOT BLOCK                   |                  | 128-Kbyte MAIN BLOCK                    |
| FBFFFH<br>FA000H | 8-Kbyte PARAMETER BLOCK               | E0000H           | ,                                       |
| F9FFFH<br>F8000H | 8-Kbyte PARAMETER BLOCK               | DFFFFH           | 128-Kbyte MAIN BLOCK                    |
| F7FFFH           | 96-Kbyte MAIN BLOCK                   | C0000H<br>BFFFFH | , , , , , , , , , , , , , , , , , , , , |
| E0000H<br>DFFFFH |                                       |                  | 128-Kbyte MAIN BLOCK                    |
|                  | 128-Kbyte MAIN BLOCK                  | A0000H<br>9FFFFH |                                         |
| C0000H<br>BFFFFH |                                       |                  | 128-Kbyte MAIN BLOCK                    |
|                  | 128-Kbyte MAIN BLOCK                  | 80000H<br>7FFFFH |                                         |
| A0000H<br>9FFFFH | · · · · · · · · · · · · · · · · · · · |                  | 128-Kbyte MAIN BLOCK                    |
| 80000H           | 128-Kbyte MAIN BLOCK                  | 60000H<br>5FFFFH |                                         |
| 7FFFFH           | <i>'</i>                              | 4000011          | 128-Kbyte MAIN BLOCK                    |
| 60000H           | 128-Kbyte MAIN BLOCK                  | 40000H<br>3FFFFH |                                         |
| 5FFFFH           | 400 Khi ta MANN BLOOK                 | 20000H           | 128-Kbyte MAIN BLOCK                    |
| 40000H           | 128-Kbyte MAIN BLOCK                  | 1FFFFH           | 96-Kbyte MAIN BLOCK                     |
| 3FFFFH           | 128-Kbyte MAIN BLOCK                  | 08000H<br>07FFFH | 8-Kbyte PARAMETER BLOCK                 |
| 20000H           |                                       | 06000H<br>05FFFH | ļ                                       |
| 1FFFFH           | 128-Kbyte MAIN BLOCK                  | 04000H<br>03FFFH | 8-Kbyte PARAMETER BLOCK                 |
| 00000Н           | 125-ruju wirdit becon                 | 00000H           | 16-Kbyte BOOT BLOCK                     |
|                  |                                       | 000001           | 29                                      |

Figure 4. Byte-Wide x8-Mode Memory Maps



|                            | 28F800-B                | •                | 28F800-T                |
|----------------------------|-------------------------|------------------|-------------------------|
| FFFFH [                    | 128-Kbyte MAIN BLOCK    | 7FFFFH<br>7E000H | 16-Kbyte BOOT BLOCK     |
| 70000Н                     | 720 NO NO NO NO NO NO   | 7DFFFH<br>7D000H | 8-Kbyte PARAMETER BLOCK |
| FFFFH                      | 128-Kbyte MAIN BLOCK    | 7CFFFH<br>7C000H | 8-Kbyte PARAMETER BLOCK |
| SOOOOH<br>FFFFH            |                         | 7BFFFH           | 96-Kbyte MAIN BLOCK     |
| 50000Н                     | 128-Kbyte MAIN BLOCK    | 70000H<br>6FFFFH | 128-Kbyte MAIN BLOCK    |
| FFFFH                      | 128-Kbyte MAIN BLOCK    | 60000H<br>5FFFFH | 120 13710 111 1220011   |
| 40000H<br>FFFFH            |                         |                  | 128-Kbyte MAIN BLOCK    |
| 30000Н                     | 128-Kbyte MAIN BLOCK    | 50000H<br>4FFFFH | 128-Kbyte MAIN BLOCK    |
| FFFFH                      | 128-Kbyte MAIN BLOCK    | 40000H<br>3FFFFH | 120-KDyle WAII4 BEOOK   |
| 20000H<br>FFFFH            |                         |                  | 128-Kbyte MAIN BLOCK    |
| 10000Н                     | 128-Kbyte MAIN BLOCK    | 30000H<br>2FFFFH | 128-Kbyte MAIN BLOCK    |
| FFFFH                      | 96-Kbyte MAIN BLOCK     | 20000H<br>1FFFFH | 120-KDyle WAIN BLOOK    |
| 04000H<br>03FFFH<br>03000H | 8-Kbyte PARAMETER BLOCK |                  | 128-Kbyte MAIN BLOCK    |
| 25000H<br>2575FH<br>02000H | 8-Kbyte PARAMETER BLOCK | 10000H<br>0FFFFH |                         |
| 1FFFH<br>00000H            | 16-Kbyte BOOT BLOCK     | 00000Н           | 128-Kbyte MAIN BLOCK    |

Figure 5. Word-Wide x16-Mode Memory Maps



#### 5.0 ADDITIONAL INFORMATION

#### 5.1 Product Information



#### **Table 4. Summary of Line Items**

| Name     | V <sub>CC</sub> |    | v  | PP  | 40-<br>Lead<br>TSOP | 44-<br>Lead<br>PSOP | 48-<br>Lead<br>TSOP | 0°C-+70°C | -40°C-+85°C |
|----------|-----------------|----|----|-----|---------------------|---------------------|---------------------|-----------|-------------|
|          | 3.3V            | 5V | 5V | 12V |                     |                     |                     |           |             |
| 28F800BV | 10              | 10 | -  | 1   |                     | <i>u</i>            | ~                   | <u> </u>  | <b>"</b>    |
| 28F008BV | -               | 1  | 1  | /   | <b>"</b>            |                     |                     | <b>"</b>  | <i>u</i>    |

#### 8-MBIT SmartVoltage BOOT BLOCK FAMILY



#### 5.2 References

| Order Number | Document                                                                          |  |  |
|--------------|-----------------------------------------------------------------------------------|--|--|
| 292130       | AB-57 "Boot Block Architecture for Safe Firmware Updates"                         |  |  |
| 292154       | AB-60 "2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family"                    |  |  |
| 292098       | AP-363 "Extended Flash BIOS Concepts for Portable Computers"                      |  |  |
| 292148       | AP-604 "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM" |  |  |
| 290530       | 4-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |  |  |
| 290531       | 2-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |  |  |

#### 5.3 Revision History

|      |                              | <br> |  |
|------|------------------------------|------|--|
| -001 | Initial release of datasheet |      |  |
|      |                              |      |  |

# intel

# 4-MBIT (256K x 16, 512K x 8) SmartVoltage BOOT BLOCK FLASH MEMORY FAMILY

28F400BV-T/B, 28F004BV-T/B, 28F400CV-T/B

- Intel SmartVoltage Technology
  - 5V or 12V Program/Erase
  - 3.3V or 5V Read Operation
  - 60% Faster Typical Programming at 12V Vpp
- Very High Performance Read
  - 5V: 60/80/120 ns Max. Access Time, 30/40 ns Max. Output Enable
  - 3V: 110/150/180 ns Max. Access Time, 65/90 ns Max. Output Enable
- **図 Low Power Consumption** 
  - Maximum 60 mA Read Current at 5V
  - Maximum 30 mA Read Current at 3V
- x8/x16-Selectable Input/Output Bus
  - 28F400 for High Performance 16- or 32-bit CPUs
- 國 x8-Only Input/Output Architecture
  - 28F004 for Space-Constrained 8-bit Applications
- M Optimized Array Blocking Architecture
  - One 16-KB Protected Boot Block
  - Two 8-KB Parameter Blocks
  - One 96-KB Main Block
  - Three 128-KB Main Blocks
  - Top or Bottom Boot Locations
- Absolute Hardware-Protection for Boot Block
- Software EEPROM Emulation with Parameter Blocks
- **Extended Temperature Operation** 
  - - 40°C to + 85°C

- Extended Cycling Capability
  - 100,000 Block Erase Cycles (Commercial Temperature)
  - 10,000 Block Erase Cycles (Extended Temperature)
- Automated Word/Byte Write and Block Erase
  - Industry Standard Command User Interface
  - Status Registers
  - Erase Suspend Capability
- SRAM-Compatible Write Interface
- Automatic Power Savings Feature
  - 1 mA Typical I<sub>CC</sub> Active Current in Static Operation
- Reset/Deep Power-Down Input
  - 0.2 μA I<sub>CC</sub>Typical
  - Provides Reset for Boot Operations
- ☐ Hardware Data Protection Feature
  - Erase/Write Lockout during Power Transitions
- Industry-Standard Surface Mount Packaging
  - 40-Lead TSOP
  - 44-Lead PSOP: JEDEC ROM Compatible
  - 48-Lead TSOP
  - 56-Lead TSOP
- Footprint Upgradable from 2 Mbit, and to 8 Mbit
- ETOX™ IV Flash Technology



290530-26

# 4-MBIT (256K x 16, 512K x 8) SmartVoltage BOOT BLOCK FLASH MEMORY FAMILY

| CONTENTS                                                       | PAGE | CONTENTS                                                                          | PAGE             |
|----------------------------------------------------------------|------|-----------------------------------------------------------------------------------|------------------|
| 1.0 PRODUCT FAMILY OVERVIEW                                    | 4-15 | 3.5 Power Consumption                                                             | 4-37             |
| 1.1 New Features in the SmartVolta                             |      | 3.5.1 ACTIVE POWER .                                                              | 4-37             |
| Products                                                       |      | 3.5.2 AUTOMATIC POV                                                               |                  |
| 1.2 Main Features                                              | 4-15 | SAVINGS                                                                           |                  |
| 1.3 Applications                                               | 4-17 | 3.5.3 STANDBY POWE                                                                |                  |
| 1.4 Pinouts                                                    | 4-19 | 3.5.4 DEEP POWER-DOMODE                                                           |                  |
| 1.5 Pin Descriptions                                           | 4-22 | 3.6 Power-Up/Down Opera                                                           |                  |
| 2.0 PRODUCT DESCRIPTION                                        | 4-24 | 3.6.1 RP# CONNECTE                                                                | D TO             |
| 2.1 Memory Organization                                        | 4-24 | SYSTEM RESET                                                                      |                  |
| 2.1.1 BLOCKING                                                 |      | 3.6.2 V <sub>CC</sub> , V <sub>PP</sub> AND RP<br>TRANSITIONS                     | <i>#</i><br>4-38 |
| 3.0 PRODUCT FAMILY PRINCIPLES                                  | OF   | 3.7 Power Supply Decoupli                                                         |                  |
| OPERATION                                                      | 4-26 | 3.7.1 V <sub>PP</sub> TRACE ON P<br>CIRCUIT BOARDS                                | RINTED           |
| 3.1 Bus Operations                                             |      | CIRCUIT BOARDS                                                                    | 4-38             |
| 3.2 Read Operations                                            |      | 4.0 ABSOLUTE MAXIMUM R                                                            | ATINGS 4-40      |
| 3.2.1 READ ARRAY                                               | 4-26 | 5.0 COMMERCIAL OPERATI                                                            | INC              |
| 3.2.2 INTELLIGENT IDENTIFIERS                                  | 4-28 | CONDITIONS                                                                        | 4-41             |
| 3.3 Write Operations                                           | 4-28 | 5.1 Switching V <sub>CC</sub> Voltages                                            | 3 4-41           |
| 3.3.1 COMMAND USER INTERFACE                                   | 4-28 | 5.2 DC Characteristics (Commercial)                                               | 4-42             |
| 3.3.2 STATUS REGISTER                                          |      | 5.3 AC Characteristics                                                            | 4.40             |
| 3.3.3 PROGRAM MODE                                             | 4-32 | (Commercial)                                                                      |                  |
| 3.3.4 ERASE MODE                                               | 4-33 | 6.0 EXTENDED OPERATING                                                            |                  |
| 3.4 Boot Block Locking                                         | 4-37 | CONDITIONS                                                                        |                  |
| 3.4.1 V <sub>PP</sub> = V <sub>IL</sub> FOR COMPLET PROTECTION | Έ    | 6.1 Applying V <sub>CC</sub> Voltages                                             |                  |
|                                                                | 4-37 | <ul><li>6.2 DC Characteristics (Ext</li><li>6.3 AC Characteristics (Ext</li></ul> | •                |
| 3.4.2 WP# = V <sub>IL</sub> FOR BOOT<br>BLOCK LOCKING          | 1.27 | 6.3 AC Characteristics (Ext                                                       | .ended) 4-62     |
|                                                                |      | 7.0 ADDITIONAL INFORMAT                                                           | ΓΙΟΝ 4-66        |
| 3.4.3 RP# = V <sub>HH</sub> OR WP# = \<br>FOR BOOT BLOCK       | 'IH  | 7.1 Ordering Information                                                          |                  |
| UNLOCKING                                                      | 4-37 | 7.2 References                                                                    |                  |
|                                                                |      | 7.3 Revision History                                                              | 4-67             |



#### 1.0 PRODUCT FAMILY OVERVIEW

This datasheet comprises the specifications for the SmartVoltage products in the 4-Mbit boot block flash memory family. Throughout this datasheet, the 28F400 refers to all x8/x16 4-Mbit products, while 28F004 refers to all x8 4-Mbit products. Section 1 provides an overview of the flash memory family including applications, pinouts and pin descriptions. Sections 2 and 3 describe, in detail, the specific memory organizations and principles of operation for these products. Finally, Sections 4 and 5 describe the family's operating specifications. Tables 1 and 2 provide a quick reference to each product's voltage supply capability.

### 1.1 New Features in the SmartVoltage Products

The new SmartVoltage boot block flash memory family offers identical operation as the current BX/BL 12V program products, except for the differences listed below. All other functions are equivalent to current products, including signatures, write commands, and pinouts.

- WP# pin has replaced a DU pin. See Table 3 and Table 10 for details.
- 5V Program/Erase operation has been added that uses proven program and erase techniques with 5V ± 10% applied to V<sub>PP</sub>.
- Enhanced circuits optimize performance at 3.3V V<sub>CC</sub>.

If you are designing with existing BX/BL 12V V<sub>PP</sub> boot block products today, you should provide the capability in your board design to upgrade to these new SmartVoltage products.

Follow these guidelines to ensure compatibility:

Connect WP# (DU on existing products) to control signal or to V<sub>CC</sub> or GND.

#### 4-MBIT SmartVoltage BOOT BLOCK FAMILY

- If adding a switch on V<sub>PP</sub> for write protection, switch to GND for complete write protection.
- Allow for connecting 5V to V<sub>PP</sub> and disconnect 12V from V<sub>PP</sub> line, if desired.

#### 1.2 Main Features

Intel's SmartVoltage technology provides the most flexible voltage solution the in SmartVoltage provides two discrete voltage supply pins, V<sub>CC</sub> for read operation, and V<sub>PP</sub> for program and erase operation. Discrete supply pins allow system designers to use the optimal voltage levels for their design. The 28F400/004BV provides read capability at 3.3V or 5V, and program/erase capability at 5V or 12V. Since many designs read from the flash memory a large percentage of the time, 3.3V V<sub>CC</sub> operation can provide great power savings. If read performance is an issue, however, 5V V<sub>CC</sub> provides faster read access times. For program and erase operations, 5V VPP operation eliminates the need for in system voltage converters, while 12V V<sub>PP</sub> operation provides faster program and erase for situations where 12V is available, such as manufacturing or designs where 12V is in-system.

The 28F400/28F004 boot block flash memory family is a very high-performance, 4-Mbit (4,194,304 bit) flash memory family organized as either 256 Kwords (262,144 words) of 16 bits each or 512 Kbytes (524,288 bytes) of 8 bits each.

Separately erasable blocks, including a hardware-lockable boot block (16,384 bytes), two parameter blocks (8,192 Bytes each) and main blocks (one block of 98,304 bytes and three blocks of 131,072 bytes) define the boot block flash family architecture. See Figure 7 and 8 for memory maps. Each block can be independently erased and programmed 100,000 times at commercial temperature or 10,000 times at extended temperature.



Table 1, x8/x16 Boot Block Product Family

| Product Name | V <sub>F</sub> | op . | V <sub>CC</sub> |          |  |
|--------------|----------------|------|-----------------|----------|--|
|              | 12V            | 5V   | 5V              | 3V       |  |
| 28F400BV-T/B | . "            | -    | <i>ν</i>        | <i>u</i> |  |

#### Table 2. x8-only Boot Block Product Family

| Product Name | V <sub>F</sub> | PP  | V <sub>CC</sub> |          |  |
|--------------|----------------|-----|-----------------|----------|--|
|              | 12V            | 5V  | 5V              | 3V       |  |
| 28F004BV-T/B | <i>V</i>       | " " | <i>u</i>        | <i>u</i> |  |

The boot block is located at either the top (denoted by -T suffix) or the bottom (-B suffix) of the address map in order to accommodate different microprocessor protocols for boot code location. The hardware-lockable boot block provides complete code security for the kernel code required for system initialization. Locking and unlocking of the boot block is controlled by WP# and/or RP# (see Section 3.4 for details).

The Command User Interface (CUI) serves as the interface between the microprocessor or microcontroller and the internal operation of the boot block flash memory products. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verifications, thereby unburdening the microprocessor or microcontroller of these tasks. The Status Register (SR) indicates the status of the WSM and whether it successfully completed the desired program or erase operation.

Program and Erase Automation allows program and erase operations to be executed using an industry-standard two-write command sequence to the CUI. Data writes are performed in word (28F400 family) or byte (28F400 or 28F004 families) increments. Each byte or word in the Flash memory can be programmed independently of other memory locations, unlike erases, which erase all locations within a block simultaneously.

The 4-Mbit SmartVoltage boot block flash memory family is also designed with an Automatic Power Savings (APS) feature which minimizes system

battery current drain, allowing for very low power designs. To provide even greater power savings, the boot block family includes a deep power-down mode which minimizes power consumption by turning most of the Flash memory's circuitry off. This mode is controlled by the RP# pin and its usage is discussed in Section 3.5, along with other power consumption issues.

Additionally, the RP# pin provides protection against unwanted command writes due to invalid system bus conditions that may occur during system reset and power-up/down sequences. Also, when the Flash memory powers-up, it automatically defaults to the read array mode, but during a warm system reset, where power continues uninterrupted to the system components, the flash memory could remain in a non-read mode, such as erase. Consequently, the system Reset pin should be tied to RP# to reset the memory to normal read mode upon activation of the Reset pin.

For the 28F400, byte-wide or word-wide input/out-put is controlled by the BYTE# pin. Please see Table 3 for a detailed description of BYTE# operations, especially the usage of the  $DQ_{15}/A_{-1}$  pin.

The 28F400 products are available in a ROM/EPROM-compatible pinout and housed in the 44-Lead PSOP (Plastic Small Outline) package, the 48-Lead TSOP (Thin Small Outline, 1.2 mm thick) package and the 56-Lead TSOP as shown in Figure 4, 5 and 6, respectively. The 28F004 products are available in the 40-Lead TSOP package as shown in Figure 3.



Refer to the DC Characteristics Table, Section 4.2 (commercial temperature) and Section 5.2 (extended temperature), for complete current and voltage specifications. Refer to the AC Characteristics Table, Section 4.3 (commercial temperature) and Section 5.3 (extended temperature), for read, write and erase performance specifications.

#### 1.3 Applications

The 4-Mbit boot block flash memory family combines high-density, low-power, high-performance, cost-effective flash memories with blocking and hardware protection capabilities. Their flexibility and versatility reduce costs throughout the product life cycle. Flash memory is ideal for Just-In-Time production flow, reducing system inventory and costs, and eliminating component handling during the production phase.

When your product is in the end-user's hands, and updates or feature enhancements become necessary, flash memory reduces the update costs by allowing user-performed code changes instead of costly product returns or technician calls.

The 4-Mbit boot block flash memory family provides full-function, blocked flash memories suitable for a wide range of applications. These applications include extended PC BIOS and ROM-able applications storage, digital cellular phone program and data storage, telecommunication boot/firmware, printer firmware/font storage and various other embedded applications where program and data storage are required.

Reprogrammable systems such as personal computers, are ideal applications for the 4-Mbit flash memory products. Increasing software sophis-

#### 4-MBIT SmartVoltage BOOT BLOCK FAMILY

tication greatens the probability that a code update will be required after the PC is shipped. For example, the emerging of "Plug and Play" standard in desktop and portable PCs enables auto-configuration of ISA and PCI add-in cards. However, since the "Plug and Play" specification continues to evolve, a flash BIOS provides a cost-effective capability to update existing PCs. In addition, the parameter blocks are ideal for storing the required auto-configuration parameters, allowing you to integrate the BIOS PROM and parameter storage EEPROM into a single component, reducing parts costs while increasing functionality.

The 4-Mbit flash memory products are also excellent design solutions for digital cellular phone and telecommunication switching applications requiring very low power consumption, high-performance, high-density storage capability, modular software designs, and a small form factor package. The 4-Mbit's Kbytes of hardware-protected boot code, four main blocks of program code and two parameter blocks of 8 Kbytes each for frequently updated data storage and diagnostic messages (e.g., phone numbers, authorization codes).

Intel's boot block architecture provides a flexible voltage solution for the different design needs of various applications. The asymmetrically blocked memory map allows the integration of several memory components into a single Flash device. The boot block provides a secure boot PROM; the parameter blocks can emulate EEPROM functionality for parameter store with proper software techniques; and the main blocks provide code and data storage with access times fast enough to execute code in place, decreasing RAM requirements.





Figure 1. 28F400 Interface to Intel386EX™ Microprocessor





Figure 2. 28F004 Interface to Intel80C188EB 8-Bit Embedded Microprocessor

#### 1.4 Pinouts

Intel's SmartVoltage Boot Block architecture provides upgrade paths in every package pinout to the 8-Mbit density. The 28F004 40-Lead TSOP pinout for space-constrained designs is shown in Figure 3. The 28F400 44-Lead PSOP pinout follows the industry standard ROM/EPROM pinout as shown in Figure 4. For designs that require x16 operation but

have space concerns, refer to the 48-Lead pinout in Figure 5. Furthermore, the 28F400 56-Lead TSOP pinout shown in Figure 6 provides density upgrades to future higher density boot block memories.

Pinouts for the corresponding 2-Mbit and 8-Mbit components are also provided for convenient reference. 4-Mbit pinouts are given on the chip illustration in the center, with 2-Mbit and 8-Mbit pinouts going outward from the center.





Figure 3. The 40-Lead TSOP Offers the Smallest Form Factor for Space-Constrained Applications



Pin 2 is DU for BX/BL 12V Vpp Versions, but for the 8-Mbit device, pin 2 has been changed to A18 (WP# on 2/4 Mbit). Designs planning on upgrading to the 8-Mbit density from the 2/4-Mbit density in this package should design pin 2 to control WP# functionality at the 2/4-Mbit level and allow for pin 2 to control A<sub>18</sub> after upgrading to the 8-Mbit density.

Figure 4. The 44-Lead PSOP Offers a Convenient Upgrade from JEDEC ROM Standards





Figure 5. The 48-Lead TSOP Offers the Smallest Form Factor for x16 Operation



Figure 6. The 56-Lead TSOP Offers Compatibility between 2 and 4 Mbits



### 1.5 Pin Descriptions

Table 3. 28F400/004 Pin Descriptions

| Symbol                            | Туре             | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>18</sub>   | INPUT            | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle. The 28F400 only has A <sub>0</sub> -A <sub>17</sub> pins, while the 28F004 has A <sub>0</sub> -A <sub>18</sub> .                                                                                                                                                                                                                                                                                                                 |
| A <sub>9</sub>                    | INPUT            | <b>ADDRESS INPUT:</b> When A <sub>9</sub> is at V <sub>HH</sub> the signature mode is accessed. During this mode, A <sub>0</sub> decodes between the manufacturer and device IDs. When BYTE# is at a logic low, only the lower byte of the signatures are read. $DQ_{15}/A_{-1}$ is a don't care in the signature mode when BYTE# is low.                                                                                                                                                                                    |
| DQ <sub>0</sub> -DQ <sub>7</sub>  | INPUT/<br>OUTPUT | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a Program command. Inputs commands to the Command User Interface when CE# and WE# are active. Data is internally latched during the Write cycle. Outputs array, Intelligent Identifier and Status Register data. The data pins float to tri-state when the chip is de-selected or the outputs are disabled.                                                                                                                                    |
| DQ <sub>8</sub> -DQ <sub>15</sub> | INPUT/<br>OUTPUT | <b>DATA INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a Program command. Data is internally latched during the Write cycle. Outputs array data. The data pins float to tri-state when the chip is de-selected or the outputs are disabled as in the byte-wide mode (BYTE# = "0"). In the byte-wide mode DQ $_{15}/A_{-1}$ becomes the lowest order address for data output on DQ $_{0}$ -DQ $_{7}$ . <b>The 28F004 does not include these DQ<math>_{8}</math>-DQ<math>_{15}</math> pins</b> . |
| CE#                               | INPUT            | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low. CE# high de-selects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                                                                                                                                                |
| OE#                               | INPUT            | <b>OUTPUT ENABLE:</b> Enables the device's outputs through the data buffers during a read cycle. OE# is active low.                                                                                                                                                                                                                                                                                                                                                                                                          |
| WE#                               | INPUT            | <b>WRITE ENABLE:</b> Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                                                                                                                        |
| RP#                               | INPUT            | <b>RESET/DEEP POWER-DOWN:</b> Uses three voltage levels ( $V_{IL}$ , $V_{IH}$ , and $V_{HH}$ ) to control two different functions: reset/deep power-down mode and boot block unlocking. It is backwards-compatible with the 28F400BX/BL.                                                                                                                                                                                                                                                                                     |
| :                                 |                  | When RP# is at logic low, the device is in reset/deep powerdown mode, which puts the outputs at High-Z, resets the Write State Machine, and draws minimum current.                                                                                                                                                                                                                                                                                                                                                           |
|                                   |                  | When RP# is at logic high, the device is in standard operation. When RP# transitions from logic-low to logic-high, the device defaults to the read array mode.                                                                                                                                                                                                                                                                                                                                                               |
|                                   | r                | When RP# is at V <sub>HH</sub> , the boot block is unlocked and can be programmed or erased. This overides any control from the WP# input.                                                                                                                                                                                                                                                                                                                                                                                   |



#### Table 3. 28F400/004 Pin Descriptions (Continued)

| Symbol          | Туре  | Name and Function                                                                                                                                                                                                                                                                                                                     |
|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WP#             | INPUT | <b>WRITE PROTECT:</b> Provides a method for unlocking the boot block in a system without a 12V supply. WP# must be pulled to logic low or high, not left floating.                                                                                                                                                                    |
|                 |       | When WP# is at logic low, the boot block is locked, preventing Program and Erase operations to the boot block. If a Program or Erase operation is attempted on the boot block when WP# is low, the corresponding status bit (bit 4 for Program, bit 5 for Erase) will be set in the Status Register to indicate the operation failed. |
|                 |       | When WP# is at logic high, the boot block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                |
|                 |       | <b>NOTE:</b> This feature is overridden and the boot block unlocked when RP $\#$ is at V <sub>HH</sub> . See Section 3.4 for details on write protection.                                                                                                                                                                             |
| BYTE#           | INPUT | BYTE# ENABLE: Not available on 28F004. Controls whether the device operates in the byte-wide mode (x8) or the word-wide mode (x16). BYTE# pin must be controlled at CMOS levels to meet the CMOS current specification in the standby mode.                                                                                           |
|                 |       | When BYTE# is at logic low, the byte-wide mode is enabled, where data is read and programmed on DQ $_0$ -DQ $_7$ and DQ $_{15}$ /A $_{-1}$ becomes the lowest order address that decodes between the upper and lower byte. DQ $_8$ -DQ $_{14}$ are tri-stated during the byte-wide mode.                                              |
|                 |       | When BYTE $\#$ is at logic high, the word-wide mode is enabled, where data is read and programmed on DQ <sub>0</sub> -DQ <sub>15</sub> .                                                                                                                                                                                              |
| V <sub>CC</sub> |       | <b>DEVICE POWER SUPPLY:</b> 5.0V $\pm$ 10%, 3.3V $\pm$ 0.3V                                                                                                                                                                                                                                                                           |
| V <sub>PP</sub> |       | <b>PROGRAM/ERASE POWER SUPPLY:</b> For erasing memory array blocks or programming data in each block, a voltage either of 5V $\pm$ 10% or 12V $\pm$ 5% must be applied to this pin. When V <sub>PP</sub> $<$ V <sub>PPLK</sub> all blocks are locked and protected against Program and Erase commands.                                |
| GND             |       | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                   |
| NC              |       | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                       |



#### 2.0 PRODUCT DESCRIPTION

#### 2.1 Memory Organization

#### 2.1.1 BLOCKING

This product family features an asymmetrically blocked architecture providing system memory integration. Each erase block can be erased independently of the others up to 100,000 times at commercial temperature or up to 10,000 times at extended temperature. The block sizes have been chosen to optimize their functionality for common applications of nonvolatile storage. For the address locations of the blocks, see the memory maps in Figures 7 and 8.

#### 2.1.1.1 Boot Block-1 x 16 KB

The boot block is intended to replace a dedicated boot PROM in a microprocessor or microcontroller-based system. The 16-Kbyte (16,384 bytes) boot block is located at either the top (denoted by -T suf-ix) or the bottom (-B suffix) of the address map to accommodate different microprocessor protocols for boot code location. This boot block features hardware controllable write-protection to protect the crucial microprocessor boot code from accidental erasure. The protection of the boot block is controlled using a combination of the V<sub>PP</sub>, RP#, and WP# pins, as is detailed in Section 3.4.

#### 2.1.1.2 Parameter Blocks-2 x 8 KB

The boot block architecture includes parameter blocks to facilitate storage of frequently updated small parameters that would normally require an EEPROM. By using software techniques, the byterewrite functionality of EEPROMs can be emulated. These techniques are detailed in Intel's AP-604, "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM." Each boot block component contains two parameter blocks of eight Kbytes (8,192 bytes) each. The parameter blocks are not write-protectable.

#### 2.1.1.3 Main Blocks—1 x 96 KB + 3 x 128 KB

After the allocation of address space to the boot and parameter blocks, the remainder is divided into main blocks for data or code storage. Each 4-Mbit device contains one 96-Kbyte (98,304 byte) block and three 128-Kbyte (131,072 byte) blocks. See the memory maps for each device for more information.





Figure 7. 28F400-T/B Memory Maps



Figure 8. 28F004-T/B Memory Maps



## 3.0 PRODUCT FAMILY PRINCIPLES OF OPERATION

Flash memory augments EPROM functionality with in-circuit electrical write and erase. The boot block flash family utilizes a Command User Interface (CUI) and automated algorithms to simplify write and erase operations. The CUI allows for 100% TTL-level control inputs, fixed power supplies during erasure and programming, and maximum EPROM compatibility.

When V<sub>PP</sub> < V<sub>PPLK</sub>, the device will only successfully execute the following commands: Read Array, Read Status Register, Clear Status Register and intelligent identifier mode. The device provides standard EPROM Read, Standby and Output Disable operations. Manufacturer Identification and Device Identification data can be accessed through the CUI or through the standard EPROM A<sub>9</sub> high voltage access (V<sub>ID</sub>) for PROM programming equipment.

The same EPROM Read, Standby and Output Disable functions are available when 5V or 12V is applied to the Vpp pin. In addition, 5V or 12V on Vpp allows write and erase of the device. All functions associated with altering memory contents: Write and Erase, Intelligent Identifier Read, and Read Status are accessed via the CUI.

The purpose of the Write State Machine (WSM) is to completely automate the write and erasure of the device. The WSM will begin operation upon receipt of a signal from the CUI and will report status back through a Status Register. The CUI will handle the WE# interface to the data and address latches, as well as system software requests for status while the WSM is in operation.

#### 3.1 Bus Operations

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles. These bus operations are summarized in Tables 4 and 5.

#### 3.2 Read Operations

#### 3.2.1 READ ARRAY

When RP# transitions from  $V_{IL}$  (reset) to  $V_{IH}$ , the device will be in the read array mode and will respond to the read control inputs (CE#, address inputs) and OE#) without any commands being written to the CUI.

When the device is in the read array mode, five control signals must be controlled to obtain data at the outputs.

- WE# must be logic high (VIH)
- CE# must be logic low (VII)
- OE must be logic low (V<sub>II</sub>)
- RP# must be logic high (VIH)
- BYTE# must be logic high or logic low.

In addition, the address of the desired location must be applied to the address pins. Refer to Figures 18 and 19 for the exact sequence and timing of these signals.

If the device is not in read array mode, as would be the case after a program or erase operation, the Read Mode command (FFH) must be written to the CUI before reads can take place.



Table 4. Bus Operations for Word-Wide Mode (BYTE#  $= V_{IH}$ )

| Mode                            | Notes | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-15</sub> |
|---------------------------------|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|
| Read                            | 1,2,3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | X               | X               | D <sub>OUT</sub>   |
| Output Disable                  |       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | High Z             |
| Standby                         |       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х               | High Z             |
| Deep Power-Down                 | 9     | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х               | Х               | High Z             |
| Intelligent Identifier (Mfr)    | 4     | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $V_{ID}$        | VIL             | Х               | 0089 H             |
| Intelligent Identifier (Device) | 4,5   | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | See Table 6        |
| Write                           | 6,7,8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х               | D <sub>IN</sub>    |

Table 5. Bus Operations for Byte-Wide Mode (BYTE# = VII)

| rable of bas operations for byte wide mode (bills, tip) |       |                 |                 |                 |                 |                 |                 |     |                 |                   |                    |  |
|---------------------------------------------------------|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|-----------------|-------------------|--------------------|--|
| Mode                                                    | Notes | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | A-1 | V <sub>PP</sub> | DQ <sub>0-7</sub> | DQ <sub>8-14</sub> |  |
| Read                                                    | 1,2,3 | V <sub>IH</sub> | VIL             | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х   | Х               | D <sub>OUT</sub>  | High Z             |  |
| Output Disable                                          |       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х   | Х               | High Z            | High Z             |  |
| Standby                                                 |       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х   | Х               | High Z            | High Z             |  |
| Deep Power-Down                                         | 9     | V <sub>IL</sub> | X               | X               | Х               | Х               | Х               | Х   | Х               | High Z            | High Z             |  |
| Intelligent Identifier (Mfr)                            | 4     | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $V_{ID}$        | VIL             | Х   | Х               | 89H               | High Z             |  |
| Intelligent Identifier (Device)                         | 4,5   | V <sub>IH</sub> | VIL             | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х   | Х               | See Table 6       | High Z             |  |
| Write                                                   | 6,7,8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х   | Х               | D <sub>IN</sub>   | High Z             |  |

- 1. Refer to DC Characteristics.

- X can be V<sub>IL</sub>, V<sub>IH</sub> for control pins and addresses, V<sub>PPLK</sub> or V<sub>PPH</sub> for V<sub>PP</sub>.
   See DC Characteristics for V<sub>PPLK</sub>, V<sub>PPH1</sub>, V<sub>PPH2</sub>, V<sub>HH</sub>, V<sub>ID</sub> voltages.
   Manufacturer and Device codes may also be accessed via a CUI write sequence, A<sub>1</sub>-A<sub>17</sub> = X, A<sub>1</sub>-A<sub>18</sub> = X.
- 5. See Table 6 of Device IDs.
- 6. Refer to Table 7 for valid  $D_{\mbox{\scriptsize IN}}$  during a Write operation.
- 7. Command writes for Block Erase or Word/Byte Write are only executed when Vpp = VppH1 or VppH2.
- 8. To Write or Erase the boot block, hold RP# at V<sub>HH</sub> or WP# at V<sub>IH</sub>.
- 9. RP# must be at GND ± 0.2V to meet the maximum deep power-down current specified.



#### 3.2.2 INTELLIGENT IDENTIFIERS

The intelligent identifiers of the SmartVoltage boot block components are identical to the boot block products that operate only at 12V Vpp. The manufacturer and device codes are read via the CUI or by taking the A<sub>9</sub> pin to V<sub>ID</sub>. Writing 90H to the CUI places the device into intelligent identifier read mode. In this mode, A<sub>0</sub> = 0 outputs the manufacturer's identification code and A<sub>0</sub> = 1 outputs the device code. When BYTE# is at a logic low, only the lower byte of the above signatures is read and DQ<sub>15</sub>/A<sub>-1</sub> is a "don't care" during intelligent identifier mode. For x8 only products only the lower byte is read. See the Table 6 below for product signatures. A Read Array command must be written to the memory to return to the read array mode.

**Table 6. Intelligent Identifier Table** 

| r       | r       |            |               |  |  |  |  |
|---------|---------|------------|---------------|--|--|--|--|
|         |         | Device ID  |               |  |  |  |  |
| Product | Mfr. ID | -т         | -В            |  |  |  |  |
|         |         | (Top Boot) | (Bottom Boot) |  |  |  |  |
| 28F400  | 0089 H  | 4470 H     | 4471 H        |  |  |  |  |
| 28F004  | 89 H    | 78 H       | 79 H          |  |  |  |  |

#### 3.3 Write Operations

#### 3.3.1 COMMAND USER INTERFACE (CUI)

The Command User Interface (CUI) serves as the interface between the microprocessor and the internal chip controller. Commands are written to the CUI using standard microprocessor write timings. The available commands are Read Array, Read Intelligent Identifier, Read Status Register, Clear Status

Register, Erase and Program (summarized in Tables 7 and 8). For Read commands, the CUI points the read path at either the array, the intelligent identifier. or the Status Register depending on the command received. For Program or Erase commands, the CUI informs the Write State Machine (WSM) that a write or erase has been requested. During the execution of a Program command, the WSM will control the programming sequences and the CUI will only respond to status reads. During an erase cycle, the CUI will respond to status reads and erase suspend. After the WSM has completed its task, it will set the WSM Status bit to a "1," which will also allow the CUI to respond to its full command set. Note that after the WSM has returned control to the CUI, the CUI will stay in the current command state until it receives another command.

Table 7. Command Set Codes and Corresponding Device Mode

| Command Codes | Device Mode                |
|---------------|----------------------------|
| 00            | Invalid Reserved           |
| 10            | Alternate Program Set-Up   |
| 20            | Erase Set-Up               |
| 40            | Program Set-Up             |
| 50            | Clear Status Register      |
| 70            | Read Status Register       |
| 90            | Intelligent Identifier     |
| В0            | Erase Suspend              |
| D0            | Erase Resume/Erase Confirm |
| FF            | Read Array                 |



#### **Table 8. Command Bus Definitions**

| Command                   | Notes | Fir   | rst Bus Cyc | ele  | Second Bus Cycle |      |      |  |
|---------------------------|-------|-------|-------------|------|------------------|------|------|--|
| Command                   | Notes | Oper  | Addr        | Data | Oper             | Addr | Data |  |
| Read Array                | 8     | Write | х           | FFH  |                  |      |      |  |
| Intelligent Identifier    | 1     | Write | X           | 90H  | Read             | IA   | IID  |  |
| Read Status Register      | 2,4   | Write | Х           | 70H  | Read             | Х    | SRD  |  |
| Clear Status Register     | 3     | Write | Х           | 50H  |                  |      |      |  |
| Word/Byte Write           |       | Write | ·WA         | 40H  | Write            | WA   | WD   |  |
| Alternate Word/Byte Write | 6,7   | Write | WA          | 10H  | Write            | WA   | WD   |  |
| Block Erase/Confirm       | 6,7   | Write | ВА          | 20H  | Write            | ВА   | D0H  |  |
| Erase Suspend/Resume      | 5     | Write | X           | вон  | Write            | Х    | D0H  |  |

#### **ADDRESS**

BA = Block Address

IA = Identifier Address WA = Write Address

X = Don't Care

#### DATA

SRD = Status Register Data

IID = Identifier Data

WD = Write Data

#### NOTES:

- 1. Bus operations are defined in Tables 4 and 5.
- 2. IA = Identifier Address: A0 = 0 for manufacturer code, A0 = 1 for device code.
- 3. SRD-Data read from Status Register.
- IID = Intelligent Identifier Data. Following the Intelligent Identifier command, two Read operations access manufacturer and device codes.
- 5. BA = Address within the block being erased.
- 6. WA = Address to be written. WD = Data to be written at location WD.
- 7. Either 40H or 10H commands is valid.
- When writing commands to the device, the upper data bus [DQ<sub>8</sub>-DQ<sub>15</sub>] = X (28F400 only) which is either V<sub>IL</sub> or V<sub>IH</sub>, to minimize current draw.



#### 3.3.1.1 Command Function Description

Device operations are selected by writing specific commands into the CUI. Tables 7 and 8 define the available commands.

#### Invalid/Reserved

These are unassigned commands and should not be used. Intel reserves the right to redefine these codes for future functions.

#### Read Array (FFH)

This single write cycle command points the read path at the array. If the host CPU performs a CE#/OE#-controlled Read immediately following a two-write sequence that started the WSM, then the device will output Status Register contents. If the Read Array command is given after the Erase Setup command, the device will reset to read the array. A two Read Array command sequence (FFH) is required to reset to Read Array after the Program Setup command.

#### Intelligent Identifier (90H)

After this command is executed, the CUI points the output path to the intelligent identifier circuits. Only intelligent identifier values at addresses 0 and 1 can be read (only address  $A_0$  is used in this mode, all other address inputs are ignored).

#### Read Status Register (70H)

This is one of the two commands that is executable while the WSM is operating. After this command is written, a read of the device will output the contents of the Status Register, regardless of the address presented to the device.

The device automatically enters this mode after program or erase has completed.

#### Clear Status Register (50H)

The WSM can only set the Program Status and Erase Status bits in the Status Register to "1," it cannot clear them to "0."

Two reasons exist for operating the Status Register in this fashion. The first is synchronization. Since the WSM does not know when the host CPU has read the Status Register, it would not know when to clear the status bits. Secondly, if the CPU is programming a string of bytes, it may be more efficient to query the Status Register after programming the string. Thus, if any errors exist while programming the string, the Status Register will return the accumulated error status.

#### Program Setup (40H or 10H)

This command simply sets the CUI into a state such that the next write will load the Address and Data registers. After this command is executed, the outputs default to the Status Register. A two Read Array command sequence (FFH) is required to reset to Read Array after the Program Setup command.

#### **Program**

The second write after the Program Setup command, will latch addresses and data. Also, the CUI initiates the WSM to begin execution of the program algorithm. The device outputs Status Register data when OE# is enabled. A Read Array command is required after programming, to read array data.

#### Erase Setup (20H)

Prepares the CUI for the Erase Confirm command. No other action is taken. If the next command is not an Erase Confirm command, then the CUI will set both the Program Status and Erase Status bits of the Status Register to a "1," place the device into the Read Status Register state, and wait for another command.

#### **Erase Confirm (D0H)**

If the previous command was an Erase Setup command, then the CUI will enable the WSM to erase, at the same time closing the address and data latches, and respond only to the Read Status Register and Erase Suspend commands. While the WSM is executing, the device will output Status Register data when OE# is toggled low. Status Register data can only be updated by toggling either OE# or CE# low.

# inta.

#### Erase Suspend (B0H)

This command is only valid while the WSM is executing an Erase operation, and therefore will only be responded to during an Erase operation. After this command has been executed, the CUI will set an output that directs the WSM to suspend Erase operations, and then respond only to Read Status Register or to the Erase Resume commands. Once the WSM has reached the Suspend state, it will set an output into the CUI which allows the CUI to respond to the Read Array, Read Status Register, and Erase Resume commands. In this mode, the CUI will not respond to any other commands. The WSM will also set the WSM Status bit to a "1." The WSM will continue to run, idling in the SUSPEND state, regardless of the state of all input control pins except RP#, which will immediately shut down the WSM and the remainder of the chip, if it is made active. During a Suspend operation, the data and address latches will remain closed, but the address pads are able to drive the address into the read path.

#### Erase Resume (D0H)

This command will cause the CUI to clear the Suspend state and clear the WSM Status Bit to a "0," but only if an Erase Suspend command was previously issued. Erase Resume will not have any effect under any other conditions.

#### 3.3.2 STATUS REGISTER

The device contains a Status Register which may be read to determine when a Program or Erase operation is complete, and whether that operation completed successfully. The Status Register may be read at any time by writing the Read Status command to the CUI. After writing this command, all subsequent Read operations output data from the Status Register until another command is written to the CUI. A Read Array command must be written to the CUI to return to the read array mode.

#### 4-MBIT SmartVoltage BOOT BLOCK FAMILY

The Status Register bits are output on DQ[0:7], whether the device is in the byte-wide (x8) or wordwide (x16) mode. In the word-wide mode the upper byte, DQ[8:15], is set to 00H during a Read Status command. In the byte-wide mode, DQ[8:14] are tristated and DQ $_{15}/A_{-1}$  retains the low order address function.

Important: The contents of the Status Register are latched on the falling edge of OE# or CE#, whichever occurs last in the read cycle. This prevents possible bus errors which might occur if the contents of the Status Register change while reading the Status Register. CE# or OE# must be toggled with each subsequent status read, or the completion of a Program or Erase operation will not be evident from the Status Register.

When the WSM is active, this register will indicate the status of the WSM, and will also hold the bits indicating whether or not the WSM was successful in performing the desired operation.

#### 3.3.2.1 Clearing the Status Register

The WSM sets status bits "3" through "7" to "1," and clears bits "6" and "7" to "0," but cannot clear status bits "3" through "5" to "0." Bits 3 through 5 can only be cleared by the controlling CPU through the use of the Clear Status Register command. These bits can indicate various error conditions. By allowing the system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several bytes or erasing multiple blocks in sequence). The Status Register may then be read to determine if an error occurred during that programming or erasure series. This adds flexibility to the way the device may be programmed or erased. To clear the Status Register, the Clear Status Register command is written to the CUI. Then, any other command may be issued to the CUI. Note, again, that before a read cycle can be initiated, a Read Array command must be written to the CUI to specify whether the read data is to come from the Memory Array, Status Register, or Intelliaent Identifier.





#### **Table 9. Status Register Bit Definition**

| WSMS | ESS | ES | DWS | VPPS | R | R | R |
|------|-----|----|-----|------|---|---|---|
| 7    | 6   | 5  | 4   | 3    | 2 | 1 | 0 |

| •       | 3                                                                                    | •                                                          | 3                                                                                             | -                                                                                                                               | • •                                                                  | 0                |
|---------|--------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------|
| SR.7 =  | WRITE STATE MACHINE ST<br>(WSMS)<br>1 = Ready<br>0 = Busy                            | determ<br>comple                                           | nine Byte/Word                                                                                | NOTES:<br>bit must first be<br>d program or Blo<br>e Program or Er                                                              | ock Erase                                                            | s are            |
| SR.6 =  | ERASE-SUSPEND STATUS  1 = Erase Suspended  0 = Erase in Progress/Com                 | and se                                                     | ts both WSMS<br>is set to "1" un                                                              | d is issued, WSM<br>and ESS bits to<br>till an Erase Res                                                                        | "1." ESS bit                                                         |                  |
| SR.5 =  | ERASE STATUS  1 = Error in Block Erasure  0 = Successful Block Erase                 | maxim                                                      | um number of                                                                                  | "1," WSM has<br>erase pulses to<br>y verify block er                                                                            | the block and                                                        | is still         |
| SR.4 =  | PROGRAM STATUS  1 = Error in Byte/Word Prog  0 = Successful Byte/Word R              | ram to prog                                                | this bit is set to<br>gram a byte or v                                                        | "1," WSM has<br>word.                                                                                                           | attempted but                                                        | failed           |
| SR.3 =  | V <sub>PP</sub> STATUS 1 = V <sub>PP</sub> Low Detect, Operat 0 = V <sub>PP</sub> OK | ion Abort provide<br>interro<br>comma<br>the sys<br>Status | e continuous in<br>gates V <sub>PP</sub> leve<br>and sequences<br>stem if V <sub>PP</sub> has | nlike an A/D condication of Vpp<br>I only after the Estave been enternated in<br>I not been switch<br>Intend to report<br>I/PPH | level. The WS<br>Byte Write or E<br>ered, and infor<br>hed on. The V | M<br>rase<br>rms |
| SR.2-SI | R.0 = RESERVED FOR FUTU<br>ENHANCEMENTS                                              |                                                            |                                                                                               | ed for future use<br>lling the Status I                                                                                         |                                                                      | e                |

#### 3.3.3 PROGRAM MODE

Programming is executed using a two-write sequence. The Program Setup command is written to the CUI followed by a second write which specifies the address and data to be programmed. The WSM will execute a sequence of internally timed events to:

- Program the desired bits of the addressed memory word or byte.
- Verify that the desired bits are sufficiently programmed.

Programming of the memory results in specific bits within a byte or word being changed to a "0."

If the user attempts to program "1"s, there will be no change of the memory cell content and no error occurs.

Similar to erasure, the Status Register indicates whether programming is complete. While the program sequence is executing, bit 7 of the Status Register is a "0." The Status Register can be polled by toggling either CE# or OE# to determine when the program sequence is complete. Only the Read Status Register command is valid while programming is active.

When programming is complete, the status bits, which indicate whether the Program operation was successful, should be checked. If the programming operation was unsuccessful, bit 4 of the Status



Register is set to a "1" to indicate a Program Failure. If bit 3 is set to a "1," then V<sub>PP</sub> was not within acceptable limits, and the WSM did not execute the programming sequence. If the program operation fails, bit 4 of the Status Register will be set within 1.5 ms as determined by the timeout of the WSM.

The Status Register should be cleared before attempting the next operation. Any CUI instruction can follow after programming is completed; however, reads from the Memory Array, Status Register, or Intelligent Identifier cannot be accomplished until the CUI is given the Read Array command.

#### 3.3.4 ERASE MODE

Erasure of a single block is initiated by writing the Erase Setup and Erase Confirm commands to the CUI, along with the addresses identifying the block to be erased. These addresses are latched internally when the Erase Confirm command is issued. Block erasure results in all bits within the block being set to "1."

The WSM will execute a sequence of internally timed events to:

- 1. Program all bits within the block to "0."
- Verify that all bits within the block are sufficiently programmed to "0."
- 3. Erase all bits within the block.
- Verify that all bits within the block are sufficiently erased.

While the erase sequence is executing, bit 7 of the Status Register is a "0."

When the Status Register indicates that erasure is complete, the status bits, which indicate whether the Erase operation was successful, should be checked. If the Erase operation was unsuccessful, bit 5 of the Status Register will be set to a "1," indicating an Erase Failure. If V<sub>PP</sub> was not within acceptable limits after the Erase Confirm command is issued, the WSM will not execute an erase sequence;

#### 4-MBIT SmartVoltage BOOT BLOCK FAMILY

instead, bit 5 of the Status Register is set to a "1" to indicate an Erase Failure, and bit 3 is set to a "1" to identify that V<sub>PP</sub> supply voltage was not within acceptable limits. If the erase operation fails, bit 5 of the Status Register will be set within 1.5ms as determined by the timeout of the WSM.

The Status Register should be cleared before attempting the next operation. Any CUI instruction can follow after erasure is completed; however, reads from the Memory Array, Status Register, or Intelligent Identifier cannot be accomplished until the CUI is given the Read Array command.

#### 3.3.4.1 Suspending and Resuming Erase

Since an erase operation requires on the order of seconds to complete, an Erase Suspend command is provided to allow erase-sequence interruption in order to read data from another block of the memory. Once the erase sequence is started, writing the Erase Suspend command to the CUI requests that the WSM pause the erase sequence at a predetermined point in the erase algorithm. The Status Register must then be read to determine if the erase operation has been suspended.

At this point, a Read Array command can be written to the CUI in order to read data from blocks other than that which is being suspended. The only other valid command at this time is the Erase Resume command or Read Status Register command.

During erase suspend mode, the chip can go into a pseudo-standby mode by taking CE# to V<sub>IH</sub>, which reduces active current draw.

To resume the erase operation, the chip must be enabled by taking CE# to  $V_{IL}$ , then issuing the Erase Resume command. When the Erase Resume command is given, the WSM will continue with the erase sequence and complete erasing the block. As with the end of a standard erase operation, the Status Register must be read, cleared, and the next instruction issued in order to continue.





Figure 9. Automated Word/Byte Programming Flowchart





Figure 10. Automated Block Erase Flowchart





Figure 11. Erase Suspend/Resume Flowchart



#### 3.4 Boot Block Locking

The boot block family architecture features a hardware-lockable boot block so that the kernel code for the system can be kept secure while the parameter and main blocks are programmed and erased independently as necessary. Only the boot block can be locked independently from the other blocks.

#### 3.4.1 $V_{PP} = V_{IL}$ FOR COMPLETE PROTECTION

For complete write protection of all blocks in the flash device, the  $V_{PP}$  programming voltage can be held low. When  $V_{PP}$  is below  $V_{PPLK}$ , any program or erase operation will result in a error in the Status Register.

### 3.4.2 WP# = V<sub>IL</sub> FOR BOOT BLOCK LOCKING

When WP# =  $V_{IL}$ , the boot block is locked and any program or erase operation to the boot block will result in an error in the Status Register. All other blocks remain unlocked in this condition and can be programmed or erased normally. Note that this feature is overridden and the boot block unlocked when RP# =  $V_{HH}$ .

### 3.4.3 RP# = $V_{HH}$ OR WP# = $V_{IH}$ FOR BOOT BLOCK UNLOCKING

Two methods can be used to unlock the boot block:

- 1.  $WP# = V_{IH}$
- 2.  $RP# = V_{HH}$

If both or either of these two conditions are met, the boot block will be unlocked and can be programmed or erased. The truth table, Table 10, clearly defines the write protection methods.

#### 3.5 Power Consumption

#### 3.5.1 ACTIVE POWER

With CE# at a logic-low level and RP# at a logic-high level, the device is placed in the active mode. Refer to the DC Characteristics table for  $I_{CC}$  current values.

#### 4-MBIT SmartVoltage BOOT BLOCK FAMILY

Table 10. Write Protection Truth Table for SmartVoltage Boot Block Family

| V <sub>PP</sub>     | V <sub>PP</sub> RP# |                 | Write Protection<br>Provided |
|---------------------|---------------------|-----------------|------------------------------|
| V <sub>IL</sub>     | Х                   | Х               | All Blocks Locked            |
| ≥ V <sub>PPLK</sub> | V <sub>IL</sub>     | Х               | All Blocks Locked (Reset)    |
| $\geq V_{PPLK}$     | $V_{HH}$            | Х               | All Blocks Unlocked          |
| ≥ V <sub>PPLK</sub> | V <sub>IH</sub>     | V <sub>IL</sub> | Boot Block Locked            |
| ≥ V <sub>PPLK</sub> | V <sub>IH</sub>     | V <sub>IH</sub> | All Blocks Unlocked          |

#### 3.5.2 AUTOMATIC POWER SAVINGS (APS)

Automatic Power Savings (APS) is a low-power feature during active mode of operation. The boot block flash memory family incorporates Power Reduction Control (PRC) circuitry which allows the device to put itself into a low current state when it is not being accessed. After data is read from the memory array, PRC logic controls the device's power consumption by entering the APS mode where typical I<sub>CC</sub> current is less than 1 mA. The device stays in this static state with outputs valid until a new location is read.

#### 3.5.3 STANDBY POWER

With CE# at a logic-high level ( $V_{IH}$ ), and the CUI in read mode, the memory is placed in standby mode. The standby operation disables much of the device's circuitry and substantially reduces device power consumption. The outputs (DQ[0:15] or DQ[0:7]) are placed in a high-impedance state independent of the status of the OE# signal. When CE# is at logic-high level during erase or program functions, the devices will continue to perform the erase or program function and consume erase or program active power until erase or program is completed.

#### 3.5.4 DEEP POWER-DOWN MODE

The SmartVoltage boot block family supports a low typical  $I_{CC}$  in deep power-down mode, which turns off all circuits to save power. This mode is activated by the RP# pin when it is at a logic-low (GND  $\pm 0.2$ V.) (Note: BYTE# pin must be at CMOS levels to meet the  $I_{CCD}$  specification.)



During read modes, the RP# pin going low de-selects the memory and places the output drivers in a high impedance state. Recovery from the deep power-down state, requires a minimum access time of tpHQV. (See AC Characteristics table)

During erase or program modes, RP# low will abort either erase or program operations, but the memory contents are no longer valid as the data has been corrupted by the RP# function. As in the read mode above, all internal circuitry is turned off to achieve the power savings.

RP# transitions to  $V_{\text{IL}}$ , or turning power off to the device will clear the Status Register.

#### 3.6 Power-Up/Down Operation

The device offers protection against accidental block erasure or programming during power transitions. Power supply sequencing is not required, since the device is indifferent as to which power supply, Vpp or V<sub>CC</sub>, powers-up first. The CUI is reset to the read mode after power-up, but the system must drop CE# low or present a new address to ensure valid data at the outputs.

A system designer must guard against spurious writes when  $V_{CC}$  voltages are above  $V_{LKO}$  and  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either signal to  $V_{IH}$  will inhibit writes to the device. The CUI architecture provides an additional protection since alteration of memory contents can only occur after successful completion of the two-step command sequences. The device is also disabled until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. By holding the device in reset (RP# connected to system PowerGood) during power up/down, invalid bus conditions during power-up can be masked, providing yet another level of memory protection.

#### 3.6.1 RP# CONNECTED TO SYSTEM RESET

The use of RP# during system reset is important with automated write/erase devices because the system expects to read from the flash memory when it comes out of reset. If a CPU reset occurs without a flash memory reset, proper CPU initialization would not occur because the flash memory may be providing status information instead of array data. Intel's flash memories allow proper CPU initialization following a system reset by connecting the RP# pin to the same RESET# signal that resets the system CPU.

#### 3.6.2 V<sub>CC</sub>, V<sub>PP</sub> AND RP# TRANSITIONS

The CUI latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its default state upon power-up, after exit from deep power-down mode, or after  $V_{CC}$  transitions above  $V_{LKO}$  (Lockout voltage), is read array mode.

After any Word/Byte Write or Block Erase operation is complete and even after V<sub>PP</sub> transitions down to V<sub>PPLK</sub>, the CUI must be reset to read array mode via the Read Array command if accesses to the flash memory are desired.

#### 3.7 Power Supply Decoupling

Flash memory's power switching characteristics require careful device decoupling methods. System designers should consider three supply current issues:

- 1. Standby current levels (I<sub>CCS</sub>)
- 2. Active current levels (ICCR)
- Transient peaks produced by falling and rising edges of CE#.

Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress these transient voltage peaks. Each flash device should have a 0.1  $\mu$ F ceramic capacitor connected between each V<sub>CC</sub> and GND, and between its V<sub>PP</sub> and GND. These high frequency, inherently low inductance capacitors should be placed as close as possible to the package leads.

### 3.7.1 V<sub>PP</sub> TRACE ON PRINTED CIRCUIT BOARDS

Designing for in-system writes to the flash memory requires special consideration of the  $V_{PP}$  power supply trace by the printed circuit board designer. The  $V_{PP}$  pin supplies the flash memory cells current for programming and erasing. One should use similar trace widths and layout considerations given to the  $V_{CC}$  power supply trace. Adequate  $V_{PP}$  supply traces, and decoupling capacitors placed adjacent to the component, will decrease spikes and overshoots.



#### **Guide to Subsequent Tables**

| Operating Conditions   | Name                                               | Table<br>Number | Page |
|------------------------|----------------------------------------------------|-----------------|------|
| Commercial Temperature | Commercial Operating Conditions                    | 11              | 29   |
|                        | V <sub>CC</sub> Supply Switching Timing            | 12              | 29   |
|                        | DC Characteristics                                 | 13              | 30   |
|                        | AC Characteristics-Read Only Operations            | 14              | 34   |
|                        | AC Characteristics-WE# Controlled Write Operations | 15              | 37   |
|                        | AC Characteristics-CE# Controlled Write Operations | 16              | 40   |
|                        | Erase and Program Timings                          | 17              | 43   |
| Extended Temperature   | Extended Operating Conditions                      | 18              | 44   |
| ,                      | V <sub>CC</sub> Supply Switching Timing            | 19              | 44   |
|                        | DC Characteristics (V <sub>CC</sub> = 5V or 3.3V)  | 20              | 45   |
|                        | AC Characteristics-Read Only Operations            | 21              | 50   |
|                        | AC Characteristics-WE# Controlled Write Operations | 22              | 51   |
|                        | AC Characteristics-CE# Controlled Write Operations | 23              | 52   |
|                        | Erase and Program Timings                          | 24              | 53   |
|                        | Summary of Line Items                              | 25              | 54   |

#### NOTE:

In the following tables, the topmost heading lists the line items to which the specifications in that column apply. For space considerations, the line items have been abbreviated as shown in the following table. See Section 7.1 for more information on product naming and line items.

| Abbreviation | Applicable Product Names                                                                                               |
|--------------|------------------------------------------------------------------------------------------------------------------------|
| BV-60°       | E28F004BVT60, E28F004BVB60, E28F400BVT60, E28F400BVB60, E28F400CVT60, E28F400CVB60, PA28F400BVT60, PA28F400BVB60       |
| BV-80        | E28F004BVT80, E28F004BVB80, E28F400BVT80, E28F400BVB80, E28F400CVT80, E28F400CVB80, PA28F400BVT80, PA28F400BVB80       |
| BV-120       | E28F004BVT120, E28F004BVB120, PA28F400BVT120, PA28F400BVB120                                                           |
| TBV-80       | TE28F004BVT80, TE28F004BVB80, TE28F400BVT80, TE28F400BVB80, TE28F400CVT80, TE28F400CVB80, TB28F400BVT80, TB28F400BVB80 |



#### 4.0 ABSOLUTE MAXIMUM RATINGS\*

| Commercial Operating Temperature                                                                               |
|----------------------------------------------------------------------------------------------------------------|
| During Read0°C to +70°C                                                                                        |
| During Block Erase and Word/Byte Write0°C to +70°C                                                             |
| Temperature Bias 10°C to 80°C                                                                                  |
| Extended Operating Temperature                                                                                 |
| During Read40°C to +85°C                                                                                       |
| During Block Erase and Word/Byte Write40°C to +85°C                                                            |
| Temperature Under Bias40°C to +85°C                                                                            |
| Storage Temperature $\dots -65^{\circ}\text{C to } + 125^{\circ}\text{C}$                                      |
| Voltage on Any Pin (except $V_{CC}$ , $V_{PP}$ , $A_9$ and $RP\#$ ) with Respect to GND $-2.0V$ to $+7.0V$ (2) |
| Voltage on Pin RP# or Pin A9 with Respect to GND $-2.0V$ to $+13.5V(2,3)$                                      |
| $V_{PP}$ Program Voltage with Respect to GND during Block Erase and Word/Byte Write2.0V to +14.0V(2,3)         |
| $V_{CC}$ Supply Voltage with Respect to GND 2.0V to +7.0V(2)                                                   |
| Output Short Circuit Current                                                                                   |
|                                                                                                                |

NOTICE: This document contains information on products in the design phase of development. Do not finalize a design with this information. Revised information will be published when the product is available. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES

- Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{\rm CC}+0.5V$  which, during transitions, may overshoot to  $V_{\rm CC}+2.0V$  for periods <20 ns.
- Maximum DC voltage on V<sub>PP</sub> may overshoot to +14.0V for periods <20 ns. Maximum DC voltage on RP# or A<sub>9</sub> may overshoot to 13.5V for periods <20 ns.</li>
- Output shorted for no more than one second. No more than one output shorted at a time.
- 10% V<sub>CC</sub> specifications reference the 28F400/ 004BV-60 in their standard test configurations, and 28F400/004BV-80/120.
- 5% V<sub>CC</sub> specifications reference the 28F400/004BV-60 in their high speed test configuration.



#### 5.0 COMMERCIAL OPERATING CONDITIONS

Table 11. Commercial Temperature and V<sub>CC</sub> Operating Conditions

| Symbol          | Parameter                                   | Notes | Min  | Max  | Units |
|-----------------|---------------------------------------------|-------|------|------|-------|
| T <sub>A</sub>  | Operating Temperature                       |       | 0    | 70   | °C    |
| V <sub>CC</sub> | 3.3V V <sub>CC</sub> Supply Voltage (±0.3V) |       | 3.0  | 3.6  | V     |
|                 | 5V V <sub>CC</sub> Supply Voltage (10%)     | 1     | 4.50 | 5.50 | V     |
|                 | 5V V <sub>CC</sub> Supply Voltage (5%)      | 2     | 4.75 | 5.25 | V     |

#### NOTES:

- 1. 10% V<sub>CC</sub> specifications apply to the 60, 80 and 120 ns product versions in their standard test configuration.
- 2. 5% V<sub>CC</sub> specifications apply to the 60 ns versions in their high speed test configuration.

### 5.1 Switching V<sub>CC</sub> Voltages

Table 12. V<sub>CC</sub> Supply Switching Timing

| Symbol            | Parameter                                     | Notes | Min | Max | Unit |  |
|-------------------|-----------------------------------------------|-------|-----|-----|------|--|
| T <sub>5VPH</sub> | V <sub>CC</sub> at 4.5V (minimum) to RP# High | 1     | 2   |     | μs   |  |
| T <sub>3VPH</sub> | V <sub>CC</sub> at 3.0V (minimum) to RP# High | 1     | 2   |     | μs   |  |

#### NOTE:

- 1. The T<sub>5VPH</sub> and/or T<sub>3VPH</sub> times must be strictly followed to guarantee all other read and write specifications.
- 2. To switch between 3.3V and 5.0V operation, the system should first transition  $V_{CC}$  from the existing voltage to GND, and then to the new voltage. The  $V_{CC}$  supply voltage should not be switched when the WSM is busy.



Figure 12. V<sub>CC</sub> Supply Switching Waveform



### 5.2 DC Characteristics

**Table 13. DC Characteristics (Commercial)** 

|                 |                                                     | . '   | BV-60 BV-60<br>BV-80 BV-80<br>BV-120 BV-120 |         |      |     | erciai) |       | t     |                                                                                                                                                                                                                                                                                                                     |
|-----------------|-----------------------------------------------------|-------|---------------------------------------------|---------|------|-----|---------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Parameter                                           | Notes |                                             | = 3.3V: |      |     | = 5V±   |       | Units | Test Conditions                                                                                                                                                                                                                                                                                                     |
|                 | ·                                                   |       | Min                                         | Тур     | Max  | Min | Тур     | Max   |       |                                                                                                                                                                                                                                                                                                                     |
| I <sub>IL</sub> | Input Load<br>Current                               | 1     |                                             |         | ±1.0 |     |         | ± 1.0 | μΑ    | $V_{CC} = V_{CC} MAX$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                   |
| lLO             | Output Leakage<br>Current                           | 1     |                                             |         | ± 10 |     |         | ± 10  | μΑ    | $V_{CC} = V_{CC} MAX$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                   |
| lccs            | V <sub>CC</sub> Standby<br>Current                  | 1,3   |                                             | 0.4     | 1.5  |     | 0.8     | 2.0   | mA    | $V_{CC} = V_{CC} MAX$ $CE\# = RP\# =$ $BYTE\# = WP\# = V_{IH}$                                                                                                                                                                                                                                                      |
|                 |                                                     |       |                                             | 60      | 110  |     | 50      | 130   | μΑ    | V <sub>CC</sub> = V <sub>CC</sub> MAX<br>CE# = RP# =<br>V <sub>CC</sub> ± 0.2V                                                                                                                                                                                                                                      |
| ICCD            | V <sub>CC</sub> Deep<br>Power-Down<br>Current       | 1     |                                             | 0.2     | 8    |     | 0.2     | 8     | μΑ    | $V_{CC} = V_{CC} \text{ MAX}$<br>$V_{IN} = V_{CC} \text{ or GND}$<br>$RP\# = \text{GND} \pm 0.2V$                                                                                                                                                                                                                   |
| ICCR            | V <sub>CC</sub> Read<br>Current for<br>Word or Byte | 1,5,6 |                                             | 15      | 30   |     | 50      | 60    | mA    | $\label{eq:cmosinputs} \begin{split} &\text{CMOS INPUTS} \\ &\text{$V_{CC} = V_{CC}$ MAX} \\ &\text{$CE\# = GND$} \\ &\text{$OE\# = V_{CC}$} \\ &\text{$f = 10$ MHz (5V),} \\ &\text{$5$ MHz (3.3V)$} \\ &\text{$I_{OUT} = 0$ mA} \\ &\text{$Inputs = GND \pm 0.2V$} \\ &\text{$or$ $V_{CC} \pm 0.2V$} \end{split}$ |
|                 |                                                     |       |                                             | 15      | 30   |     | 55      | 65    | mA    | TTL INPUTS  VCC = V <sub>CC</sub> MAX  CE# = V <sub>IL</sub> OE# = V <sub>IH</sub> f = 10 MHz (5V),  5 MHz (3.3V)  I <sub>OUT</sub> = 0 mA  Inputs = V <sub>IL</sub> or V <sub>IH</sub>                                                                                                                             |
| lccw            | V <sub>CC</sub> Write<br>Current for                | 1,4   |                                             | 13      | 30   |     | 30      | 50    | mA    | Word Write in Progress V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)                                                                                                                                                                                                                                                  |
|                 | Word or Byte                                        |       |                                             | 10      | 25   |     | 30      | 45    | mA    | Word Write in Progress $V_{PP} = V_{PPH2}$ (at 12V)                                                                                                                                                                                                                                                                 |



Table 13. DC Characteristics (Commercial) (Continued)

| <u> </u>          |                                                     |       |                 | BV-60           |        | (00 | BV-60           | , (00 | 1     |                                                                          |
|-------------------|-----------------------------------------------------|-------|-----------------|-----------------|--------|-----|-----------------|-------|-------|--------------------------------------------------------------------------|
| Symbol            | Parameter                                           | Notes |                 | BV-80<br>BV-120 |        |     | BV-80<br>BV-120 |       | Units | Test Conditions                                                          |
| •                 |                                                     |       | V <sub>CC</sub> | = 3.3V ±        | : 0.3V | Vcc | = <b>5V</b> ±   | 10%   |       |                                                                          |
|                   |                                                     |       | Min             | Тур             | Max    | Min | Тур             | Max   |       |                                                                          |
| ICCE              | V <sub>CC</sub> Erase<br>Current                    | 1,4   |                 | 13              | 30     |     | 18              | 35    | mA    | Block Erase in Progress<br>V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)   |
|                   |                                                     |       |                 | 10              | 25     |     | 18              | 30    | mA    | Block Erase in Progress $V_{PP} = V_{PPH2}$ (at 12V)                     |
| CCES              | V <sub>CC</sub> Erase<br>Suspend<br>Current         | 1,2   |                 | 3               | 8.0    |     | 5               | 10    | mA    | CE# = V <sub>IH</sub><br>Block Erase Suspend                             |
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby<br>Current                  | 1     |                 | ±5              | ±15    |     | ± 5             | ± 10  | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                        |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep<br>Power-down<br>Current       | 1     |                 | 0.2             | 10     |     | 0.2             | 5.0   | μΑ    | RP# = GND ± 0.2V                                                         |
| IPPR              | V <sub>PP</sub> Read<br>Current                     | 1     |                 | 50              | 200    |     | 30              | 200   | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                        |
| I <sub>PPW</sub>  | V <sub>PP</sub><br>Word/Byte                        | 1,4   |                 | 13              | 30     |     | 13              | 25    | mA    | V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)<br>Word Write in Progress    |
| ,                 | Write Current                                       |       |                 | 8               | 25     |     | 8               | 20    |       | V <sub>PP</sub> = V <sub>PPH2</sub> (at 12V)<br>Word Write in Progress   |
| I <sub>PPE</sub>  | V <sub>PP</sub> Erase<br>Current                    | 1,4   |                 | 13              | 30     |     | 10              | 20    | mA    | V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)<br>Block Erase in Progress   |
|                   |                                                     |       | ,               | 8               | 25     |     | 5               | 15    |       | V <sub>PP</sub> = V <sub>PPH2</sub> (at 12V)<br>Block Erase in Progress  |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase<br>Suspend<br>Current         | 1     |                 | 50              | 200    |     | 30              | 200   | μΑ    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspend<br>in Progress |
| I <sub>RP#</sub>  | RP# Boot<br>Block Unlock<br>Current                 | 1,4   |                 |                 | 500    |     |                 | 500   | μΑ    | RP# = V <sub>HH</sub>                                                    |
| l <sub>ID</sub>   | A <sub>9</sub> Intelligent<br>Identifier<br>Current | 1,4   |                 |                 | 500    |     |                 | 500   | μA    | $A_9 = V_{ID}$                                                           |



Table 13. DC Characteristics (Commercial) (Continued)

| Symbol            | Parameter                                        | BV-60<br>BV-80<br>BV-120 |                          |     |                           |                          | BV-60<br>BV-80<br>3V-120 |                           | Units | Test Conditions                             |
|-------------------|--------------------------------------------------|--------------------------|--------------------------|-----|---------------------------|--------------------------|--------------------------|---------------------------|-------|---------------------------------------------|
|                   |                                                  |                          | $V_{CC} = 3.3V \pm 0.3V$ |     |                           | V <sub>CC</sub>          | = <b>5V</b> ±            | 10%                       |       |                                             |
|                   | ·                                                |                          | Min                      | Тур | Max                       | Min                      | Тур                      | Max                       |       |                                             |
| V <sub>ID</sub>   | A <sub>9</sub> Intelligent<br>Identifier Voltage |                          | 11.4                     |     | 12.6                      | 11.4                     |                          | 12.6                      | ٧     | ,                                           |
| V <sub>IL</sub>   | Input Low Voltage                                |                          | -0.5                     |     | 0.8                       | -0.5                     |                          | 0.8                       | ٧     |                                             |
| V <sub>IH</sub>   | Input High<br>Voltage                            |                          | 2.0                      |     | V <sub>CC</sub><br>+ 0.5V | 2.0                      |                          | V <sub>CC</sub><br>+ 0.5V | ٧     |                                             |
| V <sub>OL</sub>   | Output Low<br>Voltage                            |                          |                          |     | 0.45                      |                          |                          | 0.45                      | ٧     | $V_{CC} = V_{CC} MIN$ $I_{OL} = 5.8 mA$     |
| V <sub>OH1</sub>  | Output High<br>Voltage (TTL)                     |                          | 2.4                      |     |                           | 2.4                      |                          |                           | ٧     | $V_{CC} = V_{CC} MIN$<br>$I_{OH} = -2.5 mA$ |
| V <sub>OH2</sub>  | Output High<br>Voltage                           |                          | 0.85V <sub>CC</sub>      |     |                           | 0.85V <sub>CC</sub>      |                          |                           | ٧     | $V_{CC} = V_{CC} MIN$<br>$I_{OH} = -2.5 mA$ |
|                   | (CMOS)                                           |                          | V <sub>CC</sub><br>-0.4V |     |                           | V <sub>CC</sub><br>-0.4V |                          |                           |       | $V_{CC} = V_{CC} MIN$ $I_{OH} = -100 \mu A$ |
| V <sub>PPLK</sub> | V <sub>PP</sub> Lock-Out<br>Voltage              | 3                        | 0.0                      |     | 1.5                       | 0.0                      |                          | 1.5                       | ٧     | Complete Write Protection                   |
| V <sub>PPH1</sub> | V <sub>PP</sub> (Program/<br>Erase Operations)   |                          | 4.5                      |     | 5.5                       | 4.5                      |                          | 5.5                       | ٧     | V <sub>PP</sub> at 5V                       |
| V <sub>PPH2</sub> | V <sub>PP</sub> (Program/<br>Erase Operations)   |                          | 11.4                     |     | 12.6                      | 11.4                     |                          | 12.6                      | ٧     | V <sub>PP</sub> at 12V                      |
| V <sub>LKO</sub>  | V <sub>CC</sub> Erase/Write<br>Lock Voltage      | 8                        | 2.0                      |     |                           | 2.0                      |                          |                           | ٧     | · .                                         |
| V <sub>HH</sub>   | RP# Unlock<br>Voltage                            |                          | 11.4                     |     | 12.6                      | 11.4                     |                          | 12.6                      | ٧     | Boot Block<br>Write/Erase                   |

#### NOTES:

- All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, T = 25°C. These currents are valid for all product versions (packages and speeds).
- 2. I<sub>CCES</sub> is specified with the device deselected. If the device is read while in erase suspend mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCR</sub>.
- Block erases and word/byte writes are inhibited when V<sub>PP</sub> = V<sub>PPLK</sub>, and not guaranteed in the range between V<sub>PPH1</sub> and V<sub>PPLK</sub>.
- 4. Sampled, not 100% tested.
- 5. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA typical, in static operation.
- 6. CMOS Inputs are either  $V_{CC}$   $\pm$  0.2V or GND  $\pm$  0.2V. TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .
- 7. For the 28F004, address pin  $A_{10}$  follows the  $C_{\mbox{OUT}}$  capacitance numbers.
- 8. For all BV parts,  $V_{LKO} = 2.0V$  for both 3.3V and 5V operations.





Figure 13. 3.3V Inputs and Measurement Points



Figure 14. 3.3V Standard Test Configuration



Figure 15. 5V Inputs and Measurement Points



Figure 16. 5V Standard Test Configuration



Figure 17. 5V High Speed Test Configuration



### 5.3 AC Characteristics

Table 14. AC Characteristics: Read Only Operations (Commercial)

|                   |                                                                               |      |     |      | BV     | /-60 |       |      |       |
|-------------------|-------------------------------------------------------------------------------|------|-----|------|--------|------|-------|------|-------|
|                   |                                                                               | Vcc  | 5V: | ± 5% | 5V ±   | 10%  | 3.3 ± | 0.3V |       |
|                   |                                                                               | Load | 30  | pF   | 100 pF |      | 50 pF |      |       |
| Symbol            | Parameter                                                                     | Note | Min | Max  | Min    | Max  | Min   | Max  | Units |
| t <sub>AVAV</sub> | Read Cycle Time                                                               |      | 60  |      | 70     |      | 110   |      | ns    |
| t <sub>AVQV</sub> | Address to Output Delay                                                       |      |     | 60   |        | 70   |       | 110  | ns    |
| tELQV             | CE# to Output Delay                                                           | 2    |     | 60   |        | 70   |       | 110  | ns    |
| t <sub>PHQV</sub> | RP# to Output Delay                                                           |      |     | 450  |        | 450  |       | 800  | ns    |
| tGLQV             | OE# to Output Delay                                                           | 2    |     | 30   |        | 35   |       | 65   | ns    |
| tELQX             | CE# to Output in Low Z                                                        | 3    | 0   |      | 0      |      | 0     |      | ns    |
| t <sub>EHQZ</sub> | CE# to Output in High Z                                                       | 3    |     | 20   |        | 25   |       | 55   | ns    |
| tGLQX             | OE# to Output in Low Z                                                        | 3    | 0   |      | 0      |      | 0     |      | ns    |
| tGHQZ             | OE# to Output in High Z                                                       | 3    |     | 20   |        | 25   |       | 45   | ns    |
| tон               | Output Hold from<br>Address, CE#, or OE#<br>change, whichever<br>occurs first | 3    | 0   | -    | 0      |      | 0     |      | ns    |
| t <sub>ELFL</sub> | CE# Low to BYTE#<br>High or Low                                               | 3    |     | 5    |        | 5    |       | 7    | ns    |
| t <sub>AVFL</sub> | Address to BYTE# High or Low                                                  | 3    |     | 5    |        | 5    |       | 7    | ns    |
| t <sub>FLQV</sub> | BYTE# to Output Delay                                                         | 3,4  |     | 60   |        | 70   |       | 110  | ns    |
| t <sub>FLQZ</sub> | BYTE# Low to Output in High Z                                                 | 3    |     | 20   |        | 25   |       | 45   | ns    |



#### 5.3 AC Characteristics

Table 14. AC Characteristics: Read Only Operations (Commercial) (Continued)

|                                        |                                                                                     |      |      | BV   | -80  |       |      | BV-  | -120 |        |       |
|----------------------------------------|-------------------------------------------------------------------------------------|------|------|------|------|-------|------|------|------|--------|-------|
|                                        |                                                                                     | Vcc  | 5V ± | 10%  | 3.3V | ±0.3V | 5V ± | 10%  | 3.3V | ± 0.3V |       |
|                                        |                                                                                     | Load | 100  | ) pF | 50   | pF    | 100  | ) pF | 50   | pF     | }     |
| Symbol                                 | Parameter                                                                           | Note | Min  | Max  | Min  | Max   | Min  | Max  | Min  | Max    | Units |
| t <sub>AVAV</sub>                      | Read Cycle Time                                                                     |      | 80   |      | 150  |       | 120  |      | 180  |        | ns    |
| t <sub>AVQV</sub>                      | Address to<br>Output Delay                                                          |      |      | 80   |      | 150   |      | 120  |      | 180    | ns    |
| t <sub>ELQV</sub>                      | CE# to Output<br>Delay                                                              | 2    |      | 80   |      | 150   | :    | 120  |      | 180    | ns    |
| t <sub>PHQV</sub>                      | RP# to Output<br>Delay                                                              |      |      | 450  |      | 800   |      | 450  |      | 800    | ns    |
| t <sub>GLQV</sub>                      | OE# to Output<br>Delay                                                              | 2    |      | 40   |      | 90    |      | 40   |      | 90     | ns    |
| t <sub>ELQX</sub>                      | CE# to Output in Low Z                                                              | 3    | 0    |      | 0    |       | 0    |      | 0    |        | ns    |
| t <sub>EHQZ</sub>                      | CE# to Output in High Z                                                             | 3    |      | 30   |      | 80    |      | 30   |      | 80     | ņs    |
| t <sub>GLQX</sub>                      | OE# to Output in Low Z                                                              | 3    | 0    |      | 0    |       | 0    |      | 0    | ,      | ns    |
| t <sub>GHQZ</sub>                      | OE# to Output in High Z                                                             | 3    |      | 30   |      | 60    |      | 30   |      | 60     | ns    |
| <sup>t</sup> OH                        | Output Hold<br>from Address,<br>CE#, or OE#<br>change,<br>whichever<br>occurs first | 3    | 0    |      | 0    |       | 0    |      | 0    |        | ns    |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> | CE# Low to<br>BYTE# High or<br>Low                                                  | 3    |      | 5    |      | 10    |      | 5    |      | 10     | ns    |
| t <sub>AVFL</sub>                      | Address to<br>BYTE# High or<br>Low                                                  | 3    |      | 5    |      | 10    |      | 5    |      | 10     | ns    |
| t <sub>FLQV</sub>                      | BYTE# to<br>Output Delay                                                            | 3,4  |      | 80   |      | 150   |      | 120  |      | 180    | ns    |
| t <sub>FLQZ</sub>                      | BYTE# Low to<br>Output in High Z                                                    | 3    |      | 30   |      | 60    |      | 30   |      | 60     | ns    |

#### NOTES:

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub> t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, but not 100% tested.
- 4. t<sub>FLQV</sub>, BYTE# switching low to valid output delay will be equal to t<sub>AVQV</sub>, measured from the time DQ<sub>15</sub>/A<sub>-1</sub> becomes valid.
- 5. See 5V High Speed Test Configuration.
- 6. See 5V Standard Test Configuration.
- 7. See 3.3V Test Configuration.





Figure 18. AC Waveforms for Read Operations



Figure 19. BYTE # Timing Diagram for Both Read and Write Operations with  $V_{CC}$  at 5.0V



Table 15. AC Characteristics: WE#—Controlled Write Operations(1) (Commercial)

|                    |                                                |       |     |      | B\           | /-60 |       |        |       |
|--------------------|------------------------------------------------|-------|-----|------|--------------|------|-------|--------|-------|
|                    | '                                              | Vcc   | 5V: | ± 5% | 5 <b>V</b> ± | 10%  | 3.3   | ± 0.3V |       |
|                    |                                                | Load  | 30  | pF   | 10           | 0 pF | 50 pF |        |       |
| Symbol             | Parameter                                      | Note  | Min | Max  | Min          | Max  | Min   | Max    | Units |
| t <sub>AVAV</sub>  | Write Cycle Time                               |       | 60  |      | 70           |      | 110   |        | ns    |
| t <sub>PHWL</sub>  | RP# Setup to WE#<br>Going Low                  |       | 450 |      | 450          |      | 800   |        | ns    |
| <sup>t</sup> ELWL  | CE# Setup to WE#<br>Going Low                  |       | 0   |      | 0            |      | 0     |        | ns    |
| <sup>t</sup> PHHWH | Boot Block Lock Setup<br>to WE# Going High     | 6,8   | 100 |      | 100          |      | 200   |        | ns    |
| t <sub>VPWH</sub>  | V <sub>PP</sub> Setup to WE#<br>Going High     | 5,8   | 100 |      | 100          |      | 200   |        | ns    |
| tavwh              | Address Setup to WE#<br>Going High             | 3     | 50  |      | 50           |      | 90    |        | ns    |
| <sup>t</sup> DVWH  | Data Setup to WE#<br>Going High                | 4     | 50  |      | 50           |      | 90    |        | ns    |
| twLWH              | WE# Pulse Width                                |       | 50  |      | 50           |      | 90    |        | ns    |
| t <sub>WHDX</sub>  | Data Hold Time from WE# High                   | 4     | 0   |      | 0            |      | 0     |        | ns    |
| twhax              | Address Hold Time from WE# High                | 3     | 10  |      | 10           |      | 10    |        | ns    |
| t <sub>WHEH</sub>  | CE# Hold Time from<br>WE# High                 |       | 0   |      | 0            |      | 0 .   |        | ns    |
| twhwL              | WE# Pulse Width High                           |       | 10  |      | 20           |      | 20    |        | ns    |
| <sup>t</sup> WHQV1 | Duration of Word/Byte<br>Programming Operation | 2,5   | 6   |      | 6            |      | 6     |        | μs    |
| t <sub>WHQV2</sub> | Duration of Erase<br>Operation (Boot)          | 2,5,6 | 0.3 |      | 0.3          |      | 0.3   |        | s     |
| twHQV3             | Duration of Erase<br>Operation (Parameter)     | 2,5   | 0.3 |      | 0.3          |      | 0.3   |        | s     |
| t <sub>WHQV4</sub> | Duration of Erase<br>Operation (Main)          | 2,5   | 0.6 |      | 0.6          |      | 0.6   |        | s     |
| tQWL               | V <sub>PP</sub> Hold from Valid<br>SRD         | 5,8   | 0   |      | 0            |      | 0     |        | ns    |
| <sup>t</sup> QVPH  | RP# V <sub>HH</sub> Hold from<br>Valid SRD     | 6,8   | 0   |      | 0            |      | 0     |        | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock<br>Delay                     | 7,8   |     | 100  |              | 100  |       | 200    | ns    |



Table 15. AC Characteristics: WE#—Controlled Write Operations<sup>(1)</sup> (Commercial) (Continued)

|                            |                                                    |       |              | BV   | -80   |      |     |     |       |      |       |
|----------------------------|----------------------------------------------------|-------|--------------|------|-------|------|-----|-----|-------|------|-------|
|                            |                                                    | Vcc   | 5 <b>V</b> ± | 10%  | 3.3 ± | 0.3V | 5V± | 10% | 3.3 ± | 0.3V | }     |
|                            |                                                    | Load  | 100          | ) pF | 50    | pF   | 100 | pF  | 50    | pF   | 1     |
| Symbol                     | Parameter                                          | Note  | Min          | Max  | Min   | Max  | Min | Max | Min   | Max  | Units |
| t <sub>AVAV</sub>          | Write Cycle Time                                   |       | 80           |      | 150   |      | 120 |     | 180   |      | ns    |
| <sup>†</sup> PH <b>W</b> L | RP# Setup to<br>WE# Going Low                      |       | 450          |      | 1000  |      | 450 | 1   | 1000  |      | ns    |
| <sup>t</sup> ELWL          | CE# Setup to<br>WE# Going Low                      |       | 0            |      | 0 .   |      | 0   |     | 0     |      | ns    |
| <sup>t</sup> PHHWH         | Boot Block Lock<br>Setup to WE#<br>Going High      | 6,8   | 100          |      | 200   |      | 100 |     | 200   |      | ns    |
| t <sub>VPWH</sub>          | V <sub>PP</sub> Setup to WE#<br>Going High         | 5,8   | 100          |      | 200   |      | 100 |     | 200   |      | ns    |
| tavwh                      | Address Setup to WE# Going High                    | 3     | 50           |      | 120   |      | 50  |     | 150   |      | ns    |
| <sup>t</sup> DVWH          | Data Setup to WE# Going High                       | 4     | 50           |      | 120   |      | 50  |     | 150   |      | ns    |
| twLWH                      | WE# Pulse Width                                    |       | 50           |      | 120   |      | 50  |     | 150   |      | ns    |
| twHDX                      | Data Hold Time<br>from WE# High                    | 4     | 0            | -    | 0     |      | . 0 |     | 0     |      | ns    |
| twhax                      | Address Hold Time from WE# High                    | 3     | 10           |      | 10    |      | 10  |     | 10    |      | ns    |
| twheh                      | CE# Hold Time<br>from WE# High                     |       | . 0          |      | 0     |      | 0   | ,   |       |      | ns    |
| twhwL                      | WE# Pulse Width<br>High                            |       | 30           |      | 30    |      | 30  |     | 30    |      | ns    |
| twHQV1                     | Duration of Word/<br>Byte Programming<br>Operation | 2,5   | 6            |      | 6     | -    | 6   |     | 6     |      | μs    |
| t <sub>WHQV2</sub>         | Duration of Erase<br>Operation (Boot)              | 2,5,6 | 0.3          |      | 0.3   |      | 0.3 |     | 0.3   |      | s     |
| twHQV3                     | Duration of Erase<br>Operation<br>(Parameter)      | 2,5   | 0.3          |      | 0.3   |      | 0.3 |     | 0.3   |      | s     |
| t <sub>WHQV4</sub>         | Duration of Erase<br>Operation (Main)              | 2,5   | 0.6          |      | 0.6   |      | 0.6 |     | 0.6   |      | s     |
| t <sub>QWL</sub>           | V <sub>PP</sub> Hold from<br>Valid SRD             | 5,8   | 0            |      | 0     |      | 0   |     | 0     |      | ns    |
| tQVPH                      | RP# V <sub>HH</sub> Hold<br>from Valid SRD         | 6,8   | 0            |      | 0.    |      | 0   |     | 0     |      | ns    |
| t <sub>PHBR</sub>          | Boot-Block Relock<br>Delay                         | 7,8   |              | 100  |       | 200  |     | 100 |       | 200  | ns    |



#### NOTES:

- Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during read mode.
- The on-chip WSM completely automates Program/Erase operations; Program/Erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- 4. Refer to command definition table for valid DIN.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7=1).
- For boot block program/erase, RP# should be held at V<sub>HH</sub> or WP# should be held at VIH until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the boot block.
- 8. Sampled, but not 100% tested.
- 9. Vpp at 5.0V.
- 10. Vpp at 12.0V.
- 11. See 5V High Speed Test Configuration.
- 12. See 5V Standard Test Configuration.
- 13. See 3.3V Test Configuration.



Figure 20. AC Waveforms for Write and Erase Operations (WE#-Controlled Writes)



Table 16. AC Characteristics: CE#-Controlled Write Operations<sup>(1,13)</sup> (Commercial)

|                     |                                                |                 | BV-60 |     |             |          |       |       |              |  |  |
|---------------------|------------------------------------------------|-----------------|-------|-----|-------------|----------|-------|-------|--------------|--|--|
| 1                   | 1                                              | v <sub>cc</sub> | 5V :  | ±5% | <b>5V</b> ± | 10%      | 3.3 ± | :0.3V |              |  |  |
|                     |                                                | Load            | 30    | pF  | 10          | 0 pF     | 50    | pF    |              |  |  |
| Symbol              | Parameter                                      | Note            | Min   | Max | Min         | Max      | Min   | Max   | Units        |  |  |
| t <sub>AVAV</sub>   | Write Cycle Time                               |                 | 60    |     | 70          |          | 110   |       | ns           |  |  |
| t <sub>PHEL</sub>   | RP# High Recovery<br>to CE# Going Low          |                 | 450   |     | 450         |          | 1000  |       | ns           |  |  |
| <sup>t</sup> WLEL   | WE# Setup to CE#<br>Going Low                  |                 | . 0   |     | 0           |          | 0     |       | ns           |  |  |
| <sup>t</sup> PHHEH  | Boot Block Lock Setup to CE# Going High        | 6,8             | 100   |     | 100         |          | 200   |       | ns           |  |  |
| t <sub>VPEH</sub>   | V <sub>PP</sub> Setup to CE#<br>Going High     | 5,8             | 100   |     | 100         |          | 200   |       | ns           |  |  |
| t <sub>AVEH</sub>   | Address Setup to CE#<br>Going High             | 3               | 50    |     | 50          |          | 90    |       | ns           |  |  |
| <sup>t</sup> DVEH   | Data Setup to CE#<br>Going High                | 4               | 50    |     | 50          |          | 90    |       | ns           |  |  |
| t <sub>ELEH</sub>   | CE# Pulse Width                                |                 | 50    |     | 50          |          | 90    |       | ns           |  |  |
| t <sub>EHDX</sub> . | Data Hold Time from<br>CE# High                | 4               | 0     | ,   | 0           |          | 0     |       | ns           |  |  |
| t <sub>EHAX</sub>   | Address Hold Time from CE# High                | 3               | 10    |     | 10          |          | 10    | , , , | ns           |  |  |
| t <sub>EHWH</sub>   | WE # Hold Time from<br>CE# High                |                 | 0     |     | 0           |          | 0     |       | ns           |  |  |
| t <sub>EHEL</sub>   | CE# Pulse Width High                           |                 | 10    |     | 20          | <u> </u> | 20    |       | ns           |  |  |
| tEHQV1              | Duration of Word/Byte<br>Programming Operation | 2,5             | 6     |     | 6           |          | 6     |       | μs           |  |  |
| t <sub>EHQV2</sub>  | Duration of Erase<br>Operation (Boot)          | 2,5,6           | 0.3   |     | 0.3         |          | 0.3   | •     | s            |  |  |
| t <sub>EHQV3</sub>  | Duration of Erase<br>Operation (Parameter)     | 2,5             | 0.3   | 1 - | 0.3         |          | 0.3   |       | <u>.</u> . S |  |  |
| t <sub>EHQV4</sub>  | Duration of Erase<br>Operation (Main)          | 2,5             | 0.6   |     | 0.6         |          | 0.6   |       | s            |  |  |
| tQWL                | V <sub>PP</sub> Hold from Valid<br>SRD         | 5,8             | 0     |     | 0           |          | 0     |       | ns           |  |  |
| tQVPH               | RP# V <sub>HH</sub> Hold from<br>Valid SRD     | 6,8             | 0     |     | 0           |          | 0     |       | ns           |  |  |
| t <sub>PHBR</sub>   | Boot-Block Relock<br>Delay                     | 7,8             |       | 100 |             | 100      |       | 200   | ns           |  |  |



Table 16. AC Characteristics: CE#-Controlled Write Operations(1,13) (Commercial) (Continued)

|                    |                                                    |       |      | в۷   | -80   |      |              | BV-  | -120  |      |       |
|--------------------|----------------------------------------------------|-------|------|------|-------|------|--------------|------|-------|------|-------|
|                    | ,                                                  | Vcc   | 5V ± | 10%  | 3.3 ± | 0.3V | 5 <b>V</b> ± | 10%  | 3.3 ± | 0.3V | 1     |
|                    |                                                    | Load  | 100  | ) pF | 50    | pF   | 100          | ) pF | 50    | pF   | ]     |
| Symbol             | Parameter                                          | Note  | Min  | Max  | Min   | Max  | Min          | Max  | Min   | Max  | Units |
| t <sub>AVAV</sub>  | Write Cycle Time                                   |       | 80   |      | 150   |      | 120          |      | 180   |      | ns    |
| t <sub>PHEL</sub>  | RP# High Recovery to CE# Going Low                 |       | 450  |      | 1000  |      | 450          |      | 1000  |      | ns    |
| tWLEL              | WE# Setup to CE#<br>Going Low                      |       | 0    |      | 0     |      | 0            |      | 0     |      | ns    |
| t <sub>PHHEH</sub> | Boot Block Lock<br>Setup to CE#<br>Going High      | 6,8   | 100  |      | 200   |      | 100          |      | 200   |      | ns    |
| t <sub>VPEH</sub>  | V <sub>PP</sub> Setup to CE#<br>Going High         | 5,8   | 100  |      | 200   |      | 100          |      | 200   |      | ns    |
| t <sub>AVEH</sub>  | Address Setup to CE# Going High                    | 3     | 50   |      | 120   |      | 50           |      | 150   |      | ns    |
| t <sub>DVEH</sub>  | Data Setup to CE#<br>Going High                    | 4     | 50   |      | 120   |      | 50           |      | 150   |      | ns    |
| t <sub>ELEH</sub>  | CE# Pulse Width                                    |       | 50   |      | 120   |      | 50           |      | 150   |      | ns    |
| t <sub>EHDX</sub>  | Data Hold Time from CE# High                       | 4     | 0    |      | 0     |      | 0.           |      | 0     |      | ns    |
| t <sub>EHAX</sub>  | Address Hold Time from CE# High                    | 3     | 10   |      | 10    |      | 10           |      | 10    |      | ns    |
| t <sub>EHWH</sub>  | WE # Hold Time<br>from CE# High                    |       | 0    |      | 0     |      | 0            |      | 0     |      | ns    |
| t <sub>EHEL</sub>  | CE# Pulse Width<br>High                            |       | 30   |      | 30    |      | 30           |      | 30    |      | ns    |
| t <sub>EHQV1</sub> | Duration of Word/<br>Byte Programming<br>Operation | 2,5   | 6    |      | 6     |      | 6            |      | 6     |      | μs    |
| t <sub>EHQV2</sub> | Duration of Erase<br>Operation (Boot)              | 2,5,6 | 0.3  |      | 0.3   |      | 0.3          |      | 0.3   |      | s     |
| t <sub>EHQV3</sub> | Duration of Erase<br>Operation<br>(Parameter)      | 2,5   | 0.3  |      | 0.3   |      | 0.3          |      | 0.3   |      | S     |
| t <sub>EHQV4</sub> | Duration of Erase<br>Operation (Main)              | 2,5   | 0.6  |      | 0.6   |      | 0.6          |      | 0.6   |      | s     |
| t <sub>QWL</sub>   | V <sub>PP</sub> Hold from Valid<br>SRD             | 5,8   | 0    |      | 0     |      | 0            |      | 0     |      | ns    |
| t <sub>QVPH</sub>  | RP# V <sub>HH</sub> Hold from<br>Valid SRD         | 6,8   | 0    |      | 0     |      | 0            |      | 0     | ,    | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock<br>Delay                         | 7,8   |      | 100  |       | 200  |              | 100  |       | 200  | ns    |

## NOTES:

See WE#-Controlled Write Operations for notes 1 through 12.

<sup>13.</sup> Chip-Enable controlled writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.





Figure 21. Alternate AC Waveforms for Write and Erase Operations (CE#—Controlled Writes)

Table 17. Erase and Program Timings (Commercial  $T_A = 0$ °C to +70°C)

|                                   | V <sub>PP</sub> =5                                                                | V ± 10% | V <sub>PP</sub> = 12            | 2V ±5%                        |       |  |
|-----------------------------------|-----------------------------------------------------------------------------------|---------|---------------------------------|-------------------------------|-------|--|
| Parameter                         | V <sub>CC</sub> =         V <sub>CC</sub> =           3.3 ± 0.3V         5V ± 10% |         | V <sub>CC</sub> =<br>3.3 ± 0.3V | V <sub>CC</sub> =<br>5V ± 10% | Units |  |
|                                   | Тур                                                                               | Тур     | Тур                             | Тур                           |       |  |
| Boot/Parameter Block Erase Time   | 0.84                                                                              | 0.8     | 0.44                            | 0.34                          | S     |  |
| Main Block Erase Time             | 2.4                                                                               | 1.9     | 1.3                             | 1.1                           | S     |  |
| Main Block Write Time (Byte Mode) | 1.7                                                                               | 1.8     | 1.6                             | 1.2                           | S     |  |
| Main Block Write Time (Word Mode) | 1.1                                                                               | 0.9     | 0.8                             | 0.6                           | S     |  |
| Byte Write Time                   | 10                                                                                | 10      | 8                               | 8                             | μs    |  |
| Word Write Time                   | 13                                                                                | 13      | 8                               | 8                             | μs    |  |

#### NOTES

<sup>1.</sup> All numbers are sampled, not 100% tested.

<sup>2.</sup> Contact your Intel representative for information regarding maximum Byte/Word Write specifications.



## **6.0 EXTENDED OPERATING CONDITIONS**

Table 18. Extended Temperature and V<sub>CC</sub> Operating Conditions

| Symbol         | Parameter                                   | Notes | Min  | Max  | Units |
|----------------|---------------------------------------------|-------|------|------|-------|
| T <sub>A</sub> | Operating Temperature                       |       | -40  | 85   | °C    |
| Vcc            | 3.3V V <sub>CC</sub> Supply Voltage (±0.3V) | 1     | 3.0  | 3.6  | Volts |
|                | 5V V <sub>CC</sub> Supply Voltage (10%)     | 2     | 4.50 | 5.50 | Volts |

## 6.1 Applying V<sub>CC</sub> Voltages

Table 19. V<sub>CC</sub> Supply Switching Timing

|                   | 30 1.7                                        |       |     |     |       |
|-------------------|-----------------------------------------------|-------|-----|-----|-------|
| Symbol            | Parameter                                     | Notes | Min | Max | Units |
| T <sub>5VPH</sub> | V <sub>CC</sub> at 4.5V (minimum) to RP# High | 1     | 2   |     | μs    |
| T <sub>3VPH</sub> | V <sub>CC</sub> at 3.0V (minimum) to RP# High | 1     | 2   |     | μs    |

 The T<sub>5VPH</sub> and/or T<sub>3VPH</sub> times must be strictly followed to guarantee all other read and write specifications.
 To switch between 3.3V and 5.0V operation, the system should first transition V<sub>CC</sub> from the existing voltage to GND, and then to the new voltage. The V<sub>CC</sub> supply voltage should not be switched when the WSM is busy.



Figure 22. V<sub>CC</sub> Supply Switching Waveform

<sup>1.</sup> AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.

<sup>2. 10%</sup> V<sub>CC</sub> specifications apply to 110 ns and 80 ns versions in their standard test configuration.



## 6.2 DC Characteristics

**Table 20. DC Characteristics: Extended Temperature Operation** 

|                 |                                                      |       |                 | TBV-80 TBV-80 | ١.     |                   |               |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|------------------------------------------------------|-------|-----------------|---------------|--------|-------------------|---------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Parameter                                            | Notes | V <sub>CC</sub> | = 3.3         | ± 0.3V | v <sub>cc</sub> = | = <b>5V</b> ± | 10%   | Unit | Test Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 |                                                      |       | Min             | Тур           | Max    | Min               | Тур           | Max   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| l <sub>IL</sub> | Input Load<br>Current                                | 1     |                 |               | ± 1.0  |                   |               | ± 1.0 | μΑ   | $V_{CC} = V_{CC} MAX$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                              |
| lLO             | Output Leakage<br>Current                            | 1     |                 |               | ± 10   |                   |               | ± 10  | μΑ   | $V_{CC} = V_{CC} MAX$ $V_{IN} = V_{CC}$ or GND                                                                                                                                                                                                                                                                                                                                                                                                 |
| Iccs            | V <sub>CC</sub> Standby<br>Current                   | 1,3   |                 | 0.4           | 1.5    |                   | 0.8           | 2.5   | mA   | $V_{CC} = V_{CC} MAX$ $CE\# = RP\# =$ $BYTE\# = V_{IH}$                                                                                                                                                                                                                                                                                                                                                                                        |
|                 |                                                      |       |                 | 60            | 110    |                   | 70            | 150   | μΑ   | $V_{CC} = V_{CC} MAX$ $CE\# = RP\# = WP\#$ $= V_{CC} \pm 0.2V$                                                                                                                                                                                                                                                                                                                                                                                 |
| ICCD            | V <sub>CC</sub> Deep<br>Power-Down<br>Current        | 1     |                 | 0.2           | 8      |                   | 0.2           | 8     | μΑ   | $V_{CC} = V_{CC} \text{ MAX}$<br>$V_{IN} = V_{CC} \text{ or GND}$<br>$RP\# = \text{GND} \pm 0.2V$                                                                                                                                                                                                                                                                                                                                              |
| ICCR            | V <sub>CC</sub> Read<br>Current for<br>Word or Byte  | 1,5,6 |                 | 15            | 30     |                   | 50            | 65    | mA   | $\label{eq:cmosinputs} \begin{split} &\text{CMOS INPUTS} \\ &\text{$V_{CC} = V_{CC}$ MAX} \\ &\text{$CE = GND$,} \\ &\text{$OE\# = V_{CC}$} \\ &\text{$f = 10$ MHz (5V),} \\ &\text{$5$ MHz (3.3V)} \\ &\text{$I_{OUT} = 0$ mA} \\ &\text{$Inputs = GND \pm 0.2V$} \\ &\text{$oV_{CC} \pm 0.2V$} \end{split}$                                                                                                                                  |
|                 |                                                      |       |                 | 15            | 30     |                   | 55            | 70    | mA   | $\label{eq:total_continuity} \begin{split} & \textbf{TTL INPUTS} \\ & \textbf{V}_{CC} = \textbf{V}_{CC}  \textbf{MAX} \\ & \textbf{CE} \# = \textbf{V}_{IL} \\ & \textbf{OE} \# = \textbf{V}_{IH} \\ & \textbf{f} = \textbf{10}  \textbf{MHz}  (\textbf{5V}), \\ & \textbf{5}  \textbf{MHz}  (\textbf{3.3V}) \\ & \textbf{I}_{OUT} = \textbf{0}  \textbf{mA} \\ & \textbf{Inputs} = \textbf{V}_{IL}  \textbf{or}  \textbf{V}_{IH} \end{split}$ |
| Iccw            | V <sub>CC</sub> Write<br>Current for<br>Word or Byte | 1,4   |                 | 13            | 30     |                   | 30            | 50    | mA   | Word/Byte Program<br>in Progress<br>V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)                                                                                                                                                                                                                                                                                                                                                                |
|                 | ,                                                    |       |                 | 10            | 25     |                   | 30            | 45    | mA   | Word/Byte Program<br>in Progress<br>V <sub>PP</sub> = V <sub>PPH2</sub> (at 12V)                                                                                                                                                                                                                                                                                                                                                               |



**Table 20. DC Characteristics: Extended Temperature Operation (Continued)** 

|                   |                                                   |       | TBV-80            |       |        | 7                 | TBV-80        |      |       |                                                                                                               |
|-------------------|---------------------------------------------------|-------|-------------------|-------|--------|-------------------|---------------|------|-------|---------------------------------------------------------------------------------------------------------------|
| Symbol            | Parameter                                         | Notes | V <sub>CC</sub> = | = 3.3 | ± 0.3V | V <sub>CC</sub> = | = <b>5V</b> ± | 10%  | Units | Test Conditions                                                                                               |
|                   |                                                   |       | Min               | Тур   | Max    | Min               | Тур           | Max  |       |                                                                                                               |
| ICCE              | V <sub>CC</sub> Erase<br>Current                  | 1,4   |                   | 13    | 30     |                   | 22            | 45   | mA    | Block Erase in Progress<br>V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)                                        |
|                   |                                                   |       |                   | 10    | 25     |                   | 18            | 40   | mA    | Block Erase<br>in Progress<br>V <sub>PP</sub> = V <sub>PPH2</sub> (at 12V)                                    |
| ICCES             | V <sub>CC</sub> Erase<br>Suspend<br>Current       | 1,2   |                   | 3     | 8.0    | ,                 | 5             | 12.0 | mA    | CE# = V <sub>IH</sub><br>Block Erase Suspend<br>V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)                   |
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby<br>Current                | . 1   |                   | ± 5   | ± 15   |                   | ± 5           | ± 15 | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                             |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep<br>Power-down<br>Current     | 1 ,   |                   | 0.2   | 10     |                   | 0.2           | 10   | μΑ    | RP# = GND ± 0.2V                                                                                              |
| IPPR              | V <sub>PP</sub> Read<br>Current                   | 1     |                   | 50    | 200    |                   | 50            | 200  | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                                                             |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write<br>Current for<br>Word/Byte | 1,4   |                   | 13    | 30     |                   | 13            | 30   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress<br>V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)   |
|                   |                                                   |       |                   | 8     | 25     |                   | 8             | 25   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress<br>V <sub>PP</sub> = V <sub>PPH2</sub> (at 12V)  |
| IPPE              | V <sub>PP</sub> Erase<br>Current                  | 1,4   |                   | 13    | 30     | ,                 | 15            | 25   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress<br>V <sub>PP</sub> = V <sub>PPH1</sub> (at 5V)  |
|                   |                                                   |       |                   | 8     | 25     |                   | 10            | 20   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress<br>V <sub>PP</sub> = V <sub>PPH2</sub> (at 12V) |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase<br>Suspend<br>Current       | 1     |                   | 50    | 200    |                   | 50            | 200  | μΑ    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspend<br>in Progress                                      |



**Table 20. DC Characteristics: Extended Temperature Operation (Continued)** 

|                   |                                                     |       | Т                         | BV-8 | 0                        | T                         | BV-8 | 0                        |       |                                                                                                                                           |
|-------------------|-----------------------------------------------------|-------|---------------------------|------|--------------------------|---------------------------|------|--------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol            | Parameter                                           | Notes | V <sub>CC</sub> =         | 3.3  | ± 0.3V                   | v <sub>cc</sub> =         | 5V ± | 10%                      | Units | Test Conditions                                                                                                                           |
|                   |                                                     |       | Min                       | Тур  | Max                      | Min                       | Тур  | Max                      |       |                                                                                                                                           |
| I <sub>RP#</sub>  | RP# Boot<br>Block Unlock<br>Current                 | 1,4   |                           |      | 500                      |                           | ,    | 500                      | μΑ    | RP# = V <sub>HH</sub><br>V <sub>PP</sub> = 12V                                                                                            |
| l <sub>ID</sub>   | A <sub>9</sub> Intelligent<br>Identifier<br>Current | 1,4   |                           |      | 500                      |                           |      | 500                      | μΑ    | $A_9 = V_{ID}$                                                                                                                            |
| V <sub>ID</sub>   | A <sub>9</sub> Intelligent<br>Identifier<br>Voltage |       | 11.4                      |      | 12.6                     | 11.4                      |      | 12.6                     | ٧     |                                                                                                                                           |
| V <sub>IL</sub>   | Input Low<br>Voltage                                |       | -0.5                      |      | 0.8                      | -0.5                      |      | 0.8                      | ٧     |                                                                                                                                           |
| V <sub>IH</sub>   | Input High<br>Voltage                               |       | 2.0                       |      | V <sub>CC</sub><br>±0.5V | 2.0                       |      | V <sub>CC</sub><br>±0.5V | ٧     |                                                                                                                                           |
| V <sub>OL</sub>   | Output Low<br>Voltage                               |       |                           |      | 0.45                     |                           |      | 0.45                     | ٧     | $\begin{aligned} V_{CC} &= V_{CC}  \text{MIN} \\ I_{OL} &= 5.8  \text{mA (5V)} \\ &= 2  \text{mA (3.3V)} \\ V_{PP} &= 12 V \end{aligned}$ |
| V <sub>OH1</sub>  | Output High<br>Voltage (TTL)                        |       | 2.4                       | -    |                          | 2.4                       |      |                          | . V   | $V_{CC} = V_{CC} MIN$ $I_{OH} = -2.5 mA$                                                                                                  |
| V <sub>OH2</sub>  | Output High<br>Voltage                              |       | 0.85 ×<br>V <sub>CC</sub> |      |                          | 0.85 ×<br>V <sub>CC</sub> |      |                          | ٧     | $V_{CC} = V_{CC} MIN$ $I_{OH} = -2.5 \text{ mA}$                                                                                          |
|                   | (CMOS)                                              |       | V <sub>CC</sub><br>-0.4V  |      |                          | V <sub>CC</sub><br>-0.4V  |      |                          |       | $V_{CC} = V_{CC} MIN$ $I_{OH} = -100 \mu A$                                                                                               |
| V <sub>PPLK</sub> | V <sub>PP</sub> Lock-<br>Out Voltage                | 3     | 0.0                       |      | 1.5                      | 0.0                       |      | 1.5                      | ٧     | Complete Write<br>Protection                                                                                                              |
| V <sub>PPH1</sub> | V <sub>PP</sub> (Program/<br>Erase Operations)      |       | 4.5                       |      | 5.5                      | 4.5                       |      | 5.5                      | ٧     | V <sub>PP</sub> at 5V                                                                                                                     |
| V <sub>PPH2</sub> | V <sub>PP</sub> (Program/<br>Erase Operations)      |       | 11.4                      |      | 12.6                     | 11.4                      |      | 12.6                     | ٧     | V <sub>PP</sub> at 12V                                                                                                                    |



Table 20. DC Characteristics: Extended Temperature Operation (Continued)

|                  |                                                |       | TBV-80            |       |        | •                      | TBV-80 |      |       |                                                 |  |
|------------------|------------------------------------------------|-------|-------------------|-------|--------|------------------------|--------|------|-------|-------------------------------------------------|--|
| Symbol           | Parameter                                      | Notes | V <sub>CC</sub> = | = 3.3 | ± 0.3V | $V_{CC} = 5V \pm 10\%$ |        |      | Units | Test Conditions                                 |  |
|                  |                                                |       | Min               | Тур   | Max    | Min                    | Тур    | Max  |       |                                                 |  |
| V <sub>LKO</sub> | V <sub>CC</sub><br>Erase/Write<br>Lock Voltage | 8     | 2.0               |       |        | 2.0                    |        |      | ٧     | V <sub>PP</sub> = 12V                           |  |
| V <sub>HH</sub>  | RP# Unlock<br>Voltage                          |       | 11.4              |       | 12.6   | 11.4                   |        | 12.6 | ٧     | Boot Block Write/Erase<br>V <sub>PP</sub> = 12V |  |

## NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, T = 25°C. These currents are valid for all product versions (packages and speeds).
- 2. ICCES is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum of ICCES and ICCR.
- 3. Block erases and word/byte writes are inhibited when Vpp = VppLK, and not guaranteed in the range between VppH1 and VPPLK.
- 4. Sampled, not 100% tested.
- 4. Sampled, not 100% tested.

  5. Automatic Power Savings (APS) reduces  $I_{CCR}$  to less than 1 mA typical, in static operation.

  6. CMOS Inputs are either  $V_{CC} \pm 0.2V$  or GND  $\pm 0.2V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .

  7. For the 28F004 address pin  $A_{10}$  follows the  $C_{OUT}$  capacitance numbers.

  8. For all BV parts,  $V_{LKO} = 2.0V$  for both 3.3V and 5.0V operations.

## intel<sub>®</sub>

# 

Figure 23. 3.3V Inputs and Measurement Points



Figure 24. 3.3V Standard Test Configuration

## 4-MBIT SmartVoltage BOOT BLOCK FAMILY



Figure 25. 5V Inputs and Measurement Points



Figure 26. 5V Standard Test Configuration



## 6.3 AC Characteristics

Table 21. AC Characteristics: Read Only Operations(1) (Extended Temperature)

|                                        |                                                                          |       | TB\                   | /-80        | ТВ                   | V-80     |       |
|----------------------------------------|--------------------------------------------------------------------------|-------|-----------------------|-------------|----------------------|----------|-------|
| Symbol                                 | Parameter                                                                | Notes | V <sub>CC</sub> = 3.3 | 3 ± 0.3V(6) | V <sub>CC</sub> = 5V | ± 10%(5) | Units |
|                                        |                                                                          |       | Min                   | Max         | Min                  | Max      |       |
| t <sub>AVAV</sub>                      | Read Cycle Time                                                          |       | 110                   |             | 80                   |          | ns    |
| t <sub>AVQV</sub>                      | Address to Output Delay                                                  |       |                       | 110         |                      | 80       | ns    |
| t <sub>ELQV</sub>                      | CE# to Output Delay                                                      | 2     |                       | 110         | ,                    | 80       | ns    |
| t <sub>PHQV</sub>                      | RP# to Output Delay                                                      | ·     |                       | 800         |                      | 450      | ns    |
| t <sub>GLQV</sub>                      | OE# to Output Delay                                                      | 2     |                       | 65          |                      | 40       | ns    |
| t <sub>ELQX</sub>                      | CE# to Output in Low Z                                                   | 3     | 0                     |             | 0                    |          | ns    |
| t <sub>EHQZ</sub>                      | CE# to Output in High Z                                                  | 3     |                       | 55          |                      | 30       | ns    |
| t <sub>GLQX</sub>                      | OE# to Output in Low Z                                                   | 3     | 0                     |             | 0                    |          | ns    |
| t <sub>GHQZ</sub>                      | OE# to Output in High Z                                                  | 3     |                       | 45          |                      | 30       | ns    |
| tон                                    | Output Hold from Address<br>CE#, or OE# change<br>whichever occurs first | 3     | 0                     |             | 0                    |          | ns    |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> | CE# Low to BYTE# High or Low                                             | 3     |                       | 7           |                      | 5        | ns    |
| t <sub>AVFL</sub>                      | Address to BYTE# High or Low                                             | 3     |                       | 7           |                      | . 5      | ns    |
| t <sub>FLQV</sub>                      | BYTE# to Output Delay                                                    | 3,4   |                       | 110 ,       | ,                    | 80       | ns    |
| t <sub>FLQZ</sub>                      | BYTE# Low to Output in High Z                                            | 3     |                       | 45          |                      | 30       | ns    |

### NOTES:

1. See AC Input/Output Reference Waveform for timing measurements.

2. OE# may be delayed up to  $t_{CE} - t_{OE}$  after the falling edge of CE# without impact on  $t_{CE}$ .

5. 5V Standard Test Configuration. (Figure 26)

6. See 3.3V Standard Test Configuration. (Figure 24)

Sampled, but not 100% tested.
 t<sub>FLQV</sub>, BYTE# switching low to valid output delay will be equal to t<sub>AVQV</sub>, measured from the time DQ<sub>15</sub>/A<sub>-1</sub> becomes valid.



Table 22. AC Characteristics: WE #-Controlled Write Operations(1) (Extended Temperature)

|                    |                                            |       | тв                    | V-80       | ТВ                   | /-80      |       |
|--------------------|--------------------------------------------|-------|-----------------------|------------|----------------------|-----------|-------|
| Symbol             | Parameter                                  | Notes | V <sub>CC</sub> = 3.3 | ± 0.3V(11) | V <sub>CC</sub> = 5V | ± 10%(12) | Units |
|                    |                                            |       | Min                   | Max        | Min                  | Max       |       |
| t <sub>AVAV</sub>  | Write Cycle Time                           |       | 110                   |            | 80                   |           | ns    |
| t <sub>PHWL</sub>  | RP# High Recovery to WE# Going Low         |       | 800                   |            | 450                  |           | ns    |
| t <sub>ELWL</sub>  | CE# Setup to WE# Going Low                 |       | 0                     |            | 0                    |           | ns    |
| t <sub>PHHWH</sub> | Boot Block Lock Setup to WE#<br>Going High | 6,8   | 200                   |            | 100                  |           | ns    |
| $t_{VPWH}$         | V <sub>PP</sub> Setup to WE# Going High    | 5,8   | 200                   |            | 100                  |           | ns    |
| t <sub>AVWH</sub>  | Address Setup to WE# Going<br>High         | 3     | 90                    |            | 60                   |           | ns    |
| t <sub>DVWH</sub>  | Data Setup to WE# Going High               | 4     | 90                    |            | 60                   |           | ns    |
| t <sub>WLWH</sub>  | WE# Pulse Width                            |       | . 90                  |            | 60                   |           | ns    |
| ťwhox              | Data Hold Time from WE# High               | 4     | 0                     |            | 0                    |           | ns    |
| tWHAX              | Address Hold Time from WE#<br>High         | 3     | 10                    |            | 10                   |           | ns    |
| t <sub>WHEH</sub>  | CE# Hold Time from WE# High                |       | 0 .                   |            | 0                    |           | ns    |
| twhwL              | WE# Pulse Width High                       |       | 20                    |            | 20                   |           | ns    |
| t <sub>WHQV1</sub> | Duration of Word/Byte Write<br>Operation   | 2,5   | 6                     |            | 7                    |           | μs    |
| t <sub>WHQV2</sub> | Duration of Erase Operation (Boot)         | 2,5,6 | 0.3                   |            | 0.4                  |           | s     |
| t <sub>WHQV3</sub> | Duration of Erase Operation (Parameter)    | 2,5   | 0.3                   |            | 0.4                  |           | S     |
| t <sub>WHQV4</sub> | Duration of Erase Operation (Main)         | 2,5   | 0.6                   |            | 0.7                  |           | s     |
| t <sub>QWL</sub>   | V <sub>PP</sub> Hold from Valid SRD        | 5,8   | 0                     |            | 0                    |           | ns    |
| t <sub>QVPH</sub>  | RP# V <sub>HH</sub> Hold from Valid SRD    | 6,8   | 0 ,                   |            | 0                    |           | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock Delay                    | 7,8   |                       | 200        |                      | 100       | ns    |

#### NOTES

- Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during read mode.
- The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- 4. Refer to command definition table for valid D<sub>IN</sub>.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7 = 1)
- For boot block program/erase, RP# should be held at V<sub>HH</sub> or WP# should be held at V<sub>IH</sub> until operation completes successfully.
- 7. Time t<sub>PHRR</sub> is required for successful relocking of the boot block.
- 8. Sampled, but not 100% tested.
- 9. V<sub>PP</sub> at 5.0V.
- 10. Vpp at 12.0V.
- 11. See 3.3V Standard Test Configuration.
- 12. See 5V Standard Test Configuration.



Table 23. AC Characteristics: CE #-Controlled Write Operations(1,13)

|                    |                                            |       | TB                    | <b>/-</b> 80 | ТВ                   | V-80      |       |
|--------------------|--------------------------------------------|-------|-----------------------|--------------|----------------------|-----------|-------|
| Symbol             | Parameter                                  | Notes | V <sub>CC</sub> = 3.3 | ± 0.3V(11)   | V <sub>CC</sub> = 5V | ± 10%(12) | Units |
|                    |                                            |       | Min                   | Max          | Min                  | Max       |       |
| t <sub>AVAV</sub>  | Write Cycle Time                           |       | 110                   |              | 80                   |           | ns    |
| t <sub>PHEL</sub>  | RP# High Recovery to CE# Going Low         |       | 800                   |              | 450                  |           | ns    |
| t <sub>WLEL</sub>  | WE# Setup to CE# Going Low                 | -     | 0                     |              | 0                    | -         | ns    |
| tphheh             | Boot Block Lock Setup to CE# Going High    | 6,8   | 200                   |              | 100                  |           | ns    |
| t <sub>VPEH</sub>  | V <sub>PP</sub> Setup to CE# Going<br>High | 5,8   | 200                   |              | 100                  |           | ns    |
| t <sub>AVEH</sub>  | Address Setup to CE#<br>Going High         |       | 90                    |              | 60                   |           | ns    |
| t <sub>DVEH</sub>  | Data Setup to CE# Going High               | 3     | 90                    |              | . 60                 |           | ns    |
| teleh              | CE# Pulse Width                            | 4     | 90                    |              | 60                   |           | ns    |
| t <sub>EHDX</sub>  | Data Hold Time from CE#<br>High            |       | 0                     | ,            | 0                    |           | ns    |
| t <sub>EHAX</sub>  | Address Hold Time from CE# High            | 4     | 10                    |              | , 10                 |           | ns    |
| t <sub>EHWH</sub>  | WE# Hold Time from CE#<br>High             | 3     | 0                     | ,            | 0                    |           | ns    |
| t <sub>EHEL</sub>  | CE# Pulse Width High                       |       | 20                    |              | 20                   |           | ns    |
| t <sub>EHQV1</sub> | Duration of Word/Byte<br>Write Operation   | 2,5   | 6                     |              | 7                    |           | μs    |
| t <sub>EHQV2</sub> | Duration of Erase Operation (Boot)         | 2,5,6 | 0.3                   |              | 0.4                  |           | s     |
| t <sub>EHQV3</sub> | Duration of Erase Operation (Parameter)    | 2,5   | 0.3                   |              | 0.4                  |           | s     |
| t <sub>EHQV4</sub> | Duration of Erase Operation (Main)         | 2,5   | 0.6                   |              | 0.7                  |           | s     |
| t <sub>QWL</sub>   | V <sub>PP</sub> Hold from Valid SRD        | 5,8   | 0                     |              | 0                    |           | ns    |
| t <sub>QVPH</sub>  | RP# V <sub>HH</sub> Hold from Valid<br>SRD | 6,8   | . 0                   |              | 0                    |           | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock Delay                    | 7,8   |                       | 200          | !                    | 100       | ns    |

## NOTES:

See WE# Controlled Write Operations for notes 1 through 12.

13. Chip-Enable controlled writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.

Table 24. Extended Temperature Operations—Erase and Program Timings

| Table 24. Extended Tomporature Operations Lideo and Trogram Timings |                                 |                               |                                 |                               |       |  |  |  |  |  |
|---------------------------------------------------------------------|---------------------------------|-------------------------------|---------------------------------|-------------------------------|-------|--|--|--|--|--|
|                                                                     | V <sub>PP</sub> =5              | V ± 10%                       | V <sub>PP</sub> = 1:            |                               |       |  |  |  |  |  |
| Parameter                                                           | V <sub>CC</sub> =<br>3.3 ± 0.3V | V <sub>CC</sub> =<br>5V ± 10% | V <sub>CC</sub> =<br>3.3 ± 0.3V | V <sub>CC</sub> =<br>5V ± 10% | Units |  |  |  |  |  |
|                                                                     | Тур                             | Тур                           | Тур                             | Тур                           |       |  |  |  |  |  |
| Boot/Parameter Block<br>Erase Time                                  | 0.84                            | 0.8                           | 0.44                            | 0.34                          | S     |  |  |  |  |  |
| Main Block Erase Time                                               | 2.4                             | 1.9                           | 1.3                             | 1.1                           | s     |  |  |  |  |  |
| Main Block Write Time<br>(Byte Mode)                                | 1.7                             | 1.4                           | 1.6                             | 1.2                           | S     |  |  |  |  |  |
| Main Block Write Time<br>(Word Mode)                                | 1.1                             | 0.9                           | 0.8                             | 0.6                           | S     |  |  |  |  |  |
| Byte Write Time                                                     | 10                              | 10                            | 8                               | 8                             | μs    |  |  |  |  |  |
| Word Write Time                                                     | 13                              | 13                            | 8                               | 8                             | μs    |  |  |  |  |  |

## **NOTES:**

<sup>1.</sup> All numbers are sampled, not 100% tested.

<sup>2.</sup> Contact your Intel representative for information regarding maximum Byte/Word Write specifications.



## 7.0 ADDITIONAL INFORMATION

## 7.1 Ordering Information



### Table 25. Summary of Line Items

| Name     | V <sub>CC</sub> |    | V <sub>PP</sub> |     | 40-<br>Lead<br>TSOP | 44-<br>Lead<br>PSOP | 48-<br>Lead<br>TSOP | 56-<br>Lead<br>TSOP | 0°-+70°C | -40°-+85°C |  |
|----------|-----------------|----|-----------------|-----|---------------------|---------------------|---------------------|---------------------|----------|------------|--|
|          | 3.3V            | 5V | 5V              | 12V |                     |                     |                     |                     |          |            |  |
| 28F400BV | -               | ~  | 1               | . " |                     | <i>u</i>            | ~                   | <i>u</i>            | ~        |            |  |
| 28F004BV | <b>1</b>        | ~  |                 | ~   | <u></u>             |                     |                     |                     | -        | -          |  |



## 7.2 References

| Order Number | Document                                                                          |
|--------------|-----------------------------------------------------------------------------------|
| 292130       | AB-57 "Boot Block Architecture for Safe Firmware Updates"                         |
| 292154       | AB-60 "2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family"                    |
| 292098       | AP-363 "Extended Flash BIOS Concepts for Portable Computers"                      |
| 292148       | AP-604 "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM" |
| 290448       | 28F002/200BX-T/B 2-Mbit Boot Block Flash Memory Datasheet                         |
| 290449       | 28F002/200BL-T/B 2-Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290450       | 28F004/400BL-T/B 4-Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290451       | 28F004/400BX-T/B 4-Mbit Boot Block Flash Memory Datasheet                         |
| 290531       | 2-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290539       | 8-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |

## 7.3 Revision History

|  |      | 5.1. T. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G. 1. G |
|--|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | -001 | Initial release of datasheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



# 2-MBIT (128K x 16, 256K x 8) SmartVoltage BOOT BLOCK FLASH MEMORY FAMILY

28F200BV-T/B, 28F002BV-T/B, 28F200CV-T/B

- Intel SmartVoltage Technology
  - 5V or 12V Program/Erase
  - 3.3V or 5V Read Operation
  - 60% Faster Typical Programming at 12V Vpp
- **Very High Performance Read** 
  - -- 5V: 60/80/120 ns Max. Access Time, 30/40 ns Max. Output Enable
  - 3V: 110/150 /180 ns Max. Access Time 65/90 ns Max. Output Enable
- **Low Power Consumption** 
  - Maximum 60 mA Read Current at 5V
  - Maximum 30 mA Read Current at 3V
- x8/x16-Selectable Input/Output Bus
  - 28F200 for High Performance 16- or 32-bit CPUs
- x8-Only Input/Output Architecture
  - 28F002 for Space-Constrained 8-bit Applications
- Optimized Array Blocking Architecture
  - One 16-KB Protected Boot Block
  - Two 8-KB Parameter Blocks
  - One 96-KB Main Block
  - One 128-KB Main Blocks
  - Top or Bottom Boot Locations
- Absolute Hardware-Protection for Boot Block
- Software EEPROM Emulation with Parameter Blocks
- **Extended Temperature Operation**

- **Extended Cycling Capability** 
  - 100,000 Block Erase Cycles (Commercial Temperature)
  - 10,000 Block Erase Cycles (Extended Temperature)
- Automated Word/Byte Write and Block Erase
  - Industry Standard Command User Interface
  - Status Registers
  - Erase Suspend Capability
- **■** SRAM-Compatible Write Interface
- Automatic Power Savings Feature
  - 1 mA Typical I<sub>CC</sub> Active Current in Static Operation
- Reset/Deep Power-Down Input
  - 0.2 μA I<sub>CC</sub> Typical
  - Provides Reset for Boot Operations
- Hardware Data Protection Feature
  - Erase/Write Lockout during Power Transitions
- Industry-Standard Surface Mount Packaging
  - 40-Lead TSOP
  - 44-Lead PSOP: JEDEC ROM Compatible
  - 48-Lead TSOP
  - 56-Lead TSOP
- Footprint Upgradable to 4 or 8 Mbit
- **ETOX™ IV Flash Technology**



290531-26

# 2-MBIT (128K x 16, 256K x 8) SmartVoltage BOOT BLOCK FLASH MEMORY FAMILY

| CONTENTS                                                      | PAGE      | CONTENTS                                                      | PAGE                |
|---------------------------------------------------------------|-----------|---------------------------------------------------------------|---------------------|
| 1.0 PRODUCT FAMILY OVERV                                      | VIFW 4-70 | 3.5 Power Consumption .                                       | 4-92                |
| 1.1 New Features in the Smar                                  |           | 3.5.1 ACTIVE POWER                                            | 4-92                |
| Products                                                      | 4-70      | 3.5.2 AUTOMATIC PO                                            |                     |
| 1.2 Main Features                                             | 4-70      | SAVINGS                                                       |                     |
| 1.3 Applications                                              | 4-72      | 3.5.3 STANDBY POWE                                            |                     |
| 1.4 Pinouts                                                   | 4-74      | 3.5.4 DEEP POWER-D<br>MODE                                    | OWN 4-92            |
| 1.5 Pin Descriptions                                          | 4-77      | 3.6 Power-Up/Down Oper                                        |                     |
| 2.0 PRODUCT DESCRIPTION                                       | 4-79      | 3.6.1 RP# CONNECTE                                            | ED TO               |
| 2.1 Memory Organization                                       | 4-79      | SYSTEM RESET                                                  |                     |
| 2.1.1 BLOCKING                                                | 4-79      | 3.6.2 V <sub>CC</sub> , V <sub>PP</sub> AND RI<br>TRANSITIONS | ∍#<br>4-93          |
| 3.0 PRODUCT FAMILY PRINCI                                     | PLES OF   | 3.7 Power Supply Decoup                                       | ling 4-93           |
| OPERATION                                                     | 4-81      | 3.7.1 V <sub>PP</sub> TRACE ON I                              | PRINTED             |
| 3.1 Bus Operations                                            |           | CIRCUIT BOARDS                                                | 4-93                |
| 3.2 Read Operations                                           |           | 4.0 ABSOLUTE MAXIMUM                                          | <b>RATINGS</b> 4-95 |
| 3.2.1 READ ARRAY                                              | 4-81      | 5.0 COMMERCIAL OPERAT                                         | FINO                |
| 3.2.2 INTELLIGENT IDENTIFIERS                                 | 4-83      | CONDITIONS                                                    | 4-96                |
| 3.3 Write Operations                                          | 4-83      | 5.1 Switching V <sub>CC</sub> Voltage                         | s 4-96              |
| 3.3.1 COMMAND USER INTERFACE                                  | 4-83      | 5.2 DC Characteristics (Commercial)                           | 4-97                |
| 3.3.2 STATUS REGISTER                                         |           | 5.3 AC Characteristics                                        | 4.404               |
| 3.3.3 PROGRAM MODE.                                           | 4-87      | (Commercial)                                                  | 4-101               |
| 3.3.4 ERASE MODE                                              |           | 6.0 EXTENDED OPERATIN                                         | G                   |
| 3.4 Boot Block Locking                                        | 4-92      | CONDITIONS                                                    |                     |
| 3.4.1 V <sub>PP</sub> = V <sub>IL</sub> FOR COM<br>PROTECTION |           | 6.1 Applying V <sub>CC</sub> Voltage:                         |                     |
|                                                               |           | 6.2 DC Characteristics (Ex                                    | •                   |
| $3.4.2 \text{ WP} # = V_{ L} \text{ FOR BC}$ $BLOCK LOCKING$  | OOT       | 6.3 AC Characteristics (Ex                                    | (tended) 4-117      |
|                                                               |           | 7.0 ADDITIONAL INFORMA                                        | <b>TION</b> 4-122   |
| 3.4.3 RP# = V <sub>HH</sub> OR WF<br>FOR BOOT BLOCK           | # - VIH   | 7.1 Ordering Information .                                    | 4-122               |
| UNLOCKING                                                     | 4-92      | 7.2 References                                                | 4-123               |
|                                                               |           | 7.3 Revision History                                          | 4-123               |



## 1.0 PRODUCT FAMILY OVERVIEW

This datasheet comprises the specifications for the SmartVoltage products in the 2-Mbit boot block flash memory family. Throughout this datasheet, the 28F200 refers to all x8/x16 2-Mbit products, while 28F002 refers to all x8 2-Mbit products. Section 1 provides an overview of the flash memory family including applications, pinouts and pin descriptions. Sections 2 and 3 describe, in detail, the specific memory organizations and principles of operation for these products. Finally, Sections 4 and 5 describe the family's operating specifications. Tables 1 and 2 provide a quick reference to each product's voltage supply capability.

## 1.1 New Features in the SmartVoltage Products

The new SmartVoltage boot block flash memory family offers identical operation as the current BX/BL 12V program products, except for the differences listed below. All other functions are equivalent to current products, including signatures, write commands, and pinouts.

- WP# pin has replaced a DU pin. See Table 3 and Table 10 for details.
- 5V Program/Erase operation has been added that uses proven program and erase techniques with 5V ± 10% applied to V<sub>PP</sub>.
- $\bullet$  Enhanced circuits optimize performance at 3.3V  $V_{CC}$

If you are designing with existing BX/BL 12V Vpp boot block products today, you should provide the capability in your board design to upgrade to these new SmartVoltage products.

Follow these guidelines to ensure compatibilty:

1. Connect WP# (DU on existing products) to control signal or to  $V_{CC}$  or GND.

- If adding a switch on V<sub>PP</sub> for write protection, switch to GND for complete write protection.
- Allow for connecting 5V to V<sub>PP</sub> and disconnect 12V from V<sub>PP</sub> line, if desired.

## 1.2 Main Features

Intel's SmartVoltage technology provides the most flexible voltage solution in the industry. SmartVoltage provides two discrete voltage supply pins. Voc for read operation, and Vpp for program and erase operation. Discrete supply pins allow system designers to use the optimal voltage levels for their design. The 28F200/002BV provides read capability at 3.3V or 5V, and program/erase capability at 5V or 12V. Since many designs read from the flash memory a large percentage of the time, 3.3V V<sub>CC</sub> operation can provide great power savings. If read performance is an issue, however, 5V V<sub>CC</sub> provides faster read access times. For program and erase operations, 5V VPP operation eliminates the need for in system voltage converters, while 12V V<sub>PP</sub> operation provides faster program and erase for situations where 12V is available, such as manufacturing or designs where 12V is in-system.

The 28F200/28F002 boot block flash memory family is a very high-performance, 2-Mbit (2,097,152 bit) flash memory family organized as either 256 Kwords (131,072 words) of 16 bits each or 512 Kbytes (262,144 bytes) of 8 bits each.

Separately erasable blocks, including a hardware-lockable boot block (16,384 bytes), two parameter blocks (8,192 bytes each) and main blocks (one block of 98,304 bytes and three blocks of 131,072 bytes) define the boot block flash family architecture. See Figure 7 and 8 for memory maps. Each block can be independently erased and programmed 100,000 times at commercial temperature or 10,000 times at extended temperature.



## Table 1. x8/x16 Boot Block Product Family

| Product Name | V <sub>I</sub> | pp         | V  | cc |
|--------------|----------------|------------|----|----|
|              | 12V            | 5 <b>V</b> | 5V | 3V |
| 28F200BV-T/B | 10             | и          | 1  | 10 |

## Table 2. x8-only Boot Block Product Family

| Product Name | V <sub>F</sub> | PP . | V <sub>CC</sub> |          |  |  |
|--------------|----------------|------|-----------------|----------|--|--|
|              | 12V            | 5V   | 5V              | 3V       |  |  |
| 28F002BV-T/B | 10             | 10   | 10              | <i>u</i> |  |  |

The boot block is located at either the top (denoted by -T suffix) or the bottom (-B suffix) of the address map in order to accommodate different microprocessor protocols for boot code location. The hardware-lockable boot block provides complete code security for the kernel code required for system initialization. Locking and unlocking of the boot block is controlled by WP# and/or RP# (see Section 3.4 for details).

The Command User Interface (CUI) serves as the interface between the microprocessor or microcontroller and the internal operation of the boot block flash memory products. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verifications, thereby unburdening the microprocessor or microcontroller of these tasks. The Status Register (SR) indicates the status of the WSM and whether it successfully completed the desired program or erase operation.

Program and Erase Automation allows program and erase operations to be executed using an industry-standard two-write command sequence to the CUI. Data writes are performed in word (28F200 family) or byte (28F200 or 28F002 families) increments. Each byte or word in the Flash memory can be programmed independently of other memory locations, unlike erases, which erase all locations within a block simultaneously.

The 2-Mbit SmartVoltage boot block flash memory family is also designed with an Automatic Power Savings (APS) feature which minimizes system

battery current drain, allowing for very low power designs. To provide even greater power savings, the boot block family includes a deep power-down mode which minimizes power consumption by turning most of the Flash memory's circuitry off. This mode is controlled by the RP# pin and its usage is discussed in Section 3.5, along with other power consumption issues.

Additionally, the RP# pin provides protection against unwanted command writes due to invalid system bus conditions that may occur during system reset and power-up/down sequences. Also, when the Flash memory powers-up, it automatically defaults to the read array mode, but during a warm system reset, where power continues uninterrupted to the system components, the flash memory could remain in a non-read mode, such as erase. Consequently, the system Reset pin should be tied to RP# to reset the memory to normal read mode upon activation of the Reset pin.

For the 28F200, byte-wide or word-wide input/out-put is controlled by the BYTE# pin. Please see Table 3 for a detailed description of BYTE# operations, especially the usage of the  $DQ_{15}/A_{-1}$  pin.

The 28F200 products are available in a ROM/EPROM-compatible pinout and housed in the 44-Lead PSOP (Plastic Small Outline) package, the 48-Lead TSOP (Thin Small Outline, 1.2 mm thick) package and the 56-Lead TSOP as shown in Figure 4, 5 and 6, respectively. The 28F002 products are available in the 40-Lead TSOP package as shown in Figure 3.



Refer to the DC Characteristics Table, Section 4.2 (commercial temperature) and Section 5.2 (extended temperature), for complete current and voltage specifications. Refer to the AC Characteristics Table, Section 4.3 (commercial temperature) and Section 5.3 (extended temperature), for read, write and erase performance specifications.

## 1.3 Applications

The 2-Mbit boot block flash memory family combines high-density, low-power, high-performance, cost-effective flash memories with blocking and hardware protection capabilities. Their flexibility and versatility reduce costs throughout the product life cycle. Flash memory is ideal for Just-In-Time production flow, reducing system inventory and costs, and eliminating component handling during the production phase.

When your product is in the end-user's hands, and updates or feature enhancements become necessary, flash memory reduces the update costs by allowing user-performed code changes instead of costly product returns or technician calls.

The 2-Mbit boot block flash memory family provides full-function, blocked flash memories suitable for a wide range of applications. These applications include extended PC BIOS and ROM-able applications storage, digital cellular phone program and data storage, telecommunication boot/firmware, printer firmware/font storage and various other embedded applications where program and data storage are required.

Reprogrammable systems such as personal computers, are ideal applications for the 2-Mbit flash memory products. Increasing software sophistica-

tion greatens the probability that a code update will be required after the PC is shipped. For example, the emerging of "Plug and Play" standard in desktop and portable PCs enables auto-configuration of ISA and PCI add-in cards. However, since the "Plug and Play" specification continues to evolve, a flash BIOS provides a cost-effective capability to update existing PCs. In addition, the parameter blocks are ideal for storing the required auto-configuration parameters, allowing you to integrate the BIOS PROM and parameter storage EEPROM into a single component, reducing parts costs while increasing functionality.

The 2-Mbit flash memory products are also excellent design solutions for digital cellular phone and telecommunication switching applications requiring very low power consumption, high-performance, high-density storage capability, modular software designs, and a small form factor package. The 2-Mbit's blocking scheme allows for easy segmentation of the embedded code with 16 Kbytes of hardware-protected boot code, two main blocks of program code and two parameter blocks of 8 Kbytes each for frequently updated data storage and diagnostic messages (e.g., phone numbers, authorization codes).

Intel's boot block architecture provides a flexible voltage solution for the different design needs of various applications. The asymmetrically blocked memory map allows the integration of several memory components into a single Flash device. The boot block provides a secure boot PROM; the parameter blocks can emulate EEPROM functionality for parameter store with proper software techniques; and the main blocks provide code and data storage with access times fast enough to execute code in place, decreasing RAM requirements.





Figure 1. 28F200 Interface to Intel386EX™ Microprocessor





Figure 2. 28F002 Interface to Intel80C188EB 8-Bit Embedded Microprocessor

## 1.4 Pinouts

Intel's SmartVoltage Boot Block architecture provides upgrade paths in every package pinout to the 8-Mbit density. The 28F002 40-Lead TSOP pinout for space-constrained designs is shown in Figure 3. The 28F200 44-Lead PSOP pinout follows the industry standard ROM/EPROM pinout as shown in Figure 4. For designs that require x16 operation but

have space concerns, refer to the 48-Lead pinout in Figure 5. Furthermore, the 28F200 56-Lead TSOP pinout shown in Figure 6 provides density upgrades to future higher density boot block memories.

Pinouts for the corresponding 4-Mbit and 8-Mbit components are also provided for convenient reference. 2-Mbit pinouts are given on the chip illustration in the center, with 4-Mbit and 8-Mbit pinouts going outward from the center.





Figure 3. The 40-Lead TSOP Offers the Smallest Form Factor for Space-Constrained Applications



NOTE:

Pin 2 is DU for BX/BL 12V V<sub>PP</sub> Versions, but for the 8-Mbit device, pin 2 has been changed to A<sub>18</sub> (WP# on 2/4 Mbit). Designs planning on upgrading to the 8-Mbit density from the 2/4-Mbit density in this package should design pin 2 to control WP# functionality at the 2/4-Mbit level and allow for pin 2 to control A<sub>18</sub> after upgrading to the 8-Mbit density.

Figure 4. The 44-Lead PSOP Offers a Convenient Upgrade from JEDEC ROM Standards





Figure 5. The 48-Lead TSOP Offers the Smallest Form Factor for x16 Operation



Figure 6. The 56-Lead TSOP Offers Compatibility between 2 Mbits and 4 Mbits



## 1.5 Pin Descriptions

Table 3. 28F200/002 Pin Descriptions

| Symbol                            | Туре             | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>17</sub>   | INPUT            | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle. The 28F200 only has A <sub>0</sub> -A <sub>16</sub> pins, while the 28F002 has A <sub>0</sub> -A <sub>17</sub> .                                                                                                                                                                                                                                                                                                                 |
| A <sub>9</sub>                    | INPUT            | <b>ADDRESS INPUT:</b> When A <sub>9</sub> is at V <sub>HH</sub> the signature mode is accessed. During this mode, A <sub>0</sub> decodes between the manufacturer and device IDs. When BYTE# is at a logic low, only the lower byte of the signatures are read. $DQ_{15}/A_{-1}$ is a don't care in the signature mode when BYTE# is low.                                                                                                                                                                                    |
| DQ <sub>0</sub> -DQ <sub>7</sub>  | INPUT/<br>OUTPUT | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a Program command. Inputs commands to the Command User Interface when CE# and WE# are active. Data is internally latched during the Write cycle. Outputs array, Intelligent Identifier and Status Register data. The data pins float to tri-state when the chip is de-selected or the outputs are disabled.                                                                                                                                    |
| DQ <sub>8</sub> -DQ <sub>15</sub> | INPUT/<br>OUTPUT | <b>DATA INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a Program command. Data is internally latched during the Write cycle. Outputs array data. The data pins float to tri-state when the chip is de-selected or the outputs are disabled as in the byte-wide mode (BYTE# = "0"). In the byte-wide mode DQ $_{15}/A_{-1}$ becomes the lowest order address for data output on DQ $_{0}$ -DQ $_{7}$ . <b>The 28F002 does not include these DQ<math>_{8}</math>-DQ<math>_{15}</math> pins</b> . |
| CE#                               | INPUT            | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low. CE# high de-selects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                                                                                                                                                |
| OE#                               | INPUT            | <b>OUTPUT ENABLE:</b> Enables the device's outputs through the data buffers during a read cycle. OE# is active low.                                                                                                                                                                                                                                                                                                                                                                                                          |
| WE#                               | INPUT            | <b>WRITE ENABLE:</b> Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                                                                                                                        |
| RP#                               | INPUT            | <b>RESET/DEEP POWER-DOWN:</b> Uses three voltage levels ( $V_{\rm IL}$ , $V_{\rm IH}$ , and $V_{\rm HH}$ ) to control two different functions: reset/deep power-down mode and boot block unlocking. It is backwards-compatible with the 28F200BX/BL.                                                                                                                                                                                                                                                                         |
|                                   |                  | When RP# is at logic low, the device is in reset/deep powerdown mode, which puts the outputs at High-Z, resets the Write State Machine, and draws minimum current.                                                                                                                                                                                                                                                                                                                                                           |
|                                   |                  | When RP# is at logic high, the device is in standard operation. When RP# transitions from logic-low to logic-high, the device defaults to the read array mode.                                                                                                                                                                                                                                                                                                                                                               |
|                                   |                  | When RP# is at V <sub>HH</sub> , the boot block is unlocked and can be programmed or erased. This overides any control from the WP# input.                                                                                                                                                                                                                                                                                                                                                                                   |



Table 3. 28F200/002 Pin Descriptions (Continued)

|                 | <del></del> | Table 3. 20F2007002 Fill Descriptions (Continued)                                                                                                                                                                                                                                                                                     |
|-----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Type        | Name and Function                                                                                                                                                                                                                                                                                                                     |
| WP#             | INPUT       | <b>WRITE PROTECT:</b> Provides a method for unlocking the boot block in a system without a 12V supply. WP# must be driven to logic high or low, not left floating.                                                                                                                                                                    |
| •               |             | When WP# is at logic low, the boot block is locked, preventing Program and Erase operations to the boot block. If a Program or Erase operation is attempted on the boot block when WP# is low, the corresponding status bit (bit 4 for Program, bit 5 for Erase) will be set in the Status Register to indicate the operation failed. |
|                 |             | When WP# is at logic high, the boot block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                |
|                 |             | <b>NOTE:</b> This feature is overridden and the boot block unlocked when RP# is at $V_{HH}$ . See Section 3.4 for details on write protection.                                                                                                                                                                                        |
| BYTE#           | INPUT       | BYTE# ENABLE: Not available on 28F002. Controls whether the device operates in the byte-wide mode (x8) or the word-wide mode (x16). BYTE# pin must be controlled at CMOS levels to meet the CMOS current specification in the standby mode.                                                                                           |
|                 |             | When BYTE # is at logic low, the byte-wide mode is enabled, where data is read and programmed on DQ $_0$ -DQ $_7$ and DQ $_{15}$ /A $_{-1}$ becomes the lowest order address that decodes between the upper and lower byte. DQ $_8$ -DQ $_{14}$ are tri-stated during the byte-wide mode.                                             |
|                 |             | When BYTE # is at logic high, the word-wide mode is enabled, where data is read and programmed on $DQ_0-DQ_{15}$ .                                                                                                                                                                                                                    |
| V <sub>CC</sub> |             | DEVICE POWER SUPPLY: 5.0V ± 10%, 3.3V ± 0.3V                                                                                                                                                                                                                                                                                          |
| V <sub>PP</sub> |             | <b>PROGRAM/ERASE POWER SUPPLY:</b> For erasing memory array blocks or programming data in each block, a voltage either of 5V $\pm$ 10% or 12V $\pm$ 5% must be applied to this pin. When V <sub>PP</sub> < V <sub>PPLK</sub> all blocks are locked and protected against Program and Erase commands.                                  |
| GND             |             | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                   |
| NC              | ,           | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                       |



## 2.0 PRODUCT DESCRIPTION

## 2.1 Memory Organization

### 2.1.1 BLOCKING

This product family features an asymmetrically blocked architecture providing system memory integration. Each erase block can be erased independently of the others up to 100,000 times at commercial temperature or up to 10,000 times at extended temperature. The block sizes have been chosen to optimize their functionality for common applications of nonvolatile storage. For the address locations of the blocks, see the memory maps in Figures 7 and 8.

## 2.1.1.1 Boot Block-1 x 16 KB

The boot block is intended to replace a dedicated boot PROM in a microprocessor or microcontroller-based system. The 16-Kbyte (16,384 bytes) boot block is located at either the top (denoted by -T suffix) or the bottom (-B suffix) of the address map to accommodate different microprocessor protocols for boot code location. This boot block features hardware controllable write-protection to protect the crucial microprocessor boot code from accidental erasure. The protection of the boot block is controlled using a combination of the Vpp, RP#, and WP# pins, as is detailed in Section 3.4.

## 2-MBIT SmartVoltage BOOT BLOCK FAMILY

### 2.1.1.2 Parameter Blocks-2 x 8 KB

The boot block architecture includes parameter blocks to facilitate storage of frequently updated small parameters that would normally require an EEPROM. By using software techniques, the byterewrite functionality of EEPROMs can be emulated. These techniques are detailed in Intel's AP-604, "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM." Each boot block component contains two parameter blocks of eight Kbytes (8,192 bytes) each. The parameter blocks are not write-protectable.

## 2.1.1.3 Main Blocks-1 x 96 KB + 1 x 128 KB

After the allocation of address space to the boot and parameter blocks, the remainder is divided into main blocks for data or code storage. Each 2-Mbit device contains one 96-Kbyte (98,304 byte) block and one 128-Kbyte (131,072 byte) blocks. See the memory maps for each device for more information.







Figure 7. 28F200-T/B Memory Maps



Figure 8. 28F002-T/B Memory Maps



## 3.0 PRODUCT FAMILY PRINCIPLES OF OPERATION

Flash memory augments EPROM functionality with in-circuit electrical write and erase. The boot block flash family utilizes a Command User Interface (CUI) and automated algorithms to simplify write and erase operations. The CUI allows for 100% TTL-level control inputs, fixed power supplies during erasure and programming, and maximum EPROM compatibility.

When V<sub>PP</sub> < V<sub>PPLK</sub>, the device will only successfully execute the following commands: Read Array, Read Status Register, Clear Status Register and intelligent identifier mode. The device provides standard EPROM Read, Standby and Output Disable operations. Manufacturer Identification and Device Identification data can be accessed through the CUI or through the standard EPROM A<sub>9</sub> high voltage access (V<sub>ID</sub>) for PROM programming equipment.

The same EPROM Read, Standby and Output Disable functions are available when 5V or 12V is applied to the Vpp pin. In addition, 5V or 12V on Vpp allows write and erase of the device. All functions associated with altering memory contents: Write and Erase, Intelligent Identifier Read, and Read Status are accessed via the CUI.

The purpose of the Write State Machine (WSM) is to completely automate the write and erasure of the device. The WSM will begin operation upon receipt of a signal from the CUI and will report status back through a Status Register. The CUI will handle the WE# interface to the data and address latches, as well as system software requests for status while the WSM is in operation.

## 3.1 Bus Operations

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles. These bus operations are summarized in Tables 4 and 5.

## 3.2 Read Operations

#### 3.2.1 READ ARRAY

When RP# transitions from  $V_{IL}$  (reset) to  $V_{IH}$ , the device will be in the read array mode and will respond to the read control inputs (CE#, address inputs) and OE#) without any commands being written to the CUI.

When the device is in the read array mode, five control signals must be controlled to obtain data at the outputs.

- WE# must be logic high (VIH)
- CE# must be logic low (V<sub>II</sub>)
- OE must be logic low (V<sub>IL</sub>)
- RP# must be logic high (VIH)
- BYTE# must be logic high or logic low.

In addition, the address of the desired location must be applied to the address pins. Refer to Figure 18 and 19 for the exact sequence and timing of these signals.

If the device is not in read array mode, as would be the case after a program or erase operation, the Read Mode command (FFH) must be written to the CUI before reads can take place.



Table 4. Bus Operations for Word-Wide Mode (BYTE  $\# = V_{IH}$ )

| Mode                            | Notes | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-15</sub> |
|---------------------------------|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|
| Read                            | 1,2,3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | X               | D <sub>OUT</sub>   |
| Output Disable                  |       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | X               | X               | High Z             |
| Standby                         |       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | X               | High Z             |
| Deep Power-Down                 | 9     | V <sub>IL</sub> | Х               | Х               | Х               | Х               | X               | Х               | High Z             |
| Intelligent Identifier (Mfr)    | 4     | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х               | 0089 H             |
| Intelligent Identifier (Device) | 4,5   | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | See Table 6        |
| Write                           | 6,7,8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | X               | Х               | Х               | D <sub>IN</sub>    |

## Table 5. Bus Operations for Byte-Wide Mode (BYTE# = VIII)

| Mode                            | Notes | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | $A_{-1}$ | V <sub>PP</sub> | DQ <sub>0-7</sub> | DQ <sub>8-14</sub> |
|---------------------------------|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------|-----------------|-------------------|--------------------|
| Read                            | 1,2,3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х        | Х               | D <sub>OUT</sub>  | High Z             |
| Output Disable                  |       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х        | Х               | High Z            | High Z             |
| Standby                         |       | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х        | Х               | High Z            | High Z             |
| Deep Power-Down                 | 9     | VIL             | Х               | Х               | X               | Х               | Х               | Х        | Х               | High Z            | High Z             |
| Intelligent Identifier (Mfr)    | 4     | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $V_{ID}$        | V <sub>IL</sub> | , X      | X.              | 89H               | High Z             |
| Intelligent Identifier (Device) | 4,5   | V <sub>IH</sub> | V <sub>IL</sub> | VIL             | V <sub>IH</sub> | V <sub>ID</sub> | VIH             | Х        | Х               | See Table 6       | High Z             |
| Write                           | 6,7,8 | V <sub>IH</sub> | VIL             | V <sub>IH</sub> | VIL             | X               | X               | Х        | Х               | DiN               | High Z             |

- 1. Refer to DC Characteristics.
- 2. X can be  $V_{IL}$ ,  $V_{IH}$  for control pins and addresses,  $V_{PPLK}$  or  $V_{PPH}$  for  $V_{PP}$ .
- 3. See DC Characteristics for V<sub>PPLK</sub>, V<sub>PPH</sub>1, V<sub>PPH</sub>2, V<sub>HH</sub>, V<sub>ID</sub> voltages.
  4. Manufacturer and Device codes may also be accessed via a CUI write sequence, A<sub>1</sub>-A<sub>16</sub> = X, A<sub>1</sub>-A<sub>17</sub> = X.
- 5. See Table 6 of Device IDs.
- 6. Refer to Table 7 for valid DIN during a Write operation.
- 7. Command writes for Block Erase or Word/Byte Write are only executed when V<sub>PP</sub> = V<sub>PPH</sub>1 or V<sub>PPH</sub>2.
- 8. To Write or Erase the boot block, hold RP# at VHH or WP# at VIH.
- 9. RP# must be at GND ± 0.2V to meet the maximum deep power-down current specified.



### 3.2.2 INTELLIGENT IDENTIFIERS

The intelligent identifiers of the SmartVoltage boot block components are identical to the boot block products that operate only at 12V V<sub>PP</sub>. The manufacturer and device codes are read via the CUI or by taking the A<sub>9</sub> pin to V<sub>ID</sub>. Writing 90H to the CUI places the device into intelligent identifier read mode. In this mode, A<sub>0</sub> = 0 outputs the manufacturer's identification code and A<sub>0</sub> = 1 outputs the device code. When BYTE# is at a logic low, only the lower byte of the above signatures is read and DQ<sub>15</sub>/A<sub>-1</sub> is a "don't care" during intelligent identifier mode. For x8 only products only the lower byte is read. See the Table 6 below for product signatures. A Read Array command must be written to the memory to return to the read array mode.

**Table 6. Intelligent Identifier Table** 

|         | Mfr. ID | Device ID        |                     |  |  |
|---------|---------|------------------|---------------------|--|--|
| Product |         | -T<br>(Top Boot) | -B<br>(Bottom Boot) |  |  |
| 28F200  | 0089 H  | 2274 H           | 2275 H              |  |  |
| 28F002  | 89 H    | 7C H             | 7D H                |  |  |

## 3.3 Write Operations

### 3.3.1 COMMAND USER INTERFACE (CUI)

The Command User Interface (CUI) serves as the interface between the microprocessor and the internal chip controller. Commands are written to the CUI using standard microprocessor write timings. The available commands are Read Array, Read Intelligent Identifier, Read Status Register, Clear Status

## 2-MBIT SmartVoltage BOOT BLOCK FAMILY

Register, Erase and Program (summarized in Tables 7 and 8). For Read commands, the CUI points the read path at either the array, the intelligent identifier, or the Status Register depending on the command received. For Program or Erase commands, the CUI informs the Write State Machine (WSM) that a write or erase has been requested. During the execution of a Program command, the WSM will control the programming sequences and the CUI will only respond to status reads. During an erase cycle, the CUI will respond to status reads and erase suspend. After the WSM has completed its task, it will set the WSM Status bit to a "1," which will also allow the CUI to respond to its full command set. Note that after the WSM has returned control to the CUI, the CUI will stay in the current command state until it receives another command.

Table 7. Command Set Codes and Corresponding Device Mode

| Command Codes | Device Mode                |  |  |
|---------------|----------------------------|--|--|
| 00            | Invalid Reserved           |  |  |
| 10            | Alternate Program Set-Up   |  |  |
| 20            | Erase Set-Up               |  |  |
| 40            | Program Set-Up             |  |  |
| 50            | Clear Status Register      |  |  |
| 70            | Read Status Register       |  |  |
| 90            | Intelligent Identifier     |  |  |
| B0            | Erase Suspend              |  |  |
| D0            | Erase Resume/Erase Confirm |  |  |
| FF            | Read Array                 |  |  |



## **Table 8. Command Bus Definitions**

| 0                         | Notes | First Bus Cycle |      | Second Bus Cycle |       |      |      |
|---------------------------|-------|-----------------|------|------------------|-------|------|------|
| Command                   |       | Oper            | Addr | Data             | Oper  | Addr | Data |
| Read Array                | 8     | Write           | х    | FFH              |       |      |      |
| Intelligent Identifier    | 1     | Write           | Х    | 90H              | Read  | IA   | IID  |
| Read Status Register      | 2,4   | Write           | Х    | 70H              | Read  | Х    | SRD  |
| Clear Status Register     | 3     | Write           | Х    | 50H              |       |      |      |
| Word/Byte Write           |       | Write           | WA   | 40H              | Write | WA   | WD   |
| Alternate Word/Byte Write | 6,7   | Write           | WA   | - 10H            | Write | WA   | WD   |
| Block Erase/Confirm       | 6,7   | Write           | BA   | 20H              | Write | ВА   | D0H  |
| Erase Suspend/Resume      | 5     | Write           | Х    | вон              | Write | Х    | D0H  |

## **ADDRESS**

DATA

BA = Block Address

SRD = Status Register Data

IA = Identifier Address

IID = Identifier Data

WA = Write Address

WD = Write Data

X = Don't Care

### NOTES:

- 1. Bus operations are defined in Tables 4 and 5.
- 2. IA = Identifier Address: A0 = 0 for manufacturer code, A0 = 1 for device code.
- 3. SRD-Data read from Status Register.
- IID = Intelligent Identifier Data. Following the Intelligent Identifier command, two Read operations access manufacturer and device codes.
- 5. BA = Address within the block being erased.
- 6. WA = Address to be written. WD = Data to be written at location WD.
- 7. Either 40H or 10H commands is valid.
- When writing commands to the device, the upper data bus [DQ<sub>8</sub>-DQ<sub>15</sub>] = X (28F200 only) which is either V<sub>IL</sub> or V<sub>IH</sub>, to
  minimize current draw.



## 3.3.1.1 Command Function Description

Device operations are selected by writing specific commands into the CUI. Tables 7 and 8 define the available commands.

### Invalid/Reserved

These are unassigned commands and should not be used. Intel reserves the right to redefine these codes for future functions.

## Read Array (FFH)

This single write cycle command points the read path at the array. If the host CPU performs a CE#/OE#-controlled Read immediately following a two-write sequence that started the WSM, then the device will output Status Register contents. If the Read Array command is given after the Erase Setup command, the device will reset to read the array. A two Read Array command sequence (FFH) is required to reset to Read Array after the Program Setup command.

## Intelligent Identifier (90H)

After this command is executed, the CUI points the output path to the intelligent identifier circuits. Only intelligent identifier values at addresses 0 and 1 can be read (only address  $A_0$  is used in this mode, all other address inputs are ignored).

## Read Status Register (70H)

This is one of the two commands that is executable while the WSM is operating. After this command is written, a read of the device will output the contents of the Status Register, regardless of the address presented to the device.

The device automatically enters this mode after program or erase has completed.

## Clear Status Register (50H)

The WSM can only set the Program Status and Erase Status bits in the Status Register to "1," it cannot clear them to "0."

Two reasons exist for operating the Status Register in this fashion. The first is synchronization. Since

## 2-MBIT SmartVoltage BOOT BLOCK FAMILY

the WSM does not know when the host CPU has read the Status Register, it would not know when to clear the status bits. Secondly, if the CPU is programming a string of bytes, it may be more efficient to query the Status Register after programming the string. Thus, if any errors exist while programming the string, the Status Register will return the accumulated error status.

## Program Setup (40H or 10H)

This command simply sets the CUI into a state such that the next write will load the Address and Data registers. After this command is executed, the outputs default to the Status Register. A two Read Array command sequence (FFH) is required to reset to Read Array after the Program Setup command.

## **Program**

The second write after the Program Setup command, will latch addresses and data. Also, the CUI initiates the WSM to begin execution of the program algorithm. The device outputs Status Register data when OE# is enabled. A Read Array command is required after programming, to read array data.

## Erase Setup (20H)

Prepares the CUI for the Erase Confirm command. No other action is taken. If the next command is not an Erase Confirm command, then the CUI will set both the Program Status and Erase Status bits of the Status Register to a "1," place the device into the Read Status Register state, and wait for another command.

## Erase Confirm (D0H)

If the previous command was an Erase Setup command, then the CUI will enable the WSM to erase, at the same time closing the address and data latches, and respond only to the Read Status Register and Erase Suspend commands. While the WSM is executing, the device will output Status Register data when OE# is toggled low. Status Register data can only be updated by toggling either OE# or CE# low.



### Erase Suspend (B0H)

This command is only valid while the WSM is executing an Erase operation, and therefore will only be responded to during an Erase operation. After this command has been executed, the CUI will set an output that directs the WSM to suspend Erase operations, and then respond only to Read Status Register or to the Erase Resume commands. Once the WSM has reached the Suspend state, it will set an output into the CUI which allows the CUI to respond to the Read Array, Read Status Register, and Erase Resume commands. In this mode, the CUI will not respond to any other commands. The WSM will also set the WSM Status bit to a "1." The WSM will continue to run, idling in the SUSPEND state, regardless of the state of all input control pins except RP#. which will immediately shut down the WSM and the remainder of the chip, if it is made active. During a Suspend operation, the data and address latches will remain closed, but the address pads are able to drive the address into the read path.

### Erase Resume (D0H)

This command will cause the CUI to clear the Suspend state and clear the WSM Status Bit to a "0," but only if an Erase Suspend command was previously issued. Erase Resume will not have any effect under any other conditions.

### 3.3.2 STATUS REGISTER

The device contains a Status Register which may be read to determine when a Program or Erase operation is complete, and whether that operation completed successfully. The Status Register may be read at any time by writing the Read Status command to the CUI. After writing this command, all subsequent Read operations output data from the Status Register until another command is written to the CUI. A Read Array command must be written to the CUI to return to the read array mode.

The Status Register bits are output on DQ[0:7], whether the device is in the byte-wide (x8) or word-wide (x16) mode. In the word-wide mode the upper byte, DQ[8:15], is set to 00H during a Read Status command. In the byte-wide mode, DQ[8:14] are tristated and DQ $_{15}/A_{-1}$  retains the low order address function.

Important: The contents of the Status Register are latched on the falling edge of OE# or CE#, whichever occurs last in the read cycle. This prevents possible bus errors which might occur if the contents of the Status Register change while reading the Status Register. CE# or OE# must be toggled with each subsequent status read, or the completion of a Program or Erase operation will not be evident from the Status Register.

When the WSM is active, this register will indicate the status of the WSM, and will also hold the bits indicating whether or not the WSM was successful in performing the desired operation.

### 3.3.2.1 Clearing the Status Register

The WSM sets status bits "3" through "7" to "1." and clears bits "6" and "7" to "0," but cannot clear status bits "3" through "5" to "0." Bits 3 through 5 can only be cleared by the controlling CPU through the use of the Clear Status Register command. These bits can indicate various error conditions. By allowing the system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several bytes or erasing multiple blocks in sequence). The Status Register may then be read to determine if an error occurred during that programming or erasure series. This adds flexibility to the way the device may be programmed or erased. To clear the Status Register, the Clear Status Register command is written to the CUI. Then, any other command may be issued to the CUI. Note, again, that before a read cycle can be initiated, a Read Array command must be written to the CUI to specify whether the read data is to come from the Memory Array, Status Register, or Intelligent Identifier.





**Table 9. Status Register Bit Definition** 

| WSMS | ESS | ES | DWS | VPPS | R | R | R |  |
|------|-----|----|-----|------|---|---|---|--|
| 7    | 6   | 5  | 4   | 3    | 2 | 1 | 0 |  |

| SR.7 = WRITE STATE MACHINE STATUS (WSMS)  1 = Ready 0 = Busy                                               | NOTES: Write State Machine bit must first be checked to determine Byte/Word program or Block Erase completion, before the Program or Erase Status bits are checked for success.                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR.6 = ERASE-SUSPEND STATUS (ESS)  1 = Erase Suspended  0 = Erase in Progress/Completed                    | When Erase Suspend is issued, WSM halts execution and sets both WSMS and ESS bits to "1." ESS bit remains set to "1" until an Erase Resume command is issued.                                                                                                                                                                                                                                                                              |
| SR.5 = ERASE STATUS  1 = Error in Block Erasure  0 = Successful Block Erase                                | When this bit is set to "1," WSM has applied the maximum number of erase pulses to the block and is still unable to successfully verify block erasure.                                                                                                                                                                                                                                                                                     |
| SR.4 = PROGRAM STATUS  1 = Error in Byte/Word Program  0 = Successful Byte/Word Program                    | When this bit is set to "1," WSM has attempted but failed to program a byte or word.                                                                                                                                                                                                                                                                                                                                                       |
| SR.3 = V <sub>PP</sub> STATUS<br>1 = V <sub>PP</sub> Low Detect, Operation Abort<br>0 = V <sub>PP</sub> OK | The V <sub>PP</sub> Status bit, unlike an A/D converter, does not provide continuous indication of V <sub>PP</sub> level. The WSM interrogates V <sub>PP</sub> level only after the Byte Write or Erase command sequences have been entered, and informs the system if V <sub>PP</sub> has not been switched on. V <sub>PP</sub> Status bit is not guaranteed to report accurate feedback between V <sub>PPLK</sub> and V <sub>PPH</sub> . |
| SR.2-SR.0 = RESERVED FOR FUTURE                                                                            | These bits are reserved for future use and should be                                                                                                                                                                                                                                                                                                                                                                                       |

#### 3.3.3 PROGRAM MODE

Programming is executed using a two-write sequence. The Program Setup command is written to the CUI followed by a second write which specifies the address and data to be programmed. The WSM will execute a sequence of internally timed events to:

**ENHANCEMENTS** 

- Program the desired bits of the addressed memory word or byte.
- Verify that the desired bits are sufficiently programmed.

Programming of the memory results in specific bits within a byte or word being changed to a "0."

If the user attempts to program "1"s, there will be no change of the memory cell content and no error occurs.

masked out when polling the Status Register.

Similar to erasure, the Status Register indicates whether programming is complete. While the program sequence is executing, bit 7 of the Status Register is a "0." The Status Register can be polled by toggling either CE# or OE# to determine when the program sequence is complete. Only the Read Status Register command is valid while programming is active.

When programming is complete, the status bits, which indicate whether the Program operation was successful, should be checked. If the programming operation was unsuccessful, bit 4 of the Status





Register is set to a "1" to indicate a Program Failure. If bit 3 is set to a "1," then V<sub>PP</sub> was not within acceptable limits, and the WSM did not execute the programming sequence. If the program operation fails, bit 4 of the Status Register will be set within 1.5 ms as determined by the timeout of the WSM.

The Status Register should be cleared before attempting the next operation. Any CUI instruction can follow after programming is completed; however, reads from the Memory Array, Status Register, or Intelligent Identifier cannot be accomplished until the CUI is given the Read Array command.

### 3.3.4 ERASE MODE

Erasure of a single block is initiated by writing the Erase Setup and Erase Confirm commands to the CUI, along with the addresses identifying the block to be erased. These addresses are latched internally when the Erase Confirm command is issued. Block erasure results in all bits within the block being set to "1."

The WSM will execute a sequence of internally timed events to:

- 1. Program all bits within the block to "0."
- Verify that all bits within the block are sufficiently programmed to "0."
- 3. Erase all bits within the block.
- Verify that all bits within the block are sufficiently erased.

While the erase sequence is executing, bit 7 of the Status Register is a "0."

When the Status Register indicates that erasure is complete, the status bits, which indicate whether the Erase operation was successful, should be checked. If the Erase operation was unsuccessful, bit 5 of the Status Register will be set to a "1", indicating an Erase Failure. If V<sub>PP</sub> was not within acceptable limits after the Erase Confirm command is issued, the WSM will not execute an erase sequence; in-

stead, bit 5 of the Status Register is set to a "1" to indicate an Erase Failure, and bit 3 is set to a "1" to identify that V<sub>PP</sub> supply voltage was not within acceptable limits. If the erase operation fails, bit 5 of the Status Register will be set within 1.5 ms as determined by the timeout of the WSM.

The Status Register should be cleared before attempting the next operation. Any CUI instruction can follow after erasure is completed; however, reads from the Memory Array, Status Register, or Intelligent Identifier cannot be accomplished until the CUI is given the Read Array command.

### 3.3.4.1 Suspending and Resuming Erase

Since an erase operation requires on the order of seconds to complete, an Erase Suspend command is provided to allow erase-sequence interruption in order to read data from another block of the memory. Once the erase sequence is started, writing the Erase Suspend command to the CUI requests that the WSM pause the erase sequence at a predetermined point in the erase algorithm. The Status Register must then be read to determine if the erase operation has been suspended.

At this point, a Read Array command can be written to the CUI in order to read data from blocks other than that which is being suspended. The only other valid command at this time is the Erase Resume command or Read Status Register command.

During erase suspend mode, the chip can go into a pseudo-standby mode by taking CE# to V<sub>IH</sub>, which reduces active current draw.

To resume the erase operation, the chip must be enabled by taking CE# to  $V_{IL}$ , then issuing the Erase Resume command. When the Erase Resume command is given, the WSM will continue with the erase sequence and complete erasing the block. As with the end of a standard erase operation, the Status Register must be read, cleared, and the next instruction issued in order to continue.





Figure 9. Automated Word/Byte Programming Flowchart





Figure 10. Automated Block Erase Flowchart





Figure 11. Erase Suspend/Resume Flowchart



# 3.4 Boot Block Locking

The boot block family architecture features a hardware-lockable boot block so that the kernel code for the system can be kept secure while the parameter and main blocks are programmed and erased independently as necessary. Only the boot block can be locked independently from the other blocks.

## 3.4.1 $V_{PP} = V_{IL}$ FOR COMPLETE PROTECTION

For complete write protection of all blocks in the flash device, the V<sub>PP</sub> programming voltage can be held low. When V<sub>PP</sub> is below V<sub>PPLK</sub>, any program or erase operation will result in a error in the Status Register.

# 3.4.2 WP# = V<sub>IL</sub> FOR BOOT BLOCK LOCKING

When WP# =  $V_{IL}$ , the boot block is locked and any program or erase operation to the boot block will result in an error in the Status Register. All other blocks remain unlocked in this condition and can be programmed or erased normally. Note that this feature is overridden and the boot block unlocked when RP# =  $V_{HH}$ .

# 3.4.3 RP# = $V_{HH}$ OR WP# = $V_{IH}$ FOR BOOT BLOCK UNLOCKING

Two methods can be used to unlock the boot block:

1. WP# =  $V_{IH}$ 

2.  $RP# = V_{HH}$ 

If both or either of these two conditions are met, the boot block will be unlocked and can be programmed or erased. The truth table, Table 10, clearly defines the write protection methods.

# 3.5 Power Consumption

### 3.5.1 ACTIVE POWER

With CE# at a logic-low level and RP# at a logic-high level, the device is placed in the active mode. Refer to the DC Characteristics table for  $I_{CC}$  current values.

Table 10. Write Protection Truth Table for SmartVoltage Boot Block Family

| <del></del>         |                 |                 |                              |  |  |  |  |  |  |  |  |
|---------------------|-----------------|-----------------|------------------------------|--|--|--|--|--|--|--|--|
| V <sub>PP</sub>     | RP#             | WP#             | Write Protection<br>Provided |  |  |  |  |  |  |  |  |
| V <sub>IL</sub>     | Х               | X               | All Blocks Locked            |  |  |  |  |  |  |  |  |
| ≥ V <sub>PPLK</sub> | V <sub>IL</sub> | Х               | All Blocks Locked (Reset)    |  |  |  |  |  |  |  |  |
| ≥ V <sub>PPLK</sub> | V <sub>HH</sub> | Х               | All Blocks Unlocked          |  |  |  |  |  |  |  |  |
| ≥ V <sub>PPLK</sub> |                 |                 | Boot Block Locked            |  |  |  |  |  |  |  |  |
| ≥ V <sub>PPLK</sub> | V <sub>IH</sub> | V <sub>IH</sub> | All Blocks Unlocked          |  |  |  |  |  |  |  |  |

### 3.5.2 AUTOMATIC POWER SAVINGS (APS)

Automatic Power Savings (APS) is a low-power feature during active mode of operation. The boot block flash memory family incorporates Power Reduction Control (PRC) circuitry which allows the device to put itself into a low current state when it is not being accessed. After data is read from the memory array, PRC logic controls the device's power consumption by entering the APS mode where typical I<sub>CC</sub> current is less than 1 mA. The device stays in this static state with outputs valid until a new location is read.

#### 3.5.3 STANDBY POWER

With CE# at a logic-high level ( $V_{IH}$ ), and the CUI in read mode, the memory is placed in standby mode. The standby operation disables much of the device's circuitry and substantially reduces device power consumption. The outputs (DQ[0:15] or DQ[0:7]) are placed in a high-impedance state independent of the status of the OE# signal. When CE# is at logic-high level during erase or program functions, the devices will continue to perform the erase or program function and consume erase or program active power until erase or program is completed.

### 3.5.4 DEEP POWER-DOWN MODE

The SmartVoltage boot block family supports a low typical  $I_{CC}$  in deep power-down mode, which turns off all circuits to save power. This mode is activated by the RP# pin when it is at a logic-low (GND  $\pm 0.2$ V.) (Note: BYTE# pin must be at CMOS levels to meet the  $I_{CCD}$  specification.)



During read modes, the RP# pin going low deselects the memory and places the output drivers in a high impedance state. Recovery from the deep power-down state, requires a minimum access time of tpHOV. (See AC Characteristics table)

During erase or program modes, RP# low will abort either erase or program operations, but the memory contents are no longer valid as the data has been corrupted by the RP# function. As in the read mode above, all internal circuitry is turned off to achieve the power savings.

RP# transitions to  $V_{\text{IL}}$ , or turning power off to the device will clear the Status Register.

# 3.6 Power-Up/Down Operation

The device offers protection against accidental block erasure or programming during power transitions. Power supply sequencing is not required, since the device is indifferent as to which power supply, Vpp or V<sub>CC</sub>, powers-up first. The CUI is reset to the read mode after power-up, but the system must drop CE# low or present a new address to ensure valid data at the outputs.

A system designer must guard against spurious writes when  $V_{CC}$  voltages are above  $V_{LKO}$  and  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either signal to  $V_{IH}$  will inhibit writes to the device. The CUI architecture provides an additional protection since alteration of memory contents can only occur after successful completion of the two-step command sequences. The device is also disabled until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. By holding the device in reset (RP# connected to system PowerGood) during power up/down, invalid bus conditions during power-up can be masked, providing yet another level of memory protection.

#### 3.6.1 RP# CONNECTED TO SYSTEM RESET

The use of RP# during system reset is important with automated write/erase devices because the system expects to read from the flash memory when it comes out of reset. If a CPU reset occurs without a flash memory reset, proper CPU initialization would not occur because the flash memory may be providing status information instead of array data. Intel's flash memories allow proper CPU initialization following a system reset by connecting the RP# pin to the same RESET# signal that resets the system CPU.

### 2-MBIT SmartVoltage BOOT BLOCK FAMILY

### 3.6.2 V<sub>CC</sub>, V<sub>PP</sub> AND RP# TRANSITIONS

The CUI latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its default state upon powerup, after exit from deep power-down mode, or after  $V_{CC}$  transitions above  $V_{LKO}$  (Lockout voltage), is read array mode.

After any Word/Byte Write or Block Erase operation is complete and even after  $V_{PP}$  transitions down to  $V_{PPLK}$ , the CUI must be reset to read array mode via the Read Array command if accesses to the flash memory are desired.

# 3.7 Power Supply Decoupling

Flash memory's power switching characteristics require careful device decoupling methods. System designers should consider three supply current issues:

- 1. Standby current levels (ICCs)
- 2. Active current levels (I<sub>CCR</sub>)
- Transient peaks produced by falling and rising edges of CE#.

Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress these transient voltage peaks. Each flash device should have a 0.1  $\mu F$  ceramic capacitor connected between each  $V_{CC}$  and GND, and between its  $V_{PP}$  and GND. These high frequency, inherently low inductance capacitors should be placed as close as possible to the package leads.

# 3.7.1 V<sub>PP</sub> TRACE ON PRINTED CIRCUIT BOARDS

Designing for in-system writes to the flash memory requires special consideration of the  $V_{PP}$  power supply trace by the printed circuit board designer. The  $V_{PP}$  pin supplies the flash memory cells current for programming and erasing. One should use similar trace widths and layout considerations given to the  $V_{CC}$  power supply trace. Adequate  $V_{PP}$  supply traces, and decoupling capacitors placed adjacent to the component, will decrease spikes and overshoots.



### **Guide to Subsequent Tables**

| Operating Conditions   | Name                                               | Table<br>Number | Page |
|------------------------|----------------------------------------------------|-----------------|------|
| Commercial Temperature | Commercial Operating Conditions                    | 11              | 29   |
|                        | V <sub>CC</sub> Supply Switching Timing            | 12              | 29   |
|                        | DC Characteristics                                 | 13              | 30   |
|                        | AC Characteristics-Read Only Operations            | 14              | 34   |
|                        | AC Characteristics-WE# Controlled Write Operations | 15              | 37   |
|                        | AC Characteristics-CE# Controlled Write Operations | 16              | 40   |
| **                     | Erase and Program Timings                          | ,17             | 43   |
| Extended Temperature   | Extended Operating Conditions                      | 18              | 44   |
|                        | V <sub>CC</sub> Supply Switching Timing            | 19              | 44   |
|                        | DC Characteristics (V <sub>CC</sub> = 5V or 3.3V)  | 20              | 45   |
|                        | AC Characteristics-Read Only Operations            | 21              | 50   |
|                        | AC Characteristics-WE# Controlled Write Operations | 22              | 51   |
|                        | AC Characteristics-CE# Controlled Write Operations | 23              | 53   |
|                        | Erase and Program Timings                          | 24              | 54   |
|                        | Summary of Line Items                              | 25              | 55   |

### NOTE:

In the following tables, the topmost heading lists the line items to which the specifications in that column apply. For space considerations, the line items have been abbreviated as shown in the following table. See Section 7.1 for more information on product naming and line items.

| Abbreviation | Applicable Product Names                                                                                                       |
|--------------|--------------------------------------------------------------------------------------------------------------------------------|
| BV-60        | E28F200BV-T60, E28F200BV-B60, E28F002BV-T60, E28F002BV-B60, E28F200CV-T60, E28F200CV-B60, PA28F200BV-T60, PA28F200BV-B60       |
| BV-80        | E28F200BV-T80, E28F200BV-B80, E28F002BV-T80, E28F002BV-B80, E28F200CV-T80, E28F200CV-B80, PA28F200BV-T80, PA28F200BV-B80       |
| BV-120       | E28F002BV-T120, E28F002BV-B120, PA28F200BV-T120, PA28F200BV-B120                                                               |
| TBV-80       | TE28F200BV-T80, TE28F200BV-B80, TE28F002BV-T80, TE28F002BV-B80, TE28F200CV-T80, TE28F200CV-B80, TB28F200BV-T80, TB28F200BV-B80 |



### 4.0 ABSOLUTE MAXIMUM RATINGS\*

| Commercial Operating Temperature                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------------------|
| During Read0°C to +70°C                                                                                                                        |
| During Block Erase and Word/Byte Write0°C to +70°C                                                                                             |
| Temperature Bias10°C to 80°C                                                                                                                   |
| Extended Operating Temperature                                                                                                                 |
| During Read40°C to +85°C                                                                                                                       |
| During Block Erase and Word/Byte Write 40°C to +85°C                                                                                           |
| Temperature Under Bias40°C to +85°C                                                                                                            |
| Storage Temperature $\dots -65^{\circ}\text{C}$ to $+125^{\circ}\text{C}$                                                                      |
| Voltage on Any Pin (except V <sub>CC</sub> , V <sub>PP</sub> , A <sub>9</sub> and RP#) with Respect to GND $-2.0$ V to $+7.0$ V <sup>(2)</sup> |
| Voltage on Pin RP# or Pin A9 with Respect to GND $-2.0$ V to $+13.5$ V(2,3)                                                                    |
| V <sub>PP</sub> Program Voltage with Respect to GND during Block Erase and Word/Byte Write2.0V to +14.0V(2.3)                                  |
| $V_{CC}$ Supply Voltage with Respect to GND2.0V to $+7.0V^{(2)}$                                                                               |
| Output Short Circuit Current                                                                                                                   |

# 2-MBIT SmartVoltage BOOT BLOCK FAMILY

NOTICE: This document contains information on products in the design phase of development. Do not finalize a design with this information. Revised information will be published when the product is available. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

- Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC} + 0.5V$  which, during transitions, may overshoot to  $V_{CC} + 2.0V$  for periods <20 ns.
- Maximum DC voltage on V<sub>PP</sub> may overshoot to +14.0V for periods <20 ns. Maximum DC voltage on RP# or A<sub>9</sub> may overshoot to 13.5V for periods <20 ns.</li>
- Output shorted for no more than one second. No more than one output shorted at a time.
- 10% V<sub>CC</sub> specifications reference the 28F200/002BV-60 in their standard test configurations, and 28F200/002BV-80/120.
- 5% V<sub>CC</sub> specifications reference the 28F200/002BV-60 in their high speed test configuration.



### 5.0 COMMERCIAL OPERATING CONDITIONS

Table 11. Commercial Temperature and V<sub>CC</sub> Operating Conditions

| Symbol          | Parameter                                   | Notes | Min  | Max  | Units |
|-----------------|---------------------------------------------|-------|------|------|-------|
| TA              | Operating Temperature                       |       | 0    | 70   | °C    |
| V <sub>CC</sub> | 3.3V V <sub>CC</sub> Supply Voltage (±0.3V) |       | 3.0  | 3.6  | Volts |
|                 | 5V V <sub>CC</sub> Supply Voltage (10%)     | 1     | 4.50 | 5.50 | Volts |
|                 | 5V V <sub>CC</sub> Supply Voltage (5%)      | 2     | 4.75 | 5.25 | Volts |

#### NOTES:

- 1. 10% V<sub>CC</sub> specifications apply to the 60, 80 and 120 ns product versions in their standard test configuration.
- 2. 5% V<sub>CC</sub> specifications apply to the 60 ns versions in their high speed test configuration.

# 5.1 Switching V<sub>CC</sub> Voltages

Table 12. V<sub>CC</sub> Supply Switching Timing

| Symbol            | Parameter                                     | Notes | Min | Max | Unit |
|-------------------|-----------------------------------------------|-------|-----|-----|------|
| T <sub>5VPH</sub> | V <sub>CC</sub> at 4.5V (minimum) to RP# High | 1     | 2   |     | μs   |
| T <sub>3VPH</sub> | V <sub>CC</sub> at 3.0V (minimum) to RP# High | 1     | 2   |     | μs   |

- 1. The T<sub>5VPH</sub> and/or T<sub>3VPH</sub> times must be strictly followed to guarantee all other read and write specifications.
- To switch between 3.3V and 5.0V operation, the system should first transition V<sub>CC</sub> from the existing voltage to GND, and then to the new voltage. The V<sub>CC</sub> supply voltage should not be switched when the WSM is busy.



Figure 12. V<sub>CC</sub> Supply Switching Waveform



# 5.2 DC Characteristics

Table 13. DC Characteristics (Commercial)

|                 |                                                     |       |                              | BV-60   | 7-60 BV-60 |                 |                 |       |    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|-----------------------------------------------------|-------|------------------------------|---------|------------|-----------------|-----------------|-------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Parameter                                           | Notes | BV-80 BV-80<br>BV-120 BV-120 |         |            | Units           | Test Conditions |       |    |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 |                                                     |       | V <sub>CC</sub>              | = 3.3 ± | 0.3V       | V <sub>CC</sub> | = 5V ±          | 10%   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 |                                                     |       | Min                          | Тур     | Max        | Min             | Тур             | Max   |    |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| l <sub>IL</sub> | Input Load<br>Current                               | 1     |                              |         | ±1.0       | !               |                 | ± 1.0 | μΑ | $V_{CC} = V_{CC} MAX$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                  |
| LO              | Output Leakage<br>Current                           | 1     |                              |         | ±10        |                 |                 | ± 10  | μΑ | $V_{CC} = V_{CC} MAX$<br>$V_{IN} = V_{CC} or GND$                                                                                                                                                                                                                                                                                                                                                                                  |
| lccs            | V <sub>CC</sub> Standby<br>Current                  | 1,3   |                              | 0.4     | 1.5        |                 | 0.8             | 2.0   | mA | $V_{CC} = V_{CC} MAX$ $CE\# = RP\# =$ $BYTE\# = WP\# = V_{IH}$                                                                                                                                                                                                                                                                                                                                                                     |
|                 |                                                     | -     |                              | 60      | 110        |                 | 50              | 130   | μΑ | V <sub>CC</sub> = V <sub>CC</sub> MAX<br>CE# = RP# =<br>V <sub>CC</sub> ± 0.2V                                                                                                                                                                                                                                                                                                                                                     |
| CCD             | V <sub>CC</sub> Deep<br>Power-Down<br>Current       | 1     |                              | 0.2     | 8          |                 | 0.2             | 8     | μΑ | $V_{CC} = V_{CC} MAX$ $V_{IN} = V_{CC} \text{ or GND}$ $RP\# = GND \pm 0.2V$                                                                                                                                                                                                                                                                                                                                                       |
| ICCR            | V <sub>CC</sub> Read<br>Current for<br>Word or Byte | 1,5,6 |                              | 15      | 30         |                 | 50              | 60    | mA | $\label{eq:cmosinputs} \begin{split} &\textbf{CMOS INPUTS} \\ &\textbf{V}_{CC} = \textbf{V}_{CC}  \textbf{MAX} \\ &\textbf{CE\#} = \textbf{GND} \\ &\textbf{OE\#} = \textbf{V}_{CC} \\ &\textbf{f} = 10  \textbf{MHz}  (5\text{V}), \\ & 5  \textbf{MHz}  (3.3\text{V}) \\ &\textbf{I}_{OUT} = 0  \textbf{mA} \\ &\textbf{Inputs} = \textbf{GND}  \pm  0.2\text{V} \\ &\textbf{or}  \textbf{V}_{CC}  \pm  0.2\text{V} \end{split}$ |
|                 |                                                     |       |                              | 15      | 30         |                 | 55              | 65    | mA | TTL INPUTS $V_{CC} = V_{CC} \text{ MAX}$ $CE\# = V_{IL}$ $OE\# = V_{IH}$ $f = 10 \text{ MHz (5V)},$ $5 \text{ MHz (3.3V)}$ $I_{OUT} = 0 \text{ mA}$ $Inputs = V_{IL} \text{ or } V_{IH}$                                                                                                                                                                                                                                           |
| Iccw            | V <sub>CC</sub> Write<br>Current for                | 1,4   |                              | 13      | 30         |                 | 30              | 50    | mA | Word Write in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)                                                                                                                                                                                                                                                                                                                                                             |
| ,               | Word or Byte                                        |       | :                            | , 10    | 25         |                 | 30              | 45    | mA | Word Write in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V)                                                                                                                                                                                                                                                                                                                                                            |



Table 13. DC Characteristics (Commercial) (Continued)

|                  |                                                  |       |                                             | By co By co |     |                 |               |       |                 | · ·                                                                      |
|------------------|--------------------------------------------------|-------|---------------------------------------------|-------------|-----|-----------------|---------------|-------|-----------------|--------------------------------------------------------------------------|
| Symbol           | Parameter                                        | Notes | BV-60 BV-60<br>BV-80 BV-80<br>BV-120 BV-120 |             |     |                 |               | Units | Test Conditions |                                                                          |
|                  | ÷                                                |       | $V_{CC}=3.3\pm0.3V$                         |             |     | V <sub>CC</sub> | = <b>5V</b> ± | 10%   |                 | ·                                                                        |
|                  |                                                  |       | Min                                         | Тур         | Max | Min             | Тур           | Max   | <u></u>         |                                                                          |
| ICCE             | V <sub>CC</sub> Erase<br>Current                 | 1,4   | ·                                           | 13          | 30  |                 | 18            | 35    | mA              | Block Erase in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)  |
|                  | ţ                                                | ,     |                                             | 10          | 25  |                 | -18           | 30    | mA              | Block Erase in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V) |
| CCES             | V <sub>CC</sub> Erase<br>Suspend<br>Current      | 1,2   |                                             | 3           | 8.0 |                 | 5             | .10   | mA              | CE# = V <sub>IH</sub><br>Block Erase Suspend                             |
| I <sub>PPS</sub> | V <sub>PP</sub> Standby<br>Current               | 1     |                                             | ±5          | ±15 |                 | ± 5           | ± 10  | μΑ              | V <sub>PP</sub> ≤ V <sub>CC</sub>                                        |
| I <sub>PPD</sub> | V <sub>PP</sub> Deep<br>Power-Down<br>Current    | 1     |                                             | 0.2         | 10  |                 | 0.2           | 5.0   | μΑ              | RP# = GND ± 0.2V                                                         |
| I <sub>PPR</sub> | V <sub>PP</sub> Read<br>Current                  | 1     |                                             | 50          | 200 |                 | 30            | 200   | μΑ              | V <sub>PP</sub> > V <sub>CC</sub>                                        |
| I <sub>PPW</sub> | V <sub>PP</sub> Word/Byte<br>Write Current       | 1,4   |                                             | 13          | 30  |                 | 13            | 25    | mA              | V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)<br>Word Write in Progress   |
|                  |                                                  |       |                                             | 8           | 25  |                 | 8             | 20    |                 | V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V)<br>Word Write in Progress  |
| IPPE             | V <sub>PP</sub> Erase<br>Current                 | 1,4   |                                             | 13          | 30  |                 | 10            | 20    | mA              | V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)<br>Block Erase in Progress  |
|                  |                                                  |       |                                             | 8           | 25  |                 | 5             | 15    |                 | V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V)<br>Block Erase in Progress |
| IPPES            | V <sub>PP</sub> Erase<br>Suspend<br>Current      | 1     |                                             | 50          | 200 |                 | 30            | 200   | μΑ              | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspend<br>in Progress |
| I <sub>RP#</sub> | RP# Boot Block<br>Unlock Current                 | 1,4   |                                             |             | 500 |                 |               | 500   | μΑ              | RP# = V <sub>HH</sub>                                                    |
| l <sub>ID</sub>  | A <sub>9</sub> Intelligent<br>Identifier Current | 1,4   |                                             |             | 500 |                 |               | 500   | μΑ              | $A_9 = V_{ID}$                                                           |



Table 13. DC Characteristics (Commercial) (Continued)

| Symbol             | Parameter                                        | Notes |                          |           |                           | E                        | BV-60<br>BV-80<br>BV-120 |                           | Units | Test Conditions                             |  |
|--------------------|--------------------------------------------------|-------|--------------------------|-----------|---------------------------|--------------------------|--------------------------|---------------------------|-------|---------------------------------------------|--|
|                    |                                                  |       | · V <sub>CC</sub> =      | = 3.3 ± 0 | ).3V                      | V <sub>CC</sub> =        | = <b>5V</b> ± 1          | 10%                       |       |                                             |  |
|                    |                                                  |       | Min                      | Тур       | Max                       | Min                      | Тур                      | Max                       |       | •                                           |  |
| V <sub>ID</sub>    | A <sub>9</sub> Intelligent<br>Identifier Voltage |       | 11.4                     |           | 12.6                      | 11.4                     |                          | 12.6                      | \ \ \ |                                             |  |
| V <sub>IL</sub>    | Input Low<br>Voltage                             |       | -0.5                     |           | 0.8                       | -0.5                     |                          | 0.8                       | ٧     |                                             |  |
| V <sub>IH</sub>    | Input High<br>Voltage                            |       | 2.0                      |           | V <sub>CC</sub><br>+ 0.5V | 2.0                      |                          | V <sub>CC</sub><br>+ 0.5V | ٧     |                                             |  |
| V <sub>OL</sub>    | Output Low<br>Voltage                            |       |                          |           | 0.45                      |                          |                          | 0.45                      | ٧     | $V_{CC} = V_{CC} MIN$ $I_{OL} = 5.8 mA$     |  |
| V <sub>OH</sub> 1  | Output High<br>Voltage (TTL)                     |       | 2.4                      |           |                           | 2.4                      |                          |                           | ٧     | $V_{CC} = V_{CC} MIN$ $I_{OH} = -2.5 mA$    |  |
| V <sub>OH</sub> 2  | Output High<br>Voltage                           |       | 0.85 V <sub>CC</sub>     |           |                           | 0.85 V <sub>CC</sub>     |                          |                           | ٧     | $V_{CC} = V_{CC} MIN$<br>$I_{OH} = -2.5 mA$ |  |
|                    | (CMOS)                                           |       | V <sub>CC</sub><br>-0.4V |           |                           | V <sub>CC</sub><br>-0.4V |                          |                           |       | $V_{CC} = V_{CC} MIN$ $I_{OH} = -100 \mu A$ |  |
| V <sub>PPLK</sub>  | V <sub>PP</sub> Lock-Out<br>Voltage              | 3     | 0.0                      |           | 1.5                       | 0.0                      |                          | 1.5                       | ٧     | Complete Write<br>Protection                |  |
| V <sub>PPH</sub> 1 | V <sub>PP</sub><br>(Program/Erase<br>Operations) |       | 4.5                      | -         | 5.5                       | 4.5                      |                          | 5.5                       | ٧     | V <sub>PP</sub> at 5V                       |  |
| V <sub>PPH</sub> 2 | V <sub>PP</sub><br>(Program/Erase<br>Operations) |       | 11.4                     | ·         | 12.6                      | 11.4                     |                          | 12.6                      | ٧     | V <sub>PP</sub> at 12V                      |  |
| V <sub>LKO</sub>   | V <sub>CC</sub> Erase/Write<br>Lock Voltage      | 8     | 2.0                      |           |                           | 2.0                      |                          |                           | ٧     |                                             |  |
| V <sub>HH</sub>    | RP# Unlock<br>Voltage                            |       | 11.4                     |           | 12.6                      | 11.4                     |                          | 12.6                      | ٧     | Boot Block<br>Write/Erase                   |  |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, T = 25°C. These currents are valid for all product versions (packages and speeds).
- 2. ICCES is specified with the device deselected. If the device is read while in erase suspend mode, current draw is the sum of ICCES and ICCR.
- 3. Block erases and word/byte writes are inhibited when Vpp = VppLK, and not guaranteed in the range between VppH1 and V<sub>PPLK</sub>.
- 4. Sampled, not 100% tested.
- Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA typical, in static operation.
   CMOS Inputs are either V<sub>CC</sub> ± 0.2V or GND ± 0.2V. TTL Inputs are either V<sub>IL</sub> or V<sub>IH</sub>.
- 7. For the 28F002, address pin A<sub>10</sub> follows the C<sub>OUT</sub> capacitance numbers.
- 8. For all BV parts,  $V_{LKO} = 2.0V$  for both 3.3V and 5V operations.





Figure 13. 3.3V Inputs and Measurement Points



Figure 14. 3.3V Standard Test Configuration



Figure 15. 5V Inputs and Measurement Points



Figure 16. 5V Standard Test Configuration



Figure 17. 5V High Speed Test Configuration



# 5.3 AC Characteristics

Table 14. AC Characteristics: Read Only Operations (Commercial)

|                   |                                                                             |                 |                  |     | BV                 | <b>7-60</b> |                     |     |       |
|-------------------|-----------------------------------------------------------------------------|-----------------|------------------|-----|--------------------|-------------|---------------------|-----|-------|
|                   |                                                                             | V <sub>CC</sub> | 5V ± 5%<br>30 pF |     | 5V ± 10%<br>100 pF |             | 3.3 ± 0.3V<br>50 pF |     | 1     |
| Symbol            | Parameter                                                                   | Note            | Min              | Max | Min                | Max         | Min                 | Max | Units |
| t <sub>AVAV</sub> | Read Cycle Time                                                             |                 | 60               |     | 70                 |             | 110                 |     | ns    |
| tavqv             | Address to Output Delay                                                     |                 |                  | 60  |                    | 70          |                     | 110 | ns    |
| t <sub>ELQV</sub> | CE# to Output Delay                                                         | 2               |                  | 60  |                    | 70          |                     | 110 | ns    |
| t <sub>PHQV</sub> | RP# to Output Delay                                                         |                 |                  | 450 |                    | 450         |                     | 800 | ns    |
| t <sub>GLQV</sub> | OE# to Output Delay                                                         | 2               |                  | 30  |                    | 35          |                     | 65  | ns    |
| t <sub>ELQX</sub> | CE# to Output in Low Z                                                      | 3               | 0                |     | 0                  |             | 0                   |     | ns    |
| t <sub>EHQZ</sub> | CE# to Output in High Z                                                     | 3               |                  | 20  |                    | 25          |                     | 55  | ns    |
| t <sub>GLQX</sub> | OE# to Output in Low Z                                                      | 3               | 0                |     | 0                  |             | 0                   |     | ns    |
| t <sub>GHQZ</sub> | OE# to Output in High Z                                                     | 3               |                  | 20  |                    | 25          |                     | 45  | ns    |
| t <sub>OH</sub>   | Output Hold from<br>Address CE#, or OE#<br>change whichever<br>occurs first | 3               | 0                |     | 0                  | ·           | 0                   |     | ns    |
| t <sub>ELFL</sub> | CE# Low to BYTE#<br>High or Low                                             | 3               |                  | 5   |                    | 5           |                     | 7   | ns    |
| t <sub>AVFL</sub> | Address to BYTE# High or Low                                                | 3               |                  | 5   |                    | 5           |                     | 7   | ns    |
| t <sub>FLQV</sub> | BYTE# to Output Delay                                                       | 3,4             |                  | 60  |                    | 70          |                     | 110 | ns    |
| t <sub>FLQZ</sub> | BYTE# Low to Output in High Z                                               | 3               |                  | 20  |                    | 25          |                     | 45  | ns    |



# 5.3 AC Characteristics

Table 14. AC Characteristics: Read Only Operations (Commercial) (Continued)

|                                        |                                                                                   |      |      | BV    | -80   |        |      | BV-  | 120   |        |       |
|----------------------------------------|-----------------------------------------------------------------------------------|------|------|-------|-------|--------|------|------|-------|--------|-------|
|                                        |                                                                                   | Vcc  | 5V ± | : 10% | 3.3 ± | ± 0.3V | 5V ± | 10%  | 3.3 ± | : 0.3V | 1     |
|                                        |                                                                                   | Load | 100  | ) pF  | 50    | pF     | 100  | ) pF | 50    | pF     | 1     |
| Symbol                                 | Parameter                                                                         | Note | Min  | Max   | Min   | Max-   | Min  | Max  | Min   | Max    | Units |
| t <sub>AVAV</sub>                      | Read Cycle Time                                                                   |      | 80   |       | 150   |        | 120  |      | 180   |        | ns    |
| t <sub>AVQV</sub>                      | Address to<br>Output Delay                                                        |      |      | 80    |       | 150    |      | 120  |       | 180    | ns    |
| t <sub>ELQV</sub>                      | CE# to Output<br>Delay                                                            | 2    |      | 80    | -     | 150    |      | 120  |       | 180    | ns    |
| t <sub>PHQV</sub>                      | RP# to Output<br>Delay                                                            |      |      | 450   |       | 800    |      | 450  |       | 800    | ns    |
| tGLQV                                  | OE# to Output<br>Delay                                                            | 2    |      | 40    |       | 90     |      | 40   |       | 90     | ns    |
| t <sub>ELQX</sub>                      | CE# to Output in Low Z                                                            | 3    | 0    |       | 0     |        | 0    |      | 0     |        | ns    |
| t <sub>EHQZ</sub>                      | CE# to Output in High Z                                                           | 3    |      | 30    |       | 80     |      | 30   |       | 80     | ns    |
| t <sub>GLQX</sub>                      | OE# to Output in Low Z                                                            | 3    | 0    |       | 0     |        | 0    |      | 0     |        | ns    |
| t <sub>GHQZ</sub>                      | OE# to Output in High Z                                                           | 3    |      | 30    |       | 60     |      | 30   |       | 60     | ns    |
| tон                                    | Output Hold<br>from Address<br>CE#, or OE#<br>change<br>whichever<br>occurs first | 3    | 0    |       | 0     |        | 0    |      | 0     |        | ns    |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> | CE# Low to<br>BYTE# High or<br>Low                                                | 3    |      | 5     | ,     | 10     |      | 5    |       | 10     | ns    |
| t <sub>AVFL</sub>                      | Address to<br>BYTE# High or<br>Low                                                | 3    |      | 5     |       | 10     |      | 5    |       | 10     | ns    |
| t <sub>FLQV</sub>                      | BYTE# to<br>Output Delay                                                          | 3,4  |      | 80    |       | 150    |      | 120  |       | 180    | ns    |
| t <sub>FLQZ</sub>                      | BYTE# Low to<br>Output in High Z                                                  | 3    |      | 30    |       | 60     |      | 30   |       | 60     | ns    |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to  $t_{\text{CE}}-t_{\text{OE}}$  after the falling edge of CE# without impact on  $t_{\text{CE}}$ . Sampled, but not 100% tested.
- 4. t<sub>FLOV</sub>, BYTE# switching low to valid output delay will be equal to t<sub>AVOV</sub>, measured from the time DQ<sub>15</sub>/A<sub>-1</sub> becomes valid.
- 5. See 5V High Speed Test Configuration.
- 6. See 5V Standard Test Configuration.
- 7. See 3.3V Test Configuration





Figure 18. AC Waveforms for Read Operations



Figure 19. BYTE# Timing Diagram for Both Read and Write Operations with  $V_{CC}$  at 5.0V



Table 15. AC Characteristics: WE #—Controlled Write Operations(1) (Commercial)

|                    |                                                | į               |                |     | BV           | -60  |       |        | į     |
|--------------------|------------------------------------------------|-----------------|----------------|-----|--------------|------|-------|--------|-------|
|                    |                                                | V <sub>CC</sub> | 5V :           | ±5% | 5 <b>V</b> ± | 10%  | 3.3 ± | ± 0.3V | ]     |
|                    |                                                | Load            | 30             | pF  | 100          | ) pF | 50    | pF     | 1     |
| Symbol             | Parameter                                      | Note            | Min            | Max | Min          | Max  | Min   | Max    | Units |
| tavav              | Write Cycle Time                               |                 | 60             |     | 70           |      | 110   |        | ns    |
| t <sub>PHWL</sub>  | RP# Setup to WE#<br>Going Low                  |                 | 450            |     | 450          |      | 800   |        | ns    |
| <sup>t</sup> ELWL  | CE# Setup to WE#<br>Going Low                  |                 | 0              |     | 0            |      | 0     |        | ns    |
| t <sub>PHHWH</sub> | Boot Block Lock Setup<br>to WE# Going High     | 6,8             | 100            |     | 100          |      | 200   |        | ns    |
| tvpwH              | V <sub>PP</sub> Setup to WE#<br>Going High     | 5,8             | 100            | -   | 100          |      | 200   |        | ns    |
| <sup>t</sup> AVWH  | Address Setup to WE#<br>Going High             | 3               | 50             |     | 50           |      | 90    |        | ns    |
| t <sub>DVWH</sub>  | Data Setup to WE#<br>Going High                | 4               | 50             |     | 50           |      | 90    |        | ns    |
| twLwH              | WE# Pulse Width                                |                 | 50             |     | 50           |      | 90    |        | ns    |
| twHDX              | Data Hold Time from WE# High                   | 4               | 0              |     | 0            |      | 0     | ·      | ns    |
| <sup>t</sup> whax  | Address Hold Time from WE# High                | 3               | 10             |     | 10           |      | 10    |        | ns    |
| twheh              | CE# Hold Time from<br>WE# High                 |                 | 0              |     | 0            |      | 0     |        | ns    |
| twhwL              | WE# Pulse Width High                           |                 | 10             |     | 20           |      | 20    |        | ns    |
| <sup>t</sup> WHQV1 | Duration of Word/Byte<br>Programming Operation | 2,5             | 6              |     | 6            | ,    | 6     |        | μs    |
| twhQV2             | Duration of Erase<br>Operation (Boot)          | 2,5,6           | 0.3            |     | 0.3          |      | 0.3   |        | s     |
| twнqvз             | Duration of Erase<br>Operation (Parameter)     | 2,5             | 0.3            |     | 0.3          |      | 0.3   |        | S     |
| twHQV4             | Duration of Erase<br>Operation (Main)          | 2,5             | 0.6            |     | 0.6          |      | 0.6   |        | s     |
| t <sub>QWL</sub>   | V <sub>PP</sub> Hold from Valid SRD            | 5,8             | <sup>-</sup> 0 |     | 0            | ,    | 0     |        | ns    |
| <sup>t</sup> QVPH  | RP# V <sub>HH</sub> Hold from<br>Valid SRD     | 6,8             | 0              |     | . 0          |      | 0     |        | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock Delay                        | 7,8             |                | 100 |              | 100  |       | 200    | ns    |



Table 15. AC Characteristics: WE#—Controlled Write Operations(1) (Commercial) (Continued)

|                    |                                                |       |             | ву   | <b>'-80</b> |      |      | BV-  | -120  |      |       |
|--------------------|------------------------------------------------|-------|-------------|------|-------------|------|------|------|-------|------|-------|
|                    |                                                | Vcc   | <b>5V</b> ± | 10%  | 3.3 ±       | 0.3V | 5V ± | 10%  | 3.3 ± | 0.3V | 1     |
|                    |                                                | Load  | 100         | ) pF | 50          | pF   | 100  | ) pF | 50    | pF   | 1     |
| Symbol             | Parameter                                      | Note  | Min         | Max  | Min         | Max  | Min  | Max  | Min   | Max  | Units |
| t <sub>AVAV</sub>  | Write Cycle Time                               |       | 80          |      | 150         |      | 120  |      | 180   |      | ns    |
| t <sub>PHWL</sub>  | RP# Setup to WE#<br>Going Low                  |       | 450         |      | 1000        |      | 450  |      | 1000  |      | ns    |
| t <sub>ELWL</sub>  | CE# Setup to WE#<br>Going Low                  |       | 0           |      | 0           |      | 0    |      | 0     |      | ns    |
| t <sub>PHHWH</sub> | Boot Block Lock Setup<br>to WE# Going High     | 6,8   | 100         |      | 200         |      | 100  |      | 200   |      | ns    |
| t <sub>VPWH</sub>  | V <sub>PP</sub> Setup to WE#<br>Going High     | 5,8   | 100         |      | 200         |      | 100  |      | 200   |      | ns    |
| t <sub>AVWH</sub>  | Address Setup to WE#<br>Going High             | 3     | 50          |      | 120         |      | 50   |      | 150   |      | ns    |
| t <sub>DVWH</sub>  | Data Setup to WE#<br>Going High                | 4     | 50          |      | 120         |      | 50   |      | 150   |      | ns    |
| twLWH              | WE# Pulse Width                                |       | 50          |      | 120         |      | 50   |      | 150   |      | ns    |
| t <sub>WHDX</sub>  | Data Hold Time from WE# High                   | 4     | 0           |      | 0           |      | 0    |      | 0     |      | ns    |
| t <sub>WHAX</sub>  | Address Hold Time from WE# High                | 3     | 10          |      | 10          |      | 10   |      | 10    |      | ns    |
| twheh              | CE# Hold Time from<br>WE# High                 |       | 0           |      | 0           |      | . 0  |      | 0     |      | ns    |
| twhwL              | WE# Pulse Width High                           |       | 30          |      | 30          |      | 30   |      | 30    |      | ns    |
| t <sub>WHQV1</sub> | Duration of Word/Byte<br>Programming Operation | 2,5   | 6           |      | 6           |      | 6    |      | 6     |      | μs    |
| t <sub>WHQV2</sub> | Duration of Erase<br>Operation (Boot)          | 2,5,6 | 0.3         |      | 0.3         |      | 0.3  |      | 0.3   |      | S     |
| t <sub>WHQV3</sub> | Duration of Erase<br>Operation (Parameter)     | 2,5   | 0.3         |      | 0.3         |      | 0.3  |      | 0.3   |      | S     |
| t <sub>WHQV4</sub> | Duration of Erase<br>Operation (Main)          | 2,5   | 0.6         |      | 0.6         |      | 0.6  |      | 0.6   |      | s     |
| t <sub>QWL</sub>   | V <sub>PP</sub> Hold from Valid SRD            | 5,8   | 0           |      | 0           |      | 0    |      | 0     |      | ns    |
| t <sub>QVPH</sub>  | RP# V <sub>HH</sub> Hold from<br>Valid SRD     | 6,8   | 0           |      | 0           |      | 0    |      | 0     |      | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock Delay                        | 7,8   |             | 100  |             | 200  |      | 100  |       | 200  | ns    |



- Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during read mode.
- The on-chip WSM completely automates Program/Erase operations; Program/Erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- 4. Refer to command definition table for valid D<sub>IN</sub>.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7 = 1).
- For boot block program/erase, RP# should be held at V<sub>HH</sub> or WP# should be held at V<sub>IH</sub> until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the boot block.
- 8. Sampled, but not 100% tested.
- 9. Vpp at 5.0V.
- 10. Vpp at 12.0V.
- 11. See 5V High Speed Test Configuration.
- 12. See 5V Standard Test Configuration.
- 13. See 3.3V Test Configuration.



Figure 20. AC Waveforms for Write and Erase Operations (WE#-Controlled Writes)



Table 16. AC Characteristics: CE#-Controlled Write Operations(1,13) (Commercial)

|                    |                                             |       |      |     | BV          | -60  |       |      |       |
|--------------------|---------------------------------------------|-------|------|-----|-------------|------|-------|------|-------|
|                    |                                             | Vcc   | 5V ± | 5%  | <b>5V</b> ± | 10%  | 3.3 ± | 0.3V | 1     |
|                    | •                                           | Load  | 30   | pF  | 100         | ) pF | 50    | pF   | l     |
| Symbol             | Parameter                                   | Note  | Min  | Max | Min         | Max  | Min   | Max  | Units |
| t <sub>AVAV</sub>  | Write Cycle Time                            |       | 60   |     | 70          |      | 110   |      | ns    |
| t <sub>PHEL</sub>  | RP# High Recovery to CE# Going Low          |       | 450  |     | 450         |      | 1000  |      | ns    |
| twlEL              | WE# Setup to CE# Going Low                  |       | 0    |     | 0           |      | 0     |      | ns    |
| t <sub>PHHEH</sub> | Boot Block Lock Setup to CE# Going High     | 6,8   | 100  |     | 100         |      | 200   |      | ns    |
| t <sub>VPEH</sub>  | V <sub>PP</sub> Setup to CE# Going High     | 5,8   | 100  |     | 100         |      | 200   |      | ns    |
| t <sub>AVEH</sub>  | Address Setup to CE# Going High             | 3     | 50   |     | 50          |      | 90    |      | ns    |
| t <sub>DVEH</sub>  | Data Setup to CE# Going High                | 4     | 50   |     | 50          | •    | 90    |      | ns    |
| t <sub>ELEH</sub>  | CE# Pulse Width                             |       | 50   |     | 50          |      | 90    |      | ns    |
| t <sub>EHDX</sub>  | Data Hold Time from CE# High                | 4     | 0    |     | 0           |      | 0     |      | ns    |
| t <sub>EHAX</sub>  | Address Hold Time from CE# High             | 3     | 10   |     | 10          |      | 10    |      | ns    |
| t <sub>EHWH</sub>  | WE # Hold Time from CE# High                |       | 0    |     | 0           |      | 0     |      | ns    |
| t <sub>EHEL</sub>  | CE# Pulse Width High                        |       | 10   |     | 20          |      | 20    |      | ns    |
| t <sub>EHQV1</sub> | Duration of Word/Byte Programming Operation | 2,5   | 6    |     | 6           |      | 6     |      | μs    |
| t <sub>EHQV2</sub> | Duration of Erase Operation (Boot)          | 2,5,6 | 0.3  |     | 0.3         |      | 0.3   |      | s     |
| t <sub>EHQV3</sub> | Duration of Erase Operation (Parameter)     | 2,5   | 0.3  |     | 0.3         |      | 0.3   |      | s     |
| t <sub>EHQV4</sub> | Duration of Erase Operation (Main)          | 2,5   | 0.6  |     | 0.6         |      | 0.6   |      | s     |
| t <sub>QWL</sub>   | V <sub>PP</sub> Hold from Valid SRD         | 5,8   | 0    |     | 0           |      | 0     |      | ns    |
| t <sub>QVPH</sub>  | RP# V <sub>HH</sub> Hold from Valid SRD     | 6,8   | 0    |     | 0           |      | 0     |      | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock Delay                     | 7,8   |      | 100 |             | 100  |       | 200  | ns    |



Table 16. AC Characteristics: CE #-Controlled Write Operations(1,13) (Commercial) (Continued)

|                    |                                                    |       |      | BV   | <b>'-80</b> |        |      | BV-  | -120 |        |       |
|--------------------|----------------------------------------------------|-------|------|------|-------------|--------|------|------|------|--------|-------|
|                    |                                                    | Vcc   | 5V ± | 10%  | 3.3V        | ± 0.3V | 5V ± | 10%  | 3.3V | ± 0.3V | }     |
|                    |                                                    | Load  | 100  | ) pF | 50          | pF     | 100  | ) pF | 50   | pF     | 1     |
| Symbol             | Parameter                                          | Note  | Min  | Max  | Min         | Max    | Min  | Max  | Min  | Max    | Units |
| t <sub>AVAV</sub>  | Write Cycle Time                                   |       | 80   |      | 150         |        | 120  |      | 180  |        | ns    |
| t <sub>PHEL</sub>  | RP# High<br>Recovery to CE#<br>Going Low           |       | 450  |      | 1000        |        | 450  |      | 1000 |        | ns    |
| tWLEL              | WE# Setup to<br>CE# Going Low                      |       | 0    |      | 0           |        | 0    |      | 0    |        | ns    |
| <sup>t</sup> PHHEH | Boot Block Lock<br>Setup to CE#<br>Going High      | 6,8   | 100  |      | 200         | ī      | 100  |      | 200  |        | ns    |
| t <sub>VPEH</sub>  | V <sub>PP</sub> Setup to CE#<br>Going High         | 5,8   | 100  |      | 200         |        | 100  |      | 200  |        | ns    |
| t <sub>AVEH</sub>  | Address Setup to CE# Going High                    | 3     | 50   |      | 120         |        | 50   |      | 150  |        | ns    |
| <sup>t</sup> DVEH  | Data Setup to CE#<br>Going High                    | 4     | 50   |      | 120         |        | 50   |      | 150  |        | ns    |
| t <sub>ELEH</sub>  | CE# Pulse Width                                    |       | 50   |      | 120         |        | 50   |      | 150  |        | ns    |
| tEHDX .            | Data Hold Time<br>from CE# High                    | 4     | 0    |      | 0           |        | 0    |      | 0    |        | ns    |
| tEHAX              | Address Hold Time from CE# High                    | 3     | 10   |      | 10          |        | 10   |      | 10   |        | ns    |
| tEHWH              | WE # Hold Time<br>from CE# High                    | 1     | 0    |      | 0           |        | 0    |      | 0    |        | ns    |
| t <sub>EHEL</sub>  | CE# Pulse Width<br>High                            |       | 30   |      | 30          |        | 30   |      | 30   |        | ns    |
| tEHQV1             | Duration of Word/<br>Byte Programming<br>Operation | 2,5   | 6    |      | 6           |        | 6    |      | 6    |        | μs    |
| t <sub>EHQV2</sub> | Duration of Erase<br>Operation (Boot)              | 2,5,6 | 0.3  |      | 0.3         |        | 0.3  |      | 0.3  |        | s     |
| t <sub>EHQV3</sub> | Duration of Erase<br>Operation<br>(Parameter)      | 2,5   | 0.3  |      | 0.3         |        | 0.3  |      | 0.3  |        | s     |
| t <sub>EHQV4</sub> | Duration of Erase<br>Operation (Main)              | 2,5   | 0.6  |      | 0.6         |        | 0.6  |      | 0.6  |        | S     |
| tQWL               | V <sub>PP</sub> Hold from<br>Valid SRD             | 5,8   | 0    |      | 0           |        | 0    | ·    | 0    |        | ns    |
| <sup>t</sup> QVPH  | RP# V <sub>HH</sub> Hold<br>from Valid SRD         | 6,8   | 0    |      | 0           |        | 0    |      | 0    |        | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock<br>Delay                         | 7,8   |      | 100  |             | 200    |      | 100  |      | 200    | ns    |

#### NOTES:

See WE# Controlled Write Operations for notes 1 through 12.

<sup>13.</sup> Chip-Enable controlled writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.





Figure 21. Alternate AC Waveforms for Write and Erase Operations (CE#—Controlled Writes)



Table 17. Erase and Program Timings (Commercial  $T_A = 0$ °C to +70°C)

|                                   | V <sub>PP</sub> = 5           | V ± 10%                      | V <sub>PP</sub> = 12           | V ±5%                       |       |
|-----------------------------------|-------------------------------|------------------------------|--------------------------------|-----------------------------|-------|
| Parameter                         | V <sub>CC</sub> =3.3<br>±0.3V | V <sub>CC</sub> =5V<br>± 10% | V <sub>CC</sub> =3.3V<br>±0.3V | V <sub>CC</sub> =5V<br>±10% | Units |
|                                   | Тур                           | Тур                          | Тур                            | Тур                         | ĺ     |
| Boot/Parameter Block Erase Time   | 0.84                          | 0.8                          | 0.44                           | 0.34                        | S     |
| Main Block Erase Time             | 2.4                           | 1.9                          | 1.3                            | 1.1                         | S     |
| Main Block Write Time (Byte Mode) | 1.7                           | 1.8                          | 1.6                            | 1.2                         | s     |
| Main Block Write Time (Word Mode) | 1.1                           | 0.9                          | 0.8                            | 0.6                         | s     |
| Byte Write Time                   | 10                            | 10                           | 8                              | 8                           | μs    |
| Word Write Time                   | 13                            | 13                           | - 8                            | 8                           | μs    |

<sup>1.</sup> All numbers are sampled, not 100% tested.

<sup>2.</sup> Contact your Intel representative for information regarding maximum Byte/Word Write specifications.



## 6.0 EXTENDED OPERATING CONDITIONS

Table 18. Extended Temperature and V<sub>CC</sub> Operating Conditions

| Symbol          | Parameter                                   | Notes | Min  | Max  | Units |
|-----------------|---------------------------------------------|-------|------|------|-------|
| T <sub>A</sub>  | Operating Temperature                       |       | -40  | 85   | °C    |
| V <sub>CC</sub> | 3.3V V <sub>CC</sub> Supply Voltage (±0.3V) | 1     | 3.0  | 3.6  | Volts |
|                 | 5V V <sub>CC</sub> Supply Voltage (10%)     | 2     | 4.50 | 5.50 | Volts |

#### NOTES:

1. AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.

2. 10% V<sub>CC</sub> specifications apply to 110 ns and 80 ns versions in their standard test configuration.

# 6.1 Applying V<sub>CC</sub> Voltages

Table 19. V<sub>CC</sub> Supply Switching Timing

| Symbol            | Parameter                                     | Notes | Min | Max | Units |
|-------------------|-----------------------------------------------|-------|-----|-----|-------|
| T <sub>5VPH</sub> | V <sub>CC</sub> at 4.5V (minimum) to RP# High | 1     | 2   |     | μs    |
| T <sub>3VPH</sub> | V <sub>CC</sub> at 3.0V (minimum) to RP# High | 1     | 2   |     | μs    |

#### NOTES:

1. The T<sub>5VPH</sub> and/or T<sub>3VPH</sub> times must be strictly followed to guarantee all other read and write specifications.

 To switch between 3.3V and 5.0V operation, the system should first transition V<sub>CC</sub> from the existing voltage to GND, and then to the new voltage. The V<sub>CC</sub> supply voltage should not be switched when the WSM is busy.



Figure 22. V<sub>CC</sub> Supply Switching Waveform



# 6.2 DC Characteristics

**Table 20. DC Characteristics: Extended Temperature Operation** 

|                  |                                                      |       |                 | TBV-80         |       |                 | TBV-80        |       |       |                                                                                                                                                                                                                                                                                                                                                    |
|------------------|------------------------------------------------------|-------|-----------------|----------------|-------|-----------------|---------------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol           | Parameter                                            | Notes | V <sub>CC</sub> | = <b>3.3</b> ± | 0.3V  | V <sub>CC</sub> | = <b>5V</b> ± | 10%   | Units | Test Conditions                                                                                                                                                                                                                                                                                                                                    |
|                  |                                                      |       | Min             | Тур            | Max   | Min             | Тур           | Max   |       |                                                                                                                                                                                                                                                                                                                                                    |
| I <sub>I</sub> L | Input Load<br>Current                                | 1     |                 | ,              | ± 1.0 |                 |               | ± 1.0 | μΑ    | $V_{CC} = V_{CC}MAX$<br>$V_{IN} = V_{CC} \text{ or GND}$                                                                                                                                                                                                                                                                                           |
| LO               | Output<br>Leakage<br>Current                         | 1     |                 |                | ± 10  |                 |               | ± 10  | μΑ    | $V_{CC} = V_{CC} MAX$<br>$V_{IN} = V_{CC}$<br>or GND                                                                                                                                                                                                                                                                                               |
| Iccs             | V <sub>CC</sub> Standby<br>Current                   | 1,3   |                 | 0.4            | 1.5   |                 | 0.8           | 2.5   | mA    | $V_{CC} = V_{CC}MAX$ $CE\# = RP\# = BYTE\# = V_{IH}$                                                                                                                                                                                                                                                                                               |
|                  |                                                      |       |                 | 60             | 110   |                 | 70            | 150   | μΑ    | $V_{CC} = V_{CC}MAX$ $CE\# = RP\# = WP\#$ $= V_{CC} \pm 0.2V$                                                                                                                                                                                                                                                                                      |
| CCD              | V <sub>CC</sub> Deep<br>Power-Down<br>Current        | 1     |                 | 0.2            | 8     |                 | 0.2           | 8     | μΑ    | $V_{CC} = V_{CC}MAX$<br>$V_{IN} = V_{CC} \text{ or GND}$<br>$RP\# = GND \pm 0.2V$                                                                                                                                                                                                                                                                  |
| ICCR             | V <sub>CC</sub> Read<br>Current for<br>Word or Byte  | 1,5,6 | ,               | 15             | 30    |                 | 50            | 65    | mA    | $\label{eq:cmosinputs} \begin{split} &\text{CMOS INPUTS} \\ &\text{V}_{CC} = \text{V}_{CC}\text{MAX} \\ &\text{CE\#} = \text{GND} \\ &\text{OE\#} = \text{V}_{CC} \\ &\text{f} = 10 \text{ MHz (5V),} \\ &\text{5 MHz (3.3V)} \\ &\text{I}_{OUT} = 0 \text{ mA} \\ &\text{Inputs} = \text{GND} \pm 0.2V \\ &\text{or V}_{CC} \pm 0.2V \end{split}$ |
|                  |                                                      | ,     | ,               | 15             | 30    |                 | 55            | 70    | mA    | $\begin{split} &\textbf{TTL INPUTS} \\ &\textbf{V}_{CC} = \textbf{V}_{CC} \textbf{MAX} \\ &\textbf{CE\#} = \textbf{V}_{IL} \\ &\textbf{OE\#} = \textbf{V}_{IH} \\ &\textbf{f} = \textbf{10 MHz (5V)}, \\ &\textbf{5 MHz (3.3V)} \\ &\textbf{I}_{OUT} = \textbf{0 mA} \\ &\textbf{Inputs} = \textbf{V}_{IL}  \textbf{or V}_{IH} \end{split}$        |
| lccw             | V <sub>CC</sub> Write<br>Current for<br>Word or Byte | 1,4   |                 | 13             | 30    |                 | 30            | 50    | mA    | Word/Byte Program<br>in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)                                                                                                                                                                                                                                                                   |
|                  |                                                      |       |                 | 10             | 25    |                 | 30            | 45    | mA    | Word/Byte Program<br>in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V)                                                                                                                                                                                                                                                                  |



Table 20. DC Characteristics: Extended Temperature Operation (Continued)

|                   |                                                   |       |     | TBV-80  |      |     | TBV-80        |      |       |                                                                                                               |
|-------------------|---------------------------------------------------|-------|-----|---------|------|-----|---------------|------|-------|---------------------------------------------------------------------------------------------------------------|
| Symbol            | Parameter                                         | Notes | Vcc | = 3.3 ± | 0.3V | Vcc | = <b>5V</b> ± | 10%  | Units | Test Conditions                                                                                               |
|                   |                                                   |       | Min | Тур     | Max  | Min | Тур           | Max  |       |                                                                                                               |
| CCE               | V <sub>CC</sub> Erase<br>Current                  | 1,4   |     | 13      | 30   |     | 22            | 45   | mA    | Block Erase<br>in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)                                    |
|                   | ,                                                 |       |     | 10      | 25   |     | 18            | 40   | mA    | Block Erase<br>in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V)                                   |
| CCES              | V <sub>CC</sub> Erase<br>Suspend<br>Current       | 1,2   |     | 3       | 8.0  |     | 5             | 12.0 | mA    | CE# = V <sub>IH</sub><br>Block Erase Suspend<br>V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)                  |
| PPS               | V <sub>PP</sub> Standby<br>Current                | · 1   |     | ± 5     | ± 15 |     | ± 5           | ± 15 | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                             |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep<br>Power-down<br>Current     | 1     |     | 0.2     | 10   |     | 0.2           | 10   | μΑ    | RP# = GND ± 0.2V                                                                                              |
| I <sub>PPR</sub>  | V <sub>PP</sub> Read<br>Current                   | 1     |     | 50      | 200  |     | 50            | 200  | μΑ    | $V_{PP} > V_{CC}$                                                                                             |
| I <sub>PPW</sub>  | V <sub>PP</sub> Write<br>Current for<br>Word/Byte | 1,4   |     | 13      | 30   |     | 13            | 30   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)  |
|                   |                                                   |       |     | 8       | 25   |     | 8             | 25   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress<br>V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V) |
| IPPE              | V <sub>PP</sub> Erase<br>Current                  | 1,4   |     | 13      | 30   |     | 15            | 25   | mA    | V <sub>PP</sub> = V <sub>PPH</sub> Block Erase in Progress V <sub>PP</sub> = V <sub>PPH</sub> 1 (at 5V)       |
|                   |                                                   |       |     | 8       | 25   | · · | 10            | 20   | mA    | V <sub>PP</sub> = V <sub>PPH</sub> Block Erase in Progress V <sub>PP</sub> = V <sub>PPH</sub> 2 (at 12V)      |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase<br>Suspend<br>Current       | 1     |     | 50      | 200  |     | 50            | 200  | μΑ    | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspend<br>in Progress                                      |



Table 20. DC Characteristics: Extended Temperature Operation (Continued)

|                    |                                                     |       |                           | TBV-80         |                        |                           | TBV-80        |                        |       |                                                                                          |
|--------------------|-----------------------------------------------------|-------|---------------------------|----------------|------------------------|---------------------------|---------------|------------------------|-------|------------------------------------------------------------------------------------------|
| Symbol             | Parameter                                           | Notes | V <sub>CC</sub>           | = <b>3.3</b> ± | 0.3V                   | Vcc                       | = <b>5V</b> ± | 10%                    | Units | Test Conditions                                                                          |
|                    |                                                     |       | Min                       | Тур            | Max                    | Min                       | Тур           | Max                    |       |                                                                                          |
| I <sub>RP#</sub>   | RP# Boot<br>Block Unlock<br>Current                 | 1,4   |                           |                | 500                    |                           |               | 500                    | μΑ    | RP# = V <sub>HH</sub><br>V <sub>PP</sub> = 12V                                           |
| l <sub>ID</sub>    | A <sub>9</sub> Intelligent<br>Identifier<br>Current | 1,4   |                           |                | 500                    |                           |               | 500                    | μΑ    | $A_9 = V_{ID}$                                                                           |
| V <sub>ID</sub>    | A <sub>9</sub> Intelligent<br>Identifier<br>Voltage |       | 11.4                      |                | 12.6                   | 11.4                      |               | 12.6                   | ٧     |                                                                                          |
| V <sub>IL</sub>    | Input Low<br>Voltage                                |       | -0.5                      |                | 0.8                    | -0.5                      |               | 0.8                    | ٧     |                                                                                          |
| V <sub>IH</sub>    | Input High<br>Voltage                               |       | 2.0                       |                | V <sub>CC</sub> ± 0.5V | 2.0                       |               | V <sub>CC</sub> ± 0.5V | ٧     |                                                                                          |
| V <sub>OL</sub>    | Output Low<br>Voltage                               |       |                           |                | 0.45                   |                           | ,             | 0.45                   | ٧     | $V_{CC} = V_{CC}MIN$ $I_{OL} = 5.8 \text{ mA (5V)}$ $2 \text{ mA (3.3V)}$ $V_{PP} = 12V$ |
| V <sub>OH</sub> 1  | Output High<br>Voltage (TTL)                        |       | 2.4                       |                |                        | 2.4                       |               |                        | ٧     | $V_{CC} = V_{CC}MIN$ $I_{OH} = -2.5 \text{ mA}$                                          |
| V <sub>OH</sub> 2  | Output High<br>Voltage                              | -     | 0.85 ×<br>V <sub>CC</sub> |                |                        | 0.85 ×<br>V <sub>CC</sub> |               |                        | ٧     | $V_{CC} = V_{CC}MIN$ $I_{OH} = -2.5 \text{ mA}$                                          |
|                    | (CMOS)                                              |       | V <sub>CC</sub> -<br>0.4V |                |                        | V <sub>CC</sub> -<br>0.4V |               |                        |       | $V_{CC} = V_{CC}MIN$ $I_{OH} = -100 \mu A$                                               |
| V <sub>PPLK</sub>  | V <sub>PP</sub> Lock-<br>Out Voltage                | 3     | 0.0                       |                | 1.5                    | 0.0                       |               | 1.5                    | ٧     | Complete Write<br>Protection                                                             |
| V <sub>PPH</sub> 1 | V <sub>PP</sub> (Program/<br>Erase Operations)      |       | 4.5                       |                | 5.5                    | 4.5                       |               | 5.5                    | ٧     | V <sub>PP</sub> at 5V                                                                    |
| V <sub>PPH</sub> 2 | V <sub>PP</sub> (Program/<br>Erase Operations)      |       | 11.4                      |                | 12.6                   | 11.4                      |               | 12.6                   | V     | V <sub>PP</sub> at 12V                                                                   |



**Table 20. DC Characteristics: Extended Temperature Operation (Continued)** 

|                  | Parameter                                      |       |      | TBV-80         |      |      | TBV-80        |      |       |                                                    |
|------------------|------------------------------------------------|-------|------|----------------|------|------|---------------|------|-------|----------------------------------------------------|
| Symbol           |                                                | Notes | Vcc  | = <b>3.3</b> ± | 0.3V | Vcc  | = <b>5V</b> ± | 10%  | Units | Test Conditions                                    |
|                  |                                                |       | Min  | Тур            | Max  | Min  | Тур           | Max  |       |                                                    |
| V <sub>LKO</sub> | V <sub>CC</sub><br>Erase/Write<br>Lock Voltage | 10    | 2.0  |                |      | 2.0  |               |      | ٧     | V <sub>PP</sub> = 12V                              |
| V <sub>HH</sub>  | RP# Unlock<br>Voltage                          |       | 11.4 |                | 12.6 | 11.4 |               | 12.6 | ٧     | Boot Block<br>Write/Erase<br>V <sub>PP</sub> = 12V |

- All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, T = 25°C. These currents are valid for all product versions (packages and speeds).
- 2. I<sub>CCES</sub> is specified with the device de-selected. If the device is read while in erase suspend mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCR</sub>.
- Block erases and word/byte writes are inhibited when V<sub>PP</sub> = V<sub>PPLK</sub>, and not guaranteed in the range between V<sub>PPH</sub>1 and V<sub>PPLK</sub>.
- 4. Sampled, not 100% tested.
- 5. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA typical, in static operation.
- 6. CMOS Inputs are either  $V_{CC}$   $\pm$  0.2V or GND  $\pm$  0.2V. TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .
- 7. For the 28F002 address pin  $A_{10}$  follows the  $C_{OUT}$  capacitance numbers.
- 8. For all BV parts,  $V_{LKO} = 2.0V$  for both 3.3V and 5.0V operations.





Figure 23. 3.3V Inputs and Measurement Points



Figure 24. 3.3V Standard Test Configuration



Figure 25. 5V Inputs and Measurement Points



Figure 26. 5V Standard Test Configuration



## 6.3 AC Characteristics

Table 21. AC Characteristics: Read Only Operations<sup>(1)</sup> (Extended Temperature)

|                                        |                                                                          |      | TBV-80         |             | TBV-80        |          |       |
|----------------------------------------|--------------------------------------------------------------------------|------|----------------|-------------|---------------|----------|-------|
| Symbol                                 | Parameter                                                                | Note | $V_{CC} = 3.3$ | 3 ± 0.3V(6) | $V_{CC} = 5V$ | ± 10%(5) | Units |
|                                        |                                                                          |      | Min            | Max         | Min           | Max      |       |
| t <sub>AVAV</sub>                      | Read Cycle Time                                                          |      | 110            |             | 80            |          | ns    |
| t <sub>AVQV</sub>                      | Address to Output Delay                                                  |      |                | 110         |               | - 80     | ns    |
| t <sub>ELQV</sub>                      | CE# to Output Delay                                                      | 2    |                | 110         |               | 80       | ns    |
| t <sub>PHQV</sub>                      | RP# to Output Delay                                                      |      |                | 800         |               | 450      | ns    |
| t <sub>GLQV</sub>                      | OE# to Output Delay                                                      | 2    |                | 65          |               | 40       | ns    |
| t <sub>ELQX</sub>                      | CE# to Output in Low Z                                                   | 3    | 0              |             | 0             |          | ns    |
| t <sub>EHQZ</sub>                      | CE# to Output in High Z                                                  | 3    |                | 55          |               | 30       | ns    |
| t <sub>GLQX</sub>                      | OE# to Output in Low Z                                                   | 3    | 0              |             | 0             |          | ns    |
| t <sub>GHQZ</sub>                      | OE# to Output in High Z                                                  | 3    |                | 45          |               | 30       | ns    |
| t <sub>OH</sub>                        | Output Hold from Address<br>CE#, or OE# change<br>whichever occurs first | 3    | <b>0</b>       |             | 0             |          | ns    |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> | CE# Low to BYTE# High or Low                                             | 3    |                | 7           |               | 5        | ns    |
| t <sub>AVFL</sub>                      | Address to BYTE# High or Low                                             | 3    |                | 7           |               | 5        | ns    |
| t <sub>FLQV</sub><br>t <sub>FHQV</sub> | BYTE# to Output Delay                                                    | 3,4  |                | 110         |               | 80       | ns    |
| t <sub>FLQZ</sub>                      | BYTE# Low to Output in High Z                                            | 3    |                | 45          |               | 30       | ns    |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to  $t_{CE} t_{OE}$  after the falling edge of CE# without impact on  $t_{CE}$ .
- 3. Sampled, but not 100% tested.
- 4. t<sub>FLQV</sub>, BYTE# switching low to valid output delay will be equal to t<sub>AVQV</sub>, measured from the time DQ<sub>15</sub>/A<sub>-1</sub> becomes
- 5. See 5V Standard Test Configuration.
- 6. See 3.3V Standard Test Configuration.



Table 22. AC Characteristics: WE #-Controlled Write Operations(1) (Extended Temperature)

| Symbol             | Parameter                                  |       | TB                          | V-80 | TBV-80                        |     |       |
|--------------------|--------------------------------------------|-------|-----------------------------|------|-------------------------------|-----|-------|
|                    |                                            | Notes | $V_{CC} = 3.3 \pm 0.3V(11)$ |      | $V_{CC} = 5V \pm 10\%^{(12)}$ |     | Units |
|                    |                                            |       | Min                         | Max  | Min                           | Max | ]     |
| t <sub>AVAV</sub>  | Write Cycle Time                           |       | 110                         |      | 80                            |     | ns    |
| t <sub>PHWL</sub>  | RP# High Recovery to WE#<br>Going Low      |       | 800                         | ,    | 450<br>,                      |     | ns    |
| t <sub>ELWL</sub>  | CE# Setup to WE# Going Low                 |       | 0                           |      | 0                             |     | ns    |
| t <sub>PHHWH</sub> | Boot Block Lock Setup to WE# Going High    | 6,8   | 200                         |      | 100                           |     | ns    |
| t <sub>VPWH</sub>  | V <sub>PP</sub> Setup to WE# Going<br>High | 5,8   | 200                         |      | 100                           |     | ns    |
| t <sub>AVWH</sub>  | Address Setup to WE# Going High            | 3     | 90                          |      | 60                            |     | ns    |
| t <sub>DVWH</sub>  | Data Setup to WE# Going High               | 4     | 90                          |      | 60                            |     | ns    |
| t <sub>WLWH</sub>  | WE# Pulse Width                            |       | 90                          |      | 60                            |     | ns    |
| twHDX              | Data Hold Time from WE#<br>High            | 4     | 0                           |      | 0                             |     | ns    |
| t <sub>WHAX</sub>  | Address Hold Time from WE#<br>High         | 3     | 10                          | ,    | 10                            |     | ns    |
| t <sub>WHEH</sub>  | CE# Hold Time from WE#<br>High             |       | 0                           |      | - 0                           |     | ns    |
| twhwL              | WE# Pulse Width High                       | ,     | 20                          |      | 20                            |     | ns    |
| t <sub>WHQV1</sub> | Duration of Word/Byte Write<br>Operation   | 2,5   | . 6                         |      | 7.                            |     | μs    |
| t <sub>WHQV2</sub> | Duration of Erase Operation (Boot)         | 2,5,6 | 0.3                         |      | 0.4                           |     | S     |
| t <sub>WHQV3</sub> | Duration of Erase Operation (Parameter)    | 2,5   | 0.3                         |      | 0.4                           |     | s     |
| t <sub>WHQV4</sub> | Duration of Erase Operation (Main)         | 2,5   | 0.6                         |      | 0.7                           |     | S     |

# Table 22. AC Characteristics: WE#-Controlled Write Operations(1) (Extended Temperature) (Continued)

| Symbol            | Parameter                                  |       | TB\                          | TBV-80 TBV-80 |                             |     |       |
|-------------------|--------------------------------------------|-------|------------------------------|---------------|-----------------------------|-----|-------|
|                   |                                            | Notes | $V_{CC} = 3.3 \pm 0.3 V(11)$ |               | $V_{CC} = 5V \pm 10\%$ (12) |     | Units |
|                   |                                            |       | Min                          | Max           | Min                         | Max |       |
| t <sub>QWL</sub>  | V <sub>PP</sub> Hold from Valid SRD        | 5,8   | 0                            |               | 0                           |     | ns    |
| t <sub>QVPH</sub> | RP# V <sub>HH</sub> Hold from Valid<br>SRD | 6,8   | 0                            |               | 0                           |     | ns    |
| t <sub>PHBR</sub> | Boot-Block Relock Delay                    | 7,8   |                              | 200           |                             | 100 | ns    |

- Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during read mode.
- The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- Refer to command definition table for valid D<sub>IN</sub>.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7 = 1)
- For boot block program/erase, RP# should be held at V<sub>HH</sub> or WP# should be held at V<sub>IH</sub> until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the boot block.
- 8. Sampled, but not 100% tested.
- 9. V<sub>PP</sub> at 5.0V.
- 10. V<sub>PP</sub> at 12.0V.
- 11. See 3.3V Standard Test Configuration.
- 12. See 5V Standard Test Configuration.



Table 23. AC Characteristics: CE #-Controlled Write Operations(1,13)

| Symbol             | Parameter                                  |       | TBV-80                       |     | TBV-80                        |     | Units |
|--------------------|--------------------------------------------|-------|------------------------------|-----|-------------------------------|-----|-------|
|                    |                                            | Notes | $V_{CC} = 3.3 \pm 0.3 V(11)$ |     | $V_{CC} = 5V \pm 10\%^{(12)}$ |     |       |
|                    |                                            |       | Min                          | Max | Min                           | Max |       |
| t <sub>AVAV</sub>  | Write Cycle Time                           |       | 110                          |     | 80                            |     | ns    |
| t <sub>PHEL</sub>  | RP# High Recovery to CE#<br>Going Low      |       | 800                          | ,   | 450                           |     | ns    |
| t <sub>WLEL</sub>  | WE# Setup to CE# Going Low                 |       | 0                            |     | 0                             |     | ns    |
| t <sub>PHHEH</sub> | Boot Block Lock Setup to CE# Going High    | 6,8   | 200                          |     | 100                           |     | ns    |
| t <sub>VPEH</sub>  | V <sub>PP</sub> Setup to CE# Going High    | 5,8   | 200                          |     | 100                           |     | ns    |
| t <sub>AVEH</sub>  | Address Setup to CE# Going High            |       | 90                           |     | 60                            |     | ns    |
| t <sub>DVEH</sub>  | Data Setup to CE# Going High               | 3     | 90                           |     | 60                            |     | ns    |
| tELEH              | CE# Pulse Width                            | 4     | 90                           |     | 60                            |     | ns    |
| t <sub>EHDX</sub>  | Data Hold Time from CE#<br>High            |       | 0                            |     | 0                             |     | ns    |
| t <sub>EHAX</sub>  | Address Hold Time from CE#<br>High         | 4     | 10                           |     | 10                            |     | ns    |
| t <sub>EHWH</sub>  | WE# Hold Time from CE#<br>High             | 3     | 0                            |     | 0                             | ·   | ns    |
| tEHEL              | CE# Pulse Width High                       |       | <sup>-</sup> 20              |     | 20                            |     | ns    |
| t <sub>EHQV1</sub> | Duration of Word/Byte Write Operation      | 2,5   | 6                            |     | 7                             |     | μs    |
| t <sub>EHQV2</sub> | Duration of Erase Operation (Boot)         | 2,5,6 | 0.3                          |     | 0.4                           | :   | s     |
| t <sub>EHQV3</sub> | Duration of Erase Operation (Parameter)    | 2,5   | 0.3                          |     | 0.4                           |     | s     |
| t <sub>EHQV4</sub> | Duration of Erase Operation (Main)         | 2,5   | 0.6                          |     | 0.7                           |     | s     |
| t <sub>QWL</sub>   | V <sub>PP</sub> Hold from Valid SRD        | 5,8   | 0                            |     | 0 -                           |     | ns    |
| tQVPH              | RP# V <sub>HH</sub> Hold from Valid<br>SRD | 6,8   | 0                            |     | 0                             |     | ns    |
| t <sub>PHBR</sub>  | Boot-Block Relock Delay                    | 7,8   |                              | 200 |                               | 100 | ns    |

#### NOTES:

See WE# Controlled Write Operations for notes 1 through 12.

<sup>13.</sup> Chip-Enable controlled writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.



Table 24. Extended Temperature Operations—Erase and Program Timings

|                                   | V <sub>PP</sub> = 5 | V ± 10%                       | V <sub>PP</sub> = 12V ± 5%      |                               |       |
|-----------------------------------|---------------------|-------------------------------|---------------------------------|-------------------------------|-------|
| Parameter                         | V <sub>CC</sub> =   | V <sub>CC</sub> =<br>5V ± 10% | V <sub>CC</sub> =<br>3.3 ± 0.3V | V <sub>CC</sub> =<br>5V ± 10% | Units |
|                                   | Тур                 | Тур                           | Тур                             | Тур                           |       |
| Boot/Parameter Block Erase Time   | 0.84                | 0.8                           | 0.44                            | 0.34                          | s     |
| Main Block Erase Time             | 2.4                 | 1.9                           | 1.3                             | 1.1                           | s     |
| Main Block Write Time (Byte Mode) | 1.7                 | 1.4                           | 1.6                             | 1.2                           | s     |
| Main Block Write Time (Word Mode) | 1.1                 | 0.9                           | 0.8                             | 0.6                           | s     |
| Byte Write Time                   | 10                  | 10                            | 8                               | 8                             | μs    |
| Word Write Time                   | 13                  | 13                            | 8                               | 8                             | μs    |

- 1. All numbers are sampled, not 100% tested.
- 2. Contact your Intel representative for information regarding maximum Byte/Word Write specifications.



#### 7.0 ADDITIONAL INFORMATION

### 7.1 Ordering Information



**Table 25. Summary of Line Items** 

| Name     | V <sub>CC</sub> |    | V <sub>PP</sub> |     | 40-<br>Lead<br>TSOP | 44-<br>Lead<br>PSOP | 48-<br>Lead<br>TSOP | 56-<br>Lead<br>TSOP | 0°-+70°C | -40°-+85°C |  |
|----------|-----------------|----|-----------------|-----|---------------------|---------------------|---------------------|---------------------|----------|------------|--|
|          | 3.3V            | 5V | 5V              | 12V |                     |                     |                     |                     |          |            |  |
| 28F200BV | 1               | "  |                 | ~   |                     | <u> </u>            | <u> </u>            | <i>u</i>            | ~        |            |  |
| 28F002BV | 1               | "  | <b>"</b>        | 1   | -                   |                     |                     |                     | <i>u</i> | -          |  |



## 2-MBIT SmartVoltage BOOT BLOCK FAMILY

## 7.2 References

| Order Number | Document                                                                          |
|--------------|-----------------------------------------------------------------------------------|
| 292130       | AB-57 "Boot Block Architecture for Safe Firmware Updates"                         |
| 292154       | AB-60 "2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family"                    |
| 292098       | AP-363 "Extended Flash BIOS Concepts for Portable Computers"                      |
| 292148       | AP-604 "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM" |
| 290448       | 28F002/200BX-T/B 2-Mbit Boot Block Flash Memory Datasheet                         |
| 290449       | 28F002/200BL-T/B 2-Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290450       | 28F004/400BL-T/B 4-Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290451       | 28F004/400BX-T/B 4-Mbit Boot Block Flash Memory Datasheet                         |
| 290530       | 2-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290539       | 8-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |

## 7.3 Revision History

|   |      | • • • • • • • •              |    |
|---|------|------------------------------|----|
| 1 |      |                              | ٦  |
|   | -001 | Initial release of datasheet | ١  |
|   |      | initial rologod of dataonoot | -1 |

intel

## 28F400BX-T/B, 28F004BX-T/B 4 MBIT (256K x16, 512K x8) BOOT BLOCK FLASH MEMORY FAMILY

- **■** x8/x16 Input/Output Architecture
  - -- 28F400BX-T, 28F400BX-B
  - For High Performance and High Integration 16-bit and 32-bit CPUs
- x8-only Input/Output Architecture
  - -- 28F004BX-T, 28F004BX-B
  - For Space Constrained 8-bit Applications
- Upgradeable to Intel's Smart Voltage Products
- Optimized High Density Blocked Architecture
  - One 16-KB Protected Boot Block
  - Two 8-KB Parameter Blocks
  - One 96-KB Main Block
  - Three 128-KB Main Blocks
  - Top or Bottom Boot Locations
- Extended Cycling Capability
   100,000 Block Erase Cycles
- Automated Word/Byte Write and Block Erase
  - Command User Interface
  - Status Registers
  - Erase Suspend Capability
- **SRAM-Compatible Write Interface**
- Automatic Power Savings Feature
  - 1 mA Typical I<sub>CC</sub> Active Current in Static Operation

- Very High-Performance Read
  - 60/80/120 ns Maximum Access Time
  - 30/40/40 ns Maximum Output Enable Time
- Low Power Consumption
   20 mA Typical Active Read Current
- Reset/Deep Power-Down Input
  - 0.2 μA I<sub>CC</sub> Typical
  - Acts as Reset for Boot Operations
- Extended Temperature Operation — -40°C to +85°C
- **■** Write Protection for Boot Block
- Hardware Data Protection Feature
   Erase/Write Lockout During Power Transitions
- Industry Standard Surface Mount Packaging
  - 28F400BX: JEDEC ROM Compatible 44-Lead PSOP 56-Lead TSOP
  - 28F004BX: 40-Lead TSOP
- 12V Word/Byte Write and Block Erase
  - $-V_{PP} = 12V \pm 5\%$  Standard
  - $-V_{pp} = 12V \pm 10\%$  Option
- ETOX III Flash Technology — 5V Read



Intel's 4-Mbit Flash Memory Family is an extension of the Boot Block Architecture which includes block-selective erasure, automated write and erase operations and standard microprocessor interface. The 4-Mbit Flash Memory Family enhances the Boot Block Architecture by adding more density and blocks, x8/x16 input/out-put control, very high speed, low power, an industry standard ROM compatible pinout and surface mount packaging. The 4-Mbit flash family is an easy upgrade from Intel's 2-Mbit Boot Block Flash Memory Family.

The Intel 28F400BX-T/B are 16-bit wide flash memory offerings. These high density flash memories provide user selectable bus operation for either 8-bit or 16-bit applications. The 28F400BX-T and 28F400BX-B are 4,194,304-bit non-volatile memories organized as either 524,288 bytes or 262,144 words of information. They are offered in 44-Lead plastic SOP and 56-Lead TSOP packages. The x8/x16 pinout conforms to the industry standard ROM/EPROM pinout.

The Intel 28F004BX-T/B are 8-bit wide flash memories with 4,194,304 bits organized as 524,288 bytes of information. They are offered in a 40-Lead TSOP package, which is ideal for space-constrained portable systems.

These devices use an integrated Command User Interface (CUI) and Write State Machine (WSM) for simplified word/byte write and block erasure. The 28F400BX-T/28F004BX-T provide block locations compatible with Intel's MCS-186 family, 80286, i386<sup>TM</sup>, i486<sup>TM</sup>, i860<sup>TM</sup> and 80960CA microprocessors. The 28F400BX-B/28F004BX-B provide compatibility with Intel's 80960KX and 80960SX families as well as other embedded microprocessors.

The boot block includes a data protection feature to protect the boot code in critical applications. With a maximum access time of 60 ns, these 4-Mbit flash devices are very high performance memories which interface at zero-wait-state to a wide range of microprocessors and microcontrollers. A deep power-down mode lowers the total  $V_{CC}$  power consumption to 1  $\mu$ W. This is critical in handheld battery powered systems. For very low power applications using a 3.3V supply, refer to the Intel 28F400BL-T/B, 28F004BL-T/B 4-Mbit Boot Block Flash Memory Family datasheet.

Manufactured on Intel's 0.8 micron ETOX III process, the 4-Mbit flash memory family provides world class quality, reliability and cost-effectiveness at the 4-Mbit density level.



#### 1.0 PRODUCT FAMILY OVERVIEW

Throughout this datasheet the 28F400BX refers to both the 28F400BX-T and 28F400BX-B devices and 28F004BX refers to both the 28F004BX-T and 28F004BX-B devices. The 4-Mbit flash memory family refers to both the 28F400BX and 28F004BX products. This datasheet comprises the specifications for four separate products in the 4-Mbit flash memory family. Section 1 provides an overview of the 4-Mbit flash memory family including applications, pinouts and pin descriptions. Sections 2 and 3 describe in detail the specific memory organizations for the 28F400BX and 28F004BX products respectively. Section 4 combines a description of the family's principles of operations. Finally Section 5 describes the family's operating specifications.

#### Product Family

| X8/X16 Products | X8-Only Products |
|-----------------|------------------|
| 28F400BX-T      | 28F004BX-T       |
| 28F400BX-B      | 28F004BX-B       |

### 1.1 Designing for Upgrade to SmartVoltage Products

Today's high volume boot block products are upgradable to Intel's SmartVoltage boot block products that provide program and erase operation at 5V or 12V  $V_{PP}$  and read operation at 3V or 5V  $V_{CC}$ . Intel's SmartVoltage boot block products provide the following enhancements to the boot block products described in this data sheet:

- DU pin is replaced by WP# to provide a means to lock and unlock the boot block with logic signals.
- 5V Program/Erase operation uses proven program and erase techniques with 5V ±10% applied to Vpp.
- 3. Enhanced circuits optimize performance at 3.3V Vcc.

Refer to the 2, 4 or 8 Mbit SmartVoltage Boot Block Flash Memory Data Sheets for complete specifications.

When you design with 12V V<sub>PP</sub> boot block products you should provide the capability in your board design to upgrade to SmartVoltage products.

Follow these guidelines to ensure compatibility:

- Connect DU (WP# on SmartVoltage products) to a control signal or to V<sub>CC</sub> or GND.
- If adding a switch on V<sub>PP</sub> for write protection, switch to GND for complete write protection.
- Allow for connecting 5V to V<sub>PP</sub> and disconnect 12V from the V<sub>PP</sub> line, if desired.

#### 1.2 Main Features

The 28F400BX/28F004BX boot block flash memory family is a very high performance 4-Mbit (4,194,304 bit) memory family organized as either 256 KWords (262,144 words) of 16 bits each or 512 Kbytes (524,288 bytes) of 8 bits each.

Seven Separately Erasable Blocks including a Hardware-Lockable boot block (16,384 Bytes), Two parameter blocks (8,192 Bytes each) and Four main blocks (1 block of 98,304 Bytes and 3 blocks of 131,072 Bytes) are included on the 4-Mbit family. An erase operation erases one of the main blocks in typically 2.4 seconds and the boot or parameter blocks in typically 1.0 seconds independent of the remaining blocks. Each block can be independently erased and programmed 100,000 times.

The Boot Block is located at either the top (28F400BX-T, 28F004BX-T) orthe bottom (28F400BX-B, 28F004BX-B) of the address map in order to accommodate different microprocessor protocols for boot code location. The hardware lockable boot block provides the most secure code storage. The boot block is intended to store the kernel code required for booting-up a system. When the RP# pin is between 11.4V and 12.6V the boot block is unlocked and program and erase operations can be performed. When the RP# pin is at or below 6.5V the boot block is locked and program and erase operations to the boot block are ignored.

The 28F400BX products are available in the ROM/EPROM compatible pinout and housed in the 44-Lead PSOP (Plastic Small Outline) package and the 56-Lead TSOP (Thin Small Outline, 1.2mm thick) package as shown in Figures 3 and 4. The 28F004BX products are available in the 40-Lead TSOP (1.2mm thick) package as shown in Figure 5.

The Command User Interface (CUI) serves as the interface between the microprocessor or microcontroller and the internal operation of the 28F400BX and 28F004BX flash memory products.



Program and Erase Automation allows program and erase operations to be executed using a two-write command sequence to the CUI. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verifications, thereby unburdening the microprocessor or microcontroller. Writing of memory data is performed in word or byte increments for the 28F400BX family and in byte increments for the 28F004BX family typically within 9 μs which is a 100% improvement over current flash memory products.

The **Status Register (SR)** indicates the status of the WSM and whether the WSM successfully completed the desired program or erase operation.

Maximum Access Time of 60 ns (TACC) is achieved over the commercial temperature range (0°C to 70°C), 5% V<sub>CC</sub> supply voltage range (4.75V to 5.25V) and 30 pF output load. Maximum Access Time of 70 ns (TACC) is achieved over the commercial temperature range, 10% V<sub>CC</sub> supply range (4.5V to 5.5V) and 100 pF output load.

lpp maximum Program current is 40 mA for  $\times$ 16 operation and 30 mA for  $\times$ 8 operation. Ipp Erase current is 30 mA maximum. Vpp erase and programming voltage is 11.4V to 12.6V (Vpp = 12V  $\pm$  5%) under all operating conditions. As an option, Vpp can also vary between 10.8V to 13.2V (Vpp = 12V  $\pm$  10%) with a guaranteed number of 100 block erase cycles.

Typical I<sub>CC</sub> Active Current of 25 mA is achieved for the X16 products (28F400BX). Typical I<sub>CC</sub> Active Current of 20 mA is achieved for the X8 products (28F400BX, 28F004BX). Refer to the I<sub>CC</sub> active current derating curves in this datasheet.

The 4-Mbit boot block flash memory family is also designed with an Automatic Power Savings (APS) feature to minimize system battery current drain and allows for very low power designs. Once the device is accessed to read array data, APS mode will immediately put the memory in static mode of operation where  $I_{\rm CC}$  active current is typically 1 mA until the next read is initiated.

When the CE# and RP# pins are at  $V_{CC}$  and the BYTE# pin (28F400BX-only) is at either  $V_{CC}$  or GND the CMOS Standby mode is enabled where  $I_{CC}$  is typically 50  $\mu$ A.

A Deep Power-Down Mode is enabled when the RP# pin is at ground minimizing power consumption and providing write protection during power-up conditions. Icc current during deep power-down mode is 0.20 µA typical. An initial maximum access time or Reset Time of 300 ns is required from RP# switching until outputs are valid. Equivalently, the device has a maximum wake-up time of 215 ns until writes to the Command User Interface are recognized. When RP# is at ground the WSM is reset, the Status Register is cleared and the entire device is protected from being written to. This feature prevents data corruption and protects the code stored in the device during system reset. The system Reset pin can be tied to RP# to reset the memory to normal read mode upon activation of the Reset pin. With on-chip program/erase automation in the 4-Mbit family and the RP# functionality for data protection, when the CPU is reset and even if a program or erase command is issued, the device will not recognize any operation until RP# returns to its normal state.

For the 28F400BX, Byte-wide or Word-wide Input/Output Control is possible by controlling the BYTE# pin. When the BYTE# pin is at a logic low the device is in the byte-wide mode (x8) and data is read and written through DQ[0:7]. During the byte-wide mode, DQ[8:14] are tri-stated and DQ15/A-1 becomes the lowest order address pin. When the BYTE# pin is at a logic high the device is in the word-wide mode (x16) and data is read and written through DQ[0:15].



### 1.3 Applications

The 4-Mbit boot block flash memory family combines high density, high performance, cost-effective flash memories with blocking and hardware protection capabilities. Its flexibility and versatility will reduce costs throughout the product life cycle. Flash memory is ideal for Just-In-Time production flow, reducing system inventory and costs, and eliminating component handling during the production phase.

During the product life cycle, when code updates or feature enhancements become necessary, flash memory will reduce the update costs by allowing either a user-performed code change via floppy disk or a remote code change via a serial link. The 4-Mbit boot block flash memory family provides full function, blocked flash memories suitable for a wide range of applications. These applications include Extended PC BIOS and ROM-able applications storage, Digital Cellular Phone program and data storage, Telecommunication boot/firmware, Printer firmware/font storage and various other embedded applications where both program and data storage are required.

Reprogrammable systems such as personal computers, are ideal applications for the 4-Mbit flash memory products. Portable and handheld personal computer applications are becoming more complex with the addition of power management software to take advantage of the latest microprocessor technology, the availability of ROM-based application software, pen tablet code for electronic hand writing, and diagnostic code. Figure 1 shows an example of a 28F400BX-T application.

This increase in software sophistication augments the probability that a code update will be required after the PC is shipped. The 4-Mbit flash memory products provide an inexpensive update solution for the notebook and handheld personal computers while extending their product lifetime. Furthermore, the 4-Mbit flash memory products' power-down mode provides added flexibility for these battery-operated portable designs which require operation at very low power levels.

The 4-Mbit flash memory products also provide excellent design solutions for Digital Cellular Phone and Telecommunication switching applications requiring high performance, high density storage capability coupled with modular software designs, and a small form factor package (X8-only bus). The 4-Mbit's blocking scheme allows for an easy segmentation of the embedded code with; 16 Kbytes of Hardware-Protected Boot code, 4 Main Blocks of program code and 2 Parameter Blocks of 8 Kbytes each for frequently updatable data storage and diagnostic messages (e.g., phone numbers, authorization codes). Figure 2 is an example of such an application with the 28F004BX-T.

These are a few actual examples of the wide range of applications for the 4-Mbit Boot Block flash memory family which enable system designers achieve the best possible product design. Only your imagination limits the applicability of such a versatile product family.





Figure 1. 28F400BX interface to Intel386™EX Embedded Processor



Figure 2. 28F004BX Interface to INTEL 80C188EB 8-Bit Embedded Processor



#### 1.4 Pinouts

The 28F400BX 44-Lead PSOP pinout follows the industry standard ROM/EPROM pinout as shown in Figure 3. Furthermore, the 28F400BX 56-Lead TSOP pinout shown in Figure 4 provides density upgrades to future higher density boot block memories.

The 28F004BX 40-Lead TSOP pinout shown in Figure 5 is 100% compatible and provides a density upgrade for the 2-Mbit Boot Block flash memory or the 28F002BX.



Figure 3. PSOP Lead Configuration for x8/x16 28F400BX





Figure 4. TSOP Lead Configuration for x8/x16 28F400BX



Figure 5. TSOP Lead Configuration for x8 28F004BX



## 1.5 28F400BX Pin Descriptions

| Symbol                             | Type  | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>17</sub>    | 1     | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| A <sub>9</sub>                     | . 1   | <b>ADDRESS INPUT:</b> When $A_9$ is at 12V the signature mode is accessed. During this mode $A_0$ decodes between the manufacturer and device ID's. When BYTE# is at a logic low only the lower byte of the signatures are read. $DQ_{15}/A_{-1}$ is a don't care in the signature mode when BYTE# is low.                                                                                                                                                                                                                                                                 |
| DQ <sub>0</sub> –DQ <sub>7</sub> . | 1/0   | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the command user interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array, Intelligent Identifier and Status Register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled.                                                                                                                                                                      |
| DQ <sub>8</sub> -DQ <sub>15</sub>  | 1/0   | <b>DATA-INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a program command. Data is internally latched during the write and program cycles. Outputs array data. The data pins float to tri-state when the chip is deselected or the outputs are disabled as in the byte-wide mode (BYTE# = "0"). In the byte-wide mode DQ $_{15}/A_{-1}$ becomes the lowest order address for data output on DQ $_{0}$ -DQ $_{7}$ .                                                                                                                            |
| CE#                                |       | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                                                                                                                                                                                               |
| RP#                                | -     | RESET/DEEP POWER-DOWN: Provides three-state control. Puts the device in deep power-down mode. Locks the boot block from program/erase.  When RP# is at logic high level and equals 6.5V maximum the boot block is locked and                                                                                                                                                                                                                                                                                                                                               |
|                                    |       | cannot be programmed or erased.  When RP# = 11.4V minimum the boot block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                    |       | When RP# is at a logic low level the boot block is locked, the deep power-down mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions.  When RP# transitions from logic low to logic high the flash memory enters the read-array                                                                                                                                                                                                                                         |
|                                    |       | mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| OE#                                | l<br> | OUTPUT ENABLE: Gates the device's outputs through the data buffers during a read cycle.  OE# is active low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| WE#                                | 1     | <b>WRITE ENABLE:</b> Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                                                                                                                                                                      |
| BYTE#                              | 1     | BYTE # ENABLE: Controls whether the device operates in the byte-wide mode (x8) or the word-wide mode (x16). BYTE # pin must be controlled at CMOS levels to meet 100A CMOS current in the standby mode. BYTE # = "0" enables the byte-wide mode, where data is read and programmed on DQ $_0$ -DQ $_7$ and DQ $_{15}$ /A $_1$ becomes the lowest order address that decodes between the upper and lower byte. DQ $_8$ -DQ $_14$ are tri-stated during the byte-wide mode. BYTE # = "1" enables the word-wide mode where data is read and programmed on DQ $_0$ -DQ $_15$ . |
| V <sub>PP</sub>                    |       | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.  Note: V <sub>PP</sub> < V <sub>PPLMAX</sub> memory contents cannot be altered.                                                                                                                                                                                                                                                                                                                                                                                             |
| V <sub>CC</sub>                    |       | DEVICE POWER SUPPLY (5V $\pm$ 10%, 5V $\pm$ 5%)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| GND                                | -     | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| NC                                 |       | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DU                                 |       | DON'T USE PIN: Pin should not be connected to anything.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |



## 1.6 28F004BX Pin Descriptions

| Symbol                           | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>18</sub>  | l    | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                           |
| A <sub>9</sub>                   | l    | <b>ADDRESS INPUT:</b> When $A_9$ is at 12V the signature mode is accessed. During this mode $A_0$ decodes between the manufacturer and device ID's.                                                                                                                                                                                                                                                   |
| DQ <sub>0</sub> -DQ <sub>7</sub> | 1/0  | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the command user interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array, Intelligent Identifier and status register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled. |
| CE#                              | ı    | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                          |
| RP#                              | ı    | RESET/DEEP POWERDOWN: Provides Three-State control. Puts the device in deep power-down mode. Locks the Boot Block from program/erase.                                                                                                                                                                                                                                                                 |
|                                  |      | When RP# is at logic high level and equals 6.5V maximum the Boot Block is locked and cannot be programmed or erased.                                                                                                                                                                                                                                                                                  |
|                                  |      | When RP# = 11.4V minimum the Boot Block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                  |
|                                  |      | When RP# is at a logic low level the Boot Block is locked, the deep power-down mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions. When RP# transitions from logic low to logic high, the flash memory enters the read-array mode.                                                              |
| OE#                              | ı    | OUTPUT ENABLE: Gates the device's outputs through the data buffers during a read cycle. OE # is active low.                                                                                                                                                                                                                                                                                           |
| WE#                              | I    | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE # is active low. Addresses and data are latched on the rising edge of the WE # pulse.                                                                                                                                                                                                                                      |
| V <sub>PP</sub>                  |      | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.                                                                                                                                                                                                                                                                                                        |
|                                  |      | NOTE: V <sub>PP</sub> < V <sub>PPLMAX</sub> memory contents cannot be altered.                                                                                                                                                                                                                                                                                                                        |
| V <sub>CC</sub>                  |      | DEVICE POWER SUPPLY (5V $\pm$ 10%, 5V $\pm$ 5%)                                                                                                                                                                                                                                                                                                                                                       |
| GND                              |      | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                                                                                   |
| NC                               |      | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                       |
| DU                               |      | DON'T USE PIN: Pin should not be connected to anything.                                                                                                                                                                                                                                                                                                                                               |



Figure 6. 28F400BX Word/Byte Block Diagram



## 2.1 28F400BX Memory Organization

#### 2.1.1 BLOCKING

The 28F400BX uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirm commands are written to the CUI. The 28F400BX is a random read/write memory, only erasure is performed by block.

## 2.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being written or erased when RP# is not at 12V. The boot block can be erased and written when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F400BX-T and 28F400BX-B.

#### 2.1.1.2 Parameter Block Operation

The 28F400BX has 2 parameter blocks (8-Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. The parameter blocks provide for more efficient memory utilization when dealing with parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F400BX-T and 28F400BX-B.

#### 2.1.1.3 Main Block Operation

Four main blocks of memory exist on the 28F400BX (3 x 128-Kbyte blocks and 1 x 96-Kbyte blocks). See the following section on Block Memory Map for the address location of these blocks for the 28F400BX-T and 28F400BX-B products.

#### 2.1.2 BLOCK MEMORY MAP

Two versions of the 28F400BX product exist to support two different memory maps of the array blocks in order to accommodate different microprocessor protocols for boot code location. The 28F400BX-T memory map is inverted from the 28F400BX-B memory map.

#### 2.1.2.1. 28F400BX-B Memory Map

The 28F400BX-B device has the 16-Kbyte boot block located from 00000H to 01FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F400BX-B the first 8-Kbyte parameter block resides in memory space from 02000H to 02FFFH. The second 8-Kbyte parameter block resides in memory space from 03000H to 03FFFH. The 96-Kbyte main block resides in memory space from 04000H to 0FFFFH. The three 128-Kbyte main block resides in memory space from 10000H to 1FFFFH, 20000H to 2FFFFH and 30000H to 3FFFFH (word locations). See Figure 7.



Figure 7. 28F400BX-B Memory Map



#### 2.1.2.2 28F400BX-T Memory Map

The 28F400BX-T device has the 16-Kbyte boot block located from 3E000H to 3FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F400BX-T the first 8-Kbyte parameter block resides in memory space from 3D000H to 3DFFFH. The second 8-Kbyte parameter block resides in memory space from 3C000H to 3CFFFH. The 96-Kbyte main block resides in memory space from 30000H to 3BFFFH. The three 128-Kbyte main blocks reside in memory space from 20000H to 2FFFFH, 10000H to 1FFFFH and 00000H to 0FFFFH as shown below in Figure 8.



Figure 8. 28F400BX-T Memory Map



## 3.0 28F004BX PRODUCT DESCRIPTION



Figure 9. 28F004BX Byte-Wide Block Diagram



### 3.1 28F004BX Memory Organization

#### 3.1.1 BLOCKING

The 28F004BX uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirm commands are written to the CUI. The 28F004BX is a random read/write memory, only erasure is performed by block.

## 3.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being programmed or erased when RP# is not at 12V. The boot block can be erased and programmed when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while still providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F004BX-T and 28F004BX-B.

#### 3.1.1.2 Parameter Block Operation

The 28F004BX has 2 parameter blocks (8-Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. Parameter blocks provide for more efficient memory utilization when dealing with small parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F004BX-T and 28F004BX-B.

#### 3.1.1.3 Main Block Operation

Four main blocks of memory exist on the 28F004BX (3  $\times$  128-Kbyte blocks and 1  $\times$  96-Kbyte blocks). See the following section on Block Memory Map for the address location of these blocks for the 28F004BX-T and 28F004BX-B.

#### 3.1.2 BLOCK MEMORY MAP

Two versions of the 28F004BX product exist to support two different memory maps of the array blocks in order to accommodate different microprocessor protocols for boot code location. The 28F004BX-T memory map is inverted from the 28F004BX-B memory map.

#### 3.1.2.1 28F004BX-B Memory Map

The 28F004BX-B device has the 16-Kbyte boot block located from 00000H to 03FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F004BX-B the first 8-Kbyte parameter block resides in memory from 04000H to 05FFFH. The second 8-Kbyte parameter block resides in memory space from 06000H to 07FFFH. The 96-Kbyte main block resides in memory space from 08000H to 1FFFFH. The three 128-Kbyte main block reside in memory space from 20000H to 3FFFFH, 40000H to 5FFFFH and 60000H to 7FFFFH. See Figure 10.



Figure 10. 28F004BX-B Memory Map



#### 3.1.2.2 28F004BX-T Memory Map

The 28F004BX-T device has the 16-Kbyte boot block located from 7C000H to 7FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F004BX-T the first 8-Kbyte parameter block resides in memory space from 7A000H to 7BFFFH. The second 8-Kbyte parameter block resides in memory space from 78000H to 79FFFH. The 96-Kbyte main block resides in memory space from 60000H to 77FFFH. The three 128-Kbyte main blocks reside in memory space from 40000H to 5FFFFH, 20000H to 3FFFFH and 00000H to 1FFFFH.



Figure 11. 28F004BX-T Memory Map

# 4.0 PRODUCT FAMILY PRINCIPLES OF OPERATION

Flash memory augments EPROM functionality with in-circuit electrical write and erase. The 4-Mbit flash family utilizes a Command User Interface (CUI) and internally generated and timed algorithms to simplify write and erase operations.

The CUI allows for 100% TTL-level control inputs, fixed power supplies during erasure and programming, and maximum EPROM compatibility.

In the absence of high voltage on the V<sub>PP</sub> pin, the 4-Mbit boot block flash family will only successfully execute the following commands: Read Array, Read Status Register, Clear Status Register and Intelligent Identifier mode. The device provides standard EPROM read, standby and output disable operations. Manufacturer Identification and Device Identification data can be accessed through the CUI or through the standard EPROM A<sub>9</sub> high voltage access (V<sub>ID</sub>) for PROM programming equipment.

The same EPROM read, standby and output disable functions are available when high voltage is applied to the V<sub>PP</sub> pin. In addition, high voltage on V<sub>PP</sub> allows write and erase of the device. All functions associated with altering memory contents: write and erase, Intelligent Identifier read and Read Status are accessed via the CUI.

The purpose of the Write State Machine (WSM) is to completely automate the write and erasure of the device. The WSM will begin operation upon receipt of a signal from the CUI and will report status back through a Status Register. The CUI will handle the WE# interface to the data and address latches, as well as system software requests for status while the WSM is in operation.

## 4.1 28F400BX Bus Operations

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles.



Table 1. Bus Operations for WORD-WIDE Mode (BYTE  $\# = V_{IH}$ )

| Mode                            | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-15</sub> |
|---------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | VIL             | V <sub>IH</sub> | Х               | Х               | Х               | D <sub>OUT</sub>   |
| Output Disable                  |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | High Z             |
| Standby                         |         | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | X               | Х               | Х               | High Z             |
| Deep Power-Down                 | 9       | V <sub>IL</sub> | Х               | Х               | Х               | Х               | X               | Х               | High Z             |
| Intelligent Identifier (Mfr)    | 4       | V <sub>IH</sub> | V <sub>IL</sub> | VIL             | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х               | 0089H              |
| Intelligent Identifier (Device) | 4, 5    | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | 4470H<br>4471H     |
| Write                           | 6, 7, 8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х               | D <sub>IN</sub>    |

#### Table 2. Bus Operations for BYTE-WIDE Mode (BYTE $\# = V_{IL}$ )

|                                    |         |                              | _               |                 |                 |                 | -               |     |                 |                   |                    |
|------------------------------------|---------|------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|-----------------|-------------------|--------------------|
| Mode                               | Notes   | RP#                          | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | A_1 | V <sub>PP</sub> | DQ <sub>0-7</sub> | DQ <sub>8-14</sub> |
| Read                               | 1, 2, 3 | V <sub>IH</sub>              | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х   | Х               | D <sub>OUT</sub>  | High Z             |
| Output Disable                     |         | V <sub>IH</sub>              | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х   | Х               | High Z            | High Z             |
| Standby                            |         | V <sub>IH</sub>              | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х   | Х               | High Z            | High Z             |
| Deep Power-Down                    | . 9     | V <sub>IL</sub>              | Х               | Х               | Х               | Х               | Х               | X   | Х               | High Z            | High Z             |
| Intelligent<br>Identifier (Mfr)    | 4       | <sup>j</sup> V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | X   | X               | 89H               | High Z             |
| Intelligent<br>Identifier (Device) | 4, 5    | VIH                          | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | X   | ×               | 70H<br>71H        | High Z             |
| Write                              | 6, 7, 8 | V <sub>IH</sub>              | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | X               | Х               | X   | Х               | D <sub>IN</sub>   | High Z             |

#### NOTES:

- 1. Refer to DC Characteristics.

- 2. X can be V<sub>L</sub>, V<sub>IH</sub> for control pins and addresses, V<sub>PPL</sub> or V<sub>PPH</sub> for V<sub>PP</sub>.

  3. See DC Characteristics for V<sub>PPL</sub>, V<sub>PPH</sub>, V<sub>HH</sub>, V<sub>ID</sub> voltages.

  4. Manufacturer and Device codes may also be accessed via a CUI write sequence. A<sub>1</sub>-A<sub>17</sub> = X.
- 5. Device ID = 4470H for 28F400BX-T and 4471H for 28F400BX-B. 6. Refer to Table 4 for valid  $D_{\text{IN}}$  during a write operation.
- 7. Command writes for Block Erase or Word/Byte Write are only executed when VPP = VPPH.
- 8. To write or erase the boot block, hold RP# at V<sub>HH</sub>.
- 9. RP# must be at GND  $\pm 0.2$ V to meet the 1.2  $\mu$ A maximum deep power-down current.



#### 4.2 28F004BX Bus Operations

Table 3. Bus Operations

| Mode                            | Notes   | RP#             | CE#             | OE#.            | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-7</sub> |
|---------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | VIL             | V <sub>IH</sub> | Х               | Х               | Х               | D <sub>OUT</sub>  |
| Output Disable                  |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | VIH             | Х               | Х               | Х               | High Z            |
| Standby                         |         | V <sub>IH</sub> | V <sub>IH</sub> | X               | X               | Х               | X               | Х               | High Z            |
| Deep Power-Down                 | 9       | V <sub>IL</sub> | Х               | Х               | Х               | Х               | X               | Х               | High Z            |
| Intelligent Identifier (Mfr)    | 4       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х               | 89H               |
| Intelligent Identifier (Device) | 4, 5    | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | 78H<br>79H        |
| Write                           | 6, 7, 8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х               | D <sub>IN</sub>   |

#### NOTES:

- 1. Refer to DC Characteristics.
- 2. X can be V<sub>II</sub> or V<sub>IH</sub> for control pins and addresses, V<sub>PPI</sub> or V<sub>PPH</sub> for V<sub>PP</sub>.
- 3. See DC Characteristics for VPPL, VPPH, VHH, VID voltages.
- 4. Manufacturer and Device codes may also be accessed via a CUI write sequence.  $A_1-A_{18}=X$ .
- 5. Device ID = 78H for 28F004BX-T and 79H for 28F004BX-B.
- 6. Refer to Table 4 for valid DIN during a write operation.
- 7. Command writes for Block erase or byte program are only executed when VPP = VPPH.
- 6. Program or erase the Boot block by holding RP# at VHH.
- 9. RP# must be at GND ±0.2V to meet the 1.2 μA maximum deep power-down current.

### 4.3 Read Operations

The 4-Mbit boot block flash family has three user read modes; Array, Intelligent Identifier, and Status Register. Status Register read mode will be discussed in detail in the "Write Operations" section.

During power-up conditions ( $V_{CC}$  supply ramping), it takes a maximum of 600 ns from when  $V_{CC}$  is at 4.5V minimum to valid data on the outputs.

#### 4.3.1 READ ARRAY

If the memory is not in the Read Array mode, it is necessary to write the appropriate read mode command to the CUI. The 4-Mbit boot block flash family has three control functions, all of which must be logically active, to obtain data at the outputs. Chip-Enable CE# is the device selection control. Power-Down RP# is the device power control. Output-Enable OE# is the DATA INPUT/OUTPUT (DQ[0:15] or DQ[0:7]) direction control and when active is used to drive data from the selected memory on to the I/O bus.

#### 4.3.1.1 Output Control

With OE# at logic-high level ( $V_{IH}$ ), the output from the device is disabled and data input/output pins (DQ[0:15] or DQ[0:7] are tri-stated. Data input is then controlled by WE#.

#### 4.3.1.2 Input Control

With WE# at logic-high level (V<sub>IH</sub>), input to the device is disabled. Data Input/Output pins (DQ[0:15] or DQ[0:7]) are controlled by OE#.

#### 4.3.2 INTELLIGENT IDENTIFIERS

#### 28F400BX PRODUCTS

The manufacturer and device codes are read via the CUI or by taking the  $\rm A_9$  pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 0089H, and location 00001H outputs the device code; 4470H for 28F400BX-T, 4471H for 28F400BX-B. When BYTE # is at a logic low only the lower byte of the above signatures is read and DQ $_{15}/A_{-1}$  is a "don't care" during Intelligent Identifier mode. A read array command must be written to the memory to return to the read array mode.

#### 28F004BX PRODUCTS

The manufacturer and device codes are also read via the CUI or by taking the  $A_9$  pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 89H, and location 00001H outputs the device code; 78H for 28F004BX-T, 79H for 28F004BX-B.



#### 4.4 Write Operations

Commands are written to the CUI using standard microprocessor write timings. The CUI serves as the interface between the microprocessor and the internal chip operation. The CUI can decipher Read Array, Read Intelligent Identifier, Read Status Register, Clear Status Register, Erase and Program commands. In the event of a read command, the CUI simply points the read path at either the array, the Intelligent Identifier, or the status register depending on the specific read command given. For a program or erase cycle, the CUI informs the write state machine that a write or erase has been requested. During a program cycle, the Write State Machine will control the program sequences and the CUI will only respond to status reads. During an erase cycle, the CUI will respond to status reads and erase suspend. After the Write State Machine has completed its task, it will allow the CUI to respond to its full command set. The CUI will stay in the current command state until the microprocessor issues another command.

The CUI will successfully initiate an erase or write operation only when V<sub>PP</sub> is within its voltage range. Depending upon the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable, available only when memory updates are desired. The system designer can also choose to "hard-wire" V<sub>PP</sub> to 12V. The 4-Mbit boot block flash family is designed to accommodate—either design practice. It is recommended that RP# be tied to logical Reset for data protection during unstable CPU reset function as described in the "Product Family Overview" section.

#### 4.4.1 BOOT BLOCK WRITE OPERATIONS

In the case of Boot Block modifications (write and erase), RP# is set to  $V_{HH}=12V$  typically, in addition to  $V_{PP}$  at high voltage.

However, if RP# is not at V<sub>HH</sub> when a program or erase operation of the boot block is attempted, the corresponding status register bit (Bit 4 for Program and Bit 5 for Erase, refer to Table 5 for Status Register Definitions) is set to indicate the failure to complete the operation.

#### 4.4.2 COMMAND USER INTERFACE (CUI)

The Command User Interface (CUI) serves as the interface to the microprocessor. The CUI points the read/write path to the appropriate circuit block as described in the previous section. After the WSM has completed its task, it will set the WSM Status bit to a "1", which will also allow the CUI to respond to its full command set. Note that after the WSM has returned control to the CUI, the CUI will remain in its current state.

#### 4.4.2.1 Command Set

| Command<br>Codes | Device Mode                |
|------------------|----------------------------|
| 00               | Invalid/Reserved           |
| 10               | Alternate Program Setup    |
| 20               | Erase Setup                |
| 40               | Program Setup              |
| 50               | Clear Status Register      |
| 70               | Read Status Register       |
| 90               | Intelligent Identifier     |
| B0               | Erase Suspend              |
| D0               | Erase Resume/Erase Confirm |
| FF.              | Read Array                 |

#### 4.4.2.2 Command Function Descriptions

Device operations are selected by writing specific commands into the CUI. Table 4 defines the 4-Mbit boot block flash family commands.



**Table 4. Command Definitions** 

| Command                                  | Bus<br>Cycles | Notes | First     | Bus Cycle | Second Bus Cycle |           |         |      |
|------------------------------------------|---------------|-------|-----------|-----------|------------------|-----------|---------|------|
|                                          | Req'd         | 8     | Operation | Address   | Data             | Operation | Address | Data |
| Read Array                               | 1             | 1     | Write     | Х         | FFH              |           |         |      |
| Intelligent Identifier                   | 3             | 2, 4  | Write     | Х         | 90H              | Read      | IA      | IID  |
| Read Status Register                     | 2             | 3     | Write     | Х         | 70H              | Read      | Х       | SRD  |
| Clear Status Register                    | 1             |       | Write     | Х         | 50H              |           |         |      |
| Erase Setup/Erase Confirm                | 2             | 5     | Write     | ВА        | 20H              | Write     | ВА      | DOH  |
| Word/Byte Write Setup/Write              | 2             | 6, 7  | Write     | WA        | 40H              | Write     | WA      | WD   |
| Erase Suspend/Erase Resume               | 2             |       | Write     | Х         | вон              | Write     | Х       | DOH  |
| Alternate Word/Byte<br>Write Setup/Write | 2             | 6, 7  | Write     | WA        | 10H              | Write     | WA      | WD   |

#### NOTES:

- 1. Bus operations are defined in Tables 1, 2, 3.
- 2. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
- 3. SRD = Data read from Status Register.
- 4. IID = Intelligent Identifier Data.

Following the Intelligent Identifier Command, two read operations access manufacturer and device codes.

- 5. BA = Address within the block being erased.
- 6. WA = Address to be written.
- WD = Data to be written at location WD.
- 7. Either 40H or 10H commands is valid.
- 8. When writing commands to the device, the upper data bus  $[DQ_8-DQ_{15}]=X$  (28F400BX-only) which is either  $V_{CC}$  or  $V_{SS}$  to avoid burning additional current.

#### Invalid/Reserved

These are unassigned commands. It is not recommended that the customer use any command other than the valid commands specified above. Intel reserves the right to redefine these codes for future functions.

#### Read Array (FFH)

This single write command points the read path at the array. If the host CPU performs a CE#/OE# controlled read immediately following a two-write sequence that started the WSM, then the device will output status register contents. If the Read Array command is given after Erase Setup the device is reset to read the array. A two Read Array command sequence (FFH) is required to reset to Read Array after Program Setup.

#### Intelligent Identifier (90H)

After this command is executed, the CUI points the output path to the Intelligent Identifier circuits. Only Intelligent Identifier values at addresses 0 and 1 can be read (only address  $A_0$  is used in this mode, all other address inputs are ignored).

#### Read Status Register (70H)

This is one of the two commands that is executable while the state machine is operating. After this command is written, a read of the device will output the contents of the status register, regardless of the address presented to the device.

The device automatically enters this mode after program or erase has completed.

#### Clear Status Register (50H)

The WSM can only set the Program Status and Erase Status bits in the status register, it can not clear them. Two reasons exist for operating the status register in this fashion. The first is a synchronization. The WSM does not know when the host CPU has read the status register, therefore it would not know when to clear the status bits. Secondly, if the CPU is programming a string of bytes, it may be more efficient to query the status register after programming the string. Thus, if any errors exist while programming the string, the status register will return the accumulated error status.



#### Program Setup (40H or 10H)

This command simply sets the CUI into a state such that the next write will load the address and data registers. Either 40H or 10H can be used for Program Setup. Both commands are included to accommodate efforts to achieve an industry standard command code set.

#### **Program**

The second write after the program setup command, will latch addresses and data. Also, the CUI initiates the WSM to begin execution of the program algorithm. While the WSM finishes the algorithm, the device will output Status Register contents. Note that the WSM cannot be suspended during programming.

#### Erase Setup (20H)

Prepares the CUI for the Erase Confirm command. No other action is taken. If the next command is not an Erase Confirm command then the CUI will set both the Program Status and Érase Status bits of the Status Register to a "1", place the device into the Read Status Register state, and wait for another command.

#### Erase Confirm (D0H)

If the previous command was an Erase Setup command, then the CUI will enable the WSM to erase, at the same time closing the address and data latches, and respond only to the Read Status Register and Erase Suspend commands. While the WSM is executing, the device will output Status Register data when OE# is toggled low. Status Register data can only be updated by toggling either OE# or CE# low.

#### Erase Suspend (B0H)

This command only has meaning while the WSM is executing an Erase operation, and therefore will only be responded to during an erase operation. After this command has been executed, the CUI will set an output that directs the WSM to suspend Erase operations, and then return to responding to only Read Status Register or to the Erase Resume commands. Once the WSM has reached the Suspend state, it will set an output into the CUI which allows the CUI to respond to the Read Array, Read Status Register, and Erase Resume commands. In this mode, the CUI will not respond to any other commands. The WSM will also set the WSM Status bit to a "1". The WSM will continue to run, idling in the SUSPEND state, regardless of the state of all input

control pins, with the exclusion of RP#. RP# will immediately shut down the WSM and the remainder of the chip. During a suspend operation, the data and address latches will remain closed, but the address pads are able to drive the address into the read path.

#### Erase Resume (D0H)

This command will cause the CUI to clear the Suspend state and set the WSM Status bit to a "0", but only if an Erase Suspend command was previously issued. Erase Resume will not have any effect in all other conditions.

#### 4.4.3 STATUS REGISTER

The 4-Mbit boot block flash family contains a status register which may be read to determine when a program or erase operation is complete, and whether that operation completed successfully. The status register may be read at any time by writing the Read Status command to the CUI. After writing this command, all subsequent Read operations output data from the status register until another command is written to the CUI. A Read Array command must be written to the CUI to return to the Read Array mode.

The status register bits are output on DQ[0:7] whether the device is in the byte-wide (x8) or word-wide (x16) mode for the 28F400BX. In the word-wide mode the upper byte, DQ[8:15] is set to 00H during a Read Status command. In the byte-wide mode, DQ[8:14] are tri-stated and DQ $_{15}/A_{-1}$  retains the low order address function.

It should be noted that the contents of the status register are latched on the falling edge of OE# or CE# whichever occurs last in the read cycle. This prevents possible bus errors which might occur if the contents of the status register change while reading the status register. CE# or OE# must be toggled with each subsequent status read, or the completion of a program or erase operation will not be evident.

The Status Register is the interface between the microprocessor and the Write State Machine (WSM). When the WSM is active, this register will indicate the status of the WSM, and will also hold the bits indicating whether or not the WSM was successful in performing the desired operation. The WSM sets status bits "Three" through "Seven" and clears bits "Six" and "Seven", but cannot clear status bits "Three" through "Five". These bits can only be cleared by the controlling CPU through the use of the Clear Status Register command.



#### 4.4.3.1 Status Register Bit Definition

#### **Table 5. Status Register Definitions**

|                                                | wsms    | ESS    | ES | PS | VPPS           | R           | R       | R                               |         |
|------------------------------------------------|---------|--------|----|----|----------------|-------------|---------|---------------------------------|---------|
| * 4                                            | 7       | 6      | 5  | 4  | 3              | 2           | 1       | 0                               |         |
|                                                |         |        |    |    | NOT            | ES:         |         |                                 |         |
| SR.7 = WRITE STATE MA<br>1 = Ready<br>0 = Busy | CHINE S | STATUS | 3  |    | deter<br>tion, | mine before | oyte/wo | e Status<br>rd progr<br>Program | am or b |

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

SR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

SR.4 = PROGRAM STATUS

1 = Error In Byte/Word Program

0 = Successful Byte/Word Program

SR.3 = V<sub>PP</sub> STATUS

1 = V<sub>PP</sub> Low Detect; Operation Abort

 $0 = V_{PP} OK$ 

SR.2-SR.0 = RESERVED FOR **FUTURE ENHANCEMENTS** 

st first be checked to block erase complease Status bits are

When Erase Suspend is issued, WSM halts execution and sets both WSMS and ESS bits to "1". ESS bit remains set to "1" until an Erase Resume command is issued.

When this bit is set to "1". WSM has applied the maximum number of erase pulses to the block and is still unable to successfully perform an erase verify.

When this bit is set to "1", WSM has attempted but failed to Program a byte or word.

The VPP Status bit unlike an A/D converter, does not provide continuous indication of Vpp level. The WSM interrogates the VPP level only after the byte write or block erase command sequences have been entered and informs the system if VPP has not been switched on. The VPP Status bit is not guaranteed to report accurate feedback between Vppi and VppH.

These bits are reserved for future use and should be masked out when polling the Status Register.

#### 4.4.3.2 Clearing the Status Register

Certain bits in the status register are set by the write state machine, and can only be reset by the system software. These bits can indicate various failure conditions. By allowing the system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several bytes or erasing multiple blocks in sequence). The status register may then be read to determine if an error occurred during that programming or erasure series. This adds flexibility to the way the device may be programmed or erased. To clear the status register, the Clear Status Register command is written to the CUI. Then, any other command may be issued to the CUI. Note again that before a read cycle can be initiated, a Read Array command must be written to the CUI to specify whether the read data is to come from the array, status register, or Intelligent Identifier.

#### 4.4.4 PROGRAM MODE

Program is executed by a two-write sequence. The Program Setup command is written to the CUI followed by a second write which specifies the address and data to be programmed. The write state machine will execute a sequence of internally timed events to:

- 1. Program the desired bits of the addressed memory word (byte), and
- 2. Verify that the desired bits are sufficiently programmed.

Programming of the memory results in specific bits within a byte or word being changed to a "0".

If the user attempts to program "1"s, there will be no change of the memory cell content and no error occurs.



Similar to erasure, the status register indicates whether programming is complete. While the program sequence is executing, bit 7 of the status register is a "0". The status register can be polled by toggling either CE# or OE# to determine when the program sequence is complete. Only the Read Status Register command is valid while programming is active.

When programming is complete, the status bits, which indicate whether the program operation was successful, should be checked. If the programming operation was unsuccessful, Bit 4 of the status register is set to a "1" to indicate a Program Failure. If Bit 3 is set then V<sub>PP</sub> was not within acceptable limits, and the WSM will not execute the programming sequence.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after programming is completed; however, it must be recognized that reads from the memory, status register, or Intelligent Identifier cannot be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 12 shows a system software flowchart for device byte programming operation. Figure 13 shows a similar flowchart for device word programming operation (28F400BX-only).

#### 4.4.5 ERASE MODE

Erasure of a single block is initiated by writing the Erase Setup and Erase Confirm commands to the CUI, along with the addresses, A[12:17] for the 28F400BX or A[12:18] for the 28F004BX, identifying the block to be erased. These addresses are latched internally when the Erase Confirm command is issued. Block erasure results in all bits within the block being set to "1".

The WSM will execute a sequence of internally timed events to:

- 1. Program all bits within the block
- Verify that all bits within the block are sufficiently programmed
- 3. Erase all bits within the block and
- Verify that all bits within the block are sufficiently erased

While the erase sequence is executing, Bit 7 of the status register is a "0".

When the status register indicates that erasure is complete, the status bits, which indicate whether the erase operation was successful, should be checked. If the erasure operation was unsuccessful, Bit 5 of the status register is set to a "1" to indicate an Erase Failure. If V<sub>PP</sub> was not within acceptable limits after the Erase Confirm command is issued, the WSM will not execute an erase sequence; instead, Bits of the status register is set to a "1" to indicate an Erase Failure, and Bit 3 is set to a "1" to identify that V<sub>PP</sub> supply voltage was not within acceptable limits.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after erasure is completed; however, it must be recognized that reads from the memory array, status register, or Intelligent Identifier can not be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 14 shows a system software flowchart for Block Erase operation.

#### 4.4.5.1 Suspending and Resuming Erase

Since an erase operation typically requires 1 to 3 seconds to complete, an Erase Suspend command is provided. This allows erase-sequence interruption in order to read data from another block of the memory. Once the erase sequence is started, writing the Erase Suspend command to the CUI requests that the Write State Machine (WSM) pause the erase sequence at a predetermined point in the erase algorithm. The status register must be read to determine when the erase operation has been suspended.

At this point, a Read Array command can be written to the CUI in order to read data from blocks other than that which is being suspended. The only other valid command at this time is the Erase Resume command or Read Status Register operation.

Figure 15 shows a system software flowchart detailing the operation.



During Erase Suspend mode, the chip can go into a pseudo-standby mode by taking CE# to  $V_{IH}$  and the active current is now a maximum of 10 mA. If the chip is enabled while in this mode by taking CE# to  $V_{IL}$ , the Erase Resume command can be issued to resume the erase operation.

Upon completion of reads from any block other than the block being erased, the Erase Resume command must be issued. When the Erase Resume command is given, the WSM will continue with the erase sequence and complete erasing the block. As with the end of erase, the status register must be read, cleared, and the next instruction issued in order to continue.

#### 4.4.6 EXTENDED CYCLING

Intel has designed extended cycling capability into its ETOX III flash memory technology. The 4-Mbit boot block flash family is designed for 100,000 program/erase cycles on each of the seven blocks. The combination of low electric fields, clean oxide processing and minimized oxide area per memory cell subjected to the tunneling electric field, results in very high cycling capability.





Figure 12. Automated Byte Programming Flowchart

attempting retry or other error recovery.





Bus Command Comments Operation Write Setup Data = 40H Program Address = Word to be programmed Write Program Data to be programmed Address = Word to be programmed Read Status Register Data. Toggle OE# or CE# to update Status Register Standby Check SR.7 1 = Ready, 0 = Busy

Repeat for subsequent words.

Full status check can be done after each word or after a sequence of words.

Write FFH after the last word programming operation to reset the device to Read Array Mode.

#### **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4<br>1 = Word Program Error         |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple words are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 13. Automated Word Programming Flowchart





| Bus<br>Operation | Command        | Comments                                                          |
|------------------|----------------|-------------------------------------------------------------------|
| Write            | Setup<br>Erase | Data = 20H<br>Address = Within block to be<br>erased              |
| Write            | Erase          | Data = D0H<br>Address = Within block to be<br>erased              |
| Read             |                | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent blocks.

Full status check can be done after each block or after a sequence of blocks.

Write FFH after the last block erase operation to reset the device to Read Array Mode.

#### **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4,5 Both 1 = Command Sequence Error |
| Standby          |         | Check SR.5<br>1 = Block Erase Error          |

SR.3 MUST be cleared, if set during an erase attempt, before further attempts are allowed by the Write State Machine.

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 14. Automated Block Erase Flowchart





Figure 15. Erase Suspend/Resume Flowchart

### 4.5 Power Consumption

#### 4.5.1 ACTIVE POWER

With CE# at a logic-low level and RP# at a logic-high level, the device is placed in the active mode. The device  $I_{CC}$  current is a maximum 60 mA at 10 MHz with TTL input signals.

#### 4.5.2 AUTOMATIC POWER SAVINGS

Automatic Power Savings (APS) is a low pwer feature during active mode of operation. The 4-Mbit family of products incorporate Power Reduction Control (PRC) circuitry which basically allows the device to put itself into a low current state when it is not being accessed. After data is read from the memory array, PRC logic controls the device's power consumption by entering the APS mode where

maximum  $I_{CC}$  current is 3 mA and typical  $I_{CC}$  current is 1 mA. The device stays in this static state with outputs valid until a new location is read.

#### 4.5.3 STANDBY POWER

With CE# at a logic-high level ( $V_{IH}$ ), and the CUI in read mode, the memory is placed in standby mode where the maximum  $I_{CC}$  standby current is 100  $\mu$ A with CMOS input signals. The standby operation disables much of the device's circuitry and substantially reduces device power consumption. The outputs (DQ[0:15] or DQ[0:7]) are placed in a high-impedance state independent of the status of the OE# signal. When the 4-Mbit boot block flash family is deselected during erase or program functions, the devices will continue to perform the erase or program function and consume program or erase active power until program or erase is completed.



#### 4.5.4 RESET/DEEP POWERDOWN

The 4-Mbit boot block flash family supports a typical  $I_{CC}$  of 0.2  $\mu$ A in deep power-down mode. One of the target markets for these devices is in portable equipment where the power consumption of the machine is of prime importance. The 4-Mbit boot block flash family has a RP# pin which places the device in the deep powerdown mode. When RP# is at a logic-low (GND  $\pm$ 0.2V), all circuits are turned off and the device typically draws 0.2  $\mu$ A of  $V_{CC}$  current.

During read modes, the RP# pin going low deselects the memory and places the output drivers in a high impedance state. Recovery from the deep power-down state, requires a maximum of 300 ns to access valid data (tpHOV).

During erase or program modes, RP# low will abort either erase or program operation. The contents of the memory are no longer valid as the data has been corrupted by the RP# function. As in the read mode above, all internal circuitry is turned off to achieve the 0.2  $\mu$ A current level.

RP# transitions to  $V_{\rm IL}$  or turning power off to the device will clear the status register.

This use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset it expects to read from the flash memory. Automated flash memories provide status information when accessed during write/erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input. In this application RP# is controlled by the same RESET# signal that resets the system CPU.

## 4.6 Power-up Operation

The 4-Mbit boot block flash family is designed to offer protection against accidental block erasure or programming during power transitions. Upon power-up the 4-Mbit boot block flash family is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers-up first. Power supply sequencing is not required.

The 4-Mbit boot block flash family ensures the CUI is reset to the read mode on power-up.

In addition, on power-up the user must either drop CE# low or present a new address to ensure valid data at the outputs.

A system designer must guard against spurious writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is

active. Since both WE# and CE# must be low for a command write, driving either signal to  $V_{IH}$  will inhibit writes to the device. The CUI architecture provides an added level of protection since alteration of memory contents can only occur after successful completion of the two-step command sequences. Finally the device is disabled until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. This feature provides yet another level of memory protection.

### 4.7 Power Supply Decoupling

Flash memory's power switching characteristics require careful device decoupling methods. System designers are interested in 3 supply current issues:

- Standby current levels (I<sub>CCS</sub>)
- Active current levels (I<sub>CCR</sub>)
- Transient peaks produced by falling and rising edges of CE#.

Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress these transient voltage peaks. Each flash device should have a 0.1  $\mu F$  ceramic capacitor connected between each  $V_{CC}$  and GND, and between its  $V_{PP}$  and GND. These high frequency, low-inherent inductance capacitors should be placed as close as possible to the package leads.

# 4.7.1 V<sub>PP</sub> TRACE ON PRINTED CIRCUIT BOARDS

Writing to flash memories while they reside in the target system, requires special consideration of the  $V_{PP}$  power supply trace by the printed circuit board designer. The  $V_{PP}$  pin supplies the flash memory cells current for programming and erasing. One should use similar trace widths and layout considerations given to the  $V_{CC}$  power supply trace. Adequate  $V_{PP}$  supply traces and decoupling will decrease spikes and overshoots.

#### 4.7.2 V<sub>CC</sub>, V<sub>PP</sub> AND RP# TRANSITIONS

The CUI latches commands as issued by system software and is not altered by V<sub>PP</sub> or CE# transitions or WSM actions. Its state upon power-up, after exit from deep power-down mode or after V<sub>CC</sub> transitions below V<sub>LKO</sub> (Lockout voltage), is Read Array mode.

After any word/byte write or block erase operation is complete and even after V<sub>PP</sub> transitions down to V<sub>PPL</sub>, the CUI must be reset to Read Array mode via the Read Array command when accesses to the flash memory are desired.



#### **ABSOLUTE MAXIMUM RATINGS\***

| Commercial Operating Temperature  During Read0°C to 70°C(1)  During Block Erase  and Word/Byte Write0°C to 70°C  Temperature Under Bias10°C to +80°C |
|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Extended Operating Temperature  During Read                                                                                                          |
| Storage Temperature65°C to +125°C                                                                                                                    |
| Voltage on Any Pin (except $V_{CC}$ , $V_{PP}$ , $A_9$ and $RP\#$ ) with Respect to GND $-2.0V$ to $+7.0V^{(2)}$                                     |
| Voltage on Pin RP# or Pin A <sub>9</sub>                                                                                                             |
| with Respect to GND $\dots$ -2.0V to +13.5V(2, 3)                                                                                                    |
| with Respect to GND2.0V to +13.5V(2, 3)  Vpp Program Voltage with Respect to GND during Block Erase and Word/Byte Write2.0V to +14.0V(2, 3)          |
| V <sub>PP</sub> Program Voltage with Respect to GND during Block Erase                                                                               |
| V <sub>PP</sub> Program Voltage with Respect to GND during Block Erase and Word/Byte Write2.0V to +14.0V(2, 3) V <sub>CC</sub> Supply Voltage        |

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns.

Maximum DC voltage on input/output pins is  $V_{CC} + 0.5V$  which, during transitions, may overshoot to  $V_{CC} + 2.0V$  for periods <20 ns.

- 3. Maximum DC voltage on  $V_{PP}$  may overshoot to  $\pm 14.0 V$  for periods <20 ns. Maximum DC voltage on RP# or  $A_9$  may overshoot to 13.5V for periods < 20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. 10%  $V_{CC}$  specifications reference the 28F400BX-60/28F004BX-60 in their standard test configuration, and the 28F400BX-80/28F004BX-80.
- 6. 5% V<sub>CC</sub> specifications reference the 28F400BX-60/28F004BX-60 in their high speed test configuration.

#### **OPERATING CONDITIONS**

| Symbol          | Parameter                            | Notes | Min  | Max  | Units |
|-----------------|--------------------------------------|-------|------|------|-------|
| T <sub>A</sub>  | Operating Temperature                |       | 0    | 70   | °C    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (10%) | 5     | 4.50 | 5.50 | V     |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (5%)  | 6     | 4.75 | 5.25 | ٧     |

#### DC CHARACTERISTICS

| Symbol          | Parameter              | Notes | Min | Тур | Max   | Unit | Test Condition                                    |
|-----------------|------------------------|-------|-----|-----|-------|------|---------------------------------------------------|
| lu              | Input Load Current     | 1     |     |     | ± 1.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$ |
| I <sub>LO</sub> | Output Leakage Current | 1     | 1   |     | ±10   | μΑ   | $V_{CC} = V_{CC} Max$ $V_{OUT} = V_{CC} or GND$   |



## DC CHARACTERISTICS (Continued)

| Symbol           | Parameter                                                                                    | Notes          | Min  | Тур      | Max                   | Unit | , Test Conditions                                                                                           |
|------------------|----------------------------------------------------------------------------------------------|----------------|------|----------|-----------------------|------|-------------------------------------------------------------------------------------------------------------|
| lccs             | V <sub>CC</sub> Standby Current                                                              | 1, 3           |      |          | 1.5                   | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = RP# = V <sub>IH</sub>                                        |
|                  |                                                                                              |                |      |          | 100                   | μΑ   | $V_{CC} = V_{CC}$ Max<br>$CE\# = RP\# = V_{CC} \pm 0.2V$<br>28F400BX:<br>$BYTE\# = V_{CC} \pm 0.2V$ or GND  |
| ICCD             | V <sub>CC</sub> Deep Powerdown Current                                                       | 1              |      | 0.20     | 1.2                   | μΑ   | $RP# = GND \pm 0.2V$                                                                                        |
| ICCR             | V <sub>CC</sub> Read Current for<br>28F400BX Word-Wide<br>and Byte-Wide Mode<br>and 28F004BX | 1, 5,<br>6, 10 |      | 20       | 55                    |      | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>f (Max) = 10 MHz, f (Typ) = 5 MHz<br>$I_{OUT} = 0$ mA<br>CMOS Inputs |
|                  | Byte-Wide Mode                                                                               |                | -    | 20       | 60                    | mΑ   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$ f (Max) = 10 MHz, f (Typ) = 5 MHz $I_{OUT} = 0$ mA TTL Inputs        |
| Iccw             | V <sub>CC</sub> Word/Byte Write Current                                                      | 1, 4           |      | <u> </u> | 65                    | mΑ   | Word or Byte Write in Progress                                                                              |
| ICCE .           | V <sub>CC</sub> Block Erase Current                                                          | 1, 4           |      |          | 30                    | mΑ   | Block Erase in Progress                                                                                     |
| CCES             | V <sub>CC</sub> Erase Suspend Current                                                        | 1, 2           |      | 5        | 10                    | mΑ   | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                                             |
| IPPS             | V <sub>PP</sub> Standby Current                                                              | 1              |      |          | ± 15                  | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                           |
| I <sub>PPD</sub> | V <sub>PP</sub> Deep PowerDown Current                                                       | 1              |      |          | 5.0                   | μΑ   | $RP# = GND \pm 0.2V$                                                                                        |
| IPPR             | V <sub>PP</sub> Read Current                                                                 | 1              |      |          | 200                   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                                                           |
| I <sub>PPW</sub> | V <sub>PP</sub> Word Write Current                                                           | 1, 4           |      |          | 40                    | mΑ   | $V_{PP} = V_{PPH}$ Word Write in Progress                                                                   |
| IPPW             | V <sub>PP</sub> Byte Write Current                                                           | 1, 4           | ,    |          | 30                    | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                                                |
| IPPE             | V <sub>PP</sub> Block Erase Current                                                          | 1, 4           |      |          | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                                               |
| IPPES            | V <sub>PP</sub> Erase Suspend Current                                                        | 1              |      |          | 200                   | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                                                 |
| I <sub>RP#</sub> | RP# Boot Block Unlock<br>Current                                                             | 1, 4           |      |          | 500                   | μΑ   | RP# = V <sub>HH</sub>                                                                                       |
| l <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current                                                | 1, 4           |      |          | 500                   | μΑ   | $A_9 = V_{ID}$                                                                                              |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Voltage                                                |                | 11.5 |          | 13.0                  | ٧    |                                                                                                             |
| V <sub>IL</sub>  | Input Low Voltage                                                                            |                | -0.5 |          | 0.8                   | ٧    |                                                                                                             |
| V <sub>IH</sub>  | Input High Voltage                                                                           |                | 2.0  |          | V <sub>CC</sub> + 0.5 | ٧    |                                                                                                             |
| V <sub>OL</sub>  | Output Low Voltage                                                                           |                |      |          | 0.45                  | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                                                                     |



## DC CHARACTERISTICS (Continued)

| Symbol           | Parameter                                     | Notes | Min                   | Тур  | Max  | Unit     | Test Conditions                                             |
|------------------|-----------------------------------------------|-------|-----------------------|------|------|----------|-------------------------------------------------------------|
| V <sub>OH1</sub> | Output High Voltage (TTL)                     | 1,4   | 2.4                   |      |      | >        | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                    |
| V <sub>OH2</sub> | Output High Voltage (CMOS)                    |       | 0.85 V <sub>CC</sub>  |      |      | ٧        | $I_{OH} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$ |
|                  |                                               |       | V <sub>CC</sub> - 0.4 |      |      |          | $I_{OH} = -100 \mu A$ $V_{CC} = V_{CC} Min$                 |
| $V_{PPL}$        | V <sub>PP</sub> during Normal Operations      | 3     | 0.0                   |      | 6.5  | <b>V</b> |                                                             |
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write Operations | 7     | 11.4                  | 12.0 | 12.6 | ٧        |                                                             |
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write Operations | 8     | 10.8                  | 12.0 | 13.2 | ٧        |                                                             |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.0                   |      |      | ٧        |                                                             |
| V <sub>HH</sub>  | RP# Unlock Voltage                            |       | 11.5                  |      | 13.0 | >        | Boot Block Write/Erase                                      |

## **EXTENDED TEMPERATURE OPERATING CONDITIONS**

| Symbol          | mbol Parameter                       |   | Min  | Max  | Unit |
|-----------------|--------------------------------------|---|------|------|------|
| T <sub>A</sub>  | Operating Temperature                |   | -40  | 85   | °C   |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (10%) | 5 | 4.50 | 5.50 | ٧    |

## DC CHARACTERISTICS: EXTENDED TEMPERATURE OPERATION

| Symbol            | Parameter                               | Notes | Min | Тур  | Max  | Unit | Test Conditions                                                                                                                             |
|-------------------|-----------------------------------------|-------|-----|------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------|
| ել                | Input Load Current                      | 1     |     |      | ±1.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                                                           |
| I <sub>LO</sub> . | Output Leakage Current                  | 1     |     |      | ±10  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                                                                          |
| Iccs              | V <sub>CC</sub> Standby Current         | 1, 3  |     |      | 1.5  | mA   | $V_{CC} = V_{CC} Max$ $CE\# = RP\# = V_{IH} RP\#$                                                                                           |
|                   |                                         |       |     |      | 100  | μА   | $\begin{aligned} &V_{CC} = V_{CC}  Max \\ &CE\# = RP\# = V_{CC} \pm 0.2V \\ &28F400BX: \\ &BYTE\# = V_{CC} \pm 0.2V  or  GND \end{aligned}$ |
| I <sub>CCD</sub>  | V <sub>CC</sub> Deep Power-Down Current | 1     |     | 0.20 | 20   | μΑ   | RP# = GND ±0.2V                                                                                                                             |



## DC CHARACTERISTICS: EXTENDED TEMPERATURE OPERATION (Continued)

| Symbol           | Parameter                                                                                            | Notes          | Min | Тур | Max | Unit | Test Conditions                                                                    |
|------------------|------------------------------------------------------------------------------------------------------|----------------|-----|-----|-----|------|------------------------------------------------------------------------------------|
| ICCR             | V <sub>CC</sub> Read Current for 28F400BX<br>Word-Wide and Byte-Wide Mode<br>28F004BX Byte-Wide Mode | 1, 5,<br>6, 10 |     | ,   | 60  | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>f = 10 MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs |
|                  |                                                                                                      |                |     |     | 65  | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$ f = 10 MHz, $I_{OUT} = 0$ mA TTL Inputs     |
| Iccw             | V <sub>CC</sub> Word Write Current                                                                   | 1              |     |     | 70  | mΑ   | Word Write in Progress                                                             |
| ICCE             | V <sub>CC</sub> Block Erase Current                                                                  | 1              |     |     | 40  | mΑ   | Block Erase in Progress                                                            |
| ICCES            | V <sub>CC</sub> Erase Suspend Current                                                                | 1, 2           |     | 5   | 10  | mA   | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                    |
| I <sub>PPS</sub> | V <sub>PP</sub> Standby Current                                                                      | 1              |     |     | ±15 | μΑ   | $V_{PP} \leq V_{CC}$                                                               |
| I <sub>PPD</sub> | V <sub>CC</sub> Deep Power-Down Current                                                              | 1              |     |     | 5.0 | μΑ   | $RP# = GND \pm 0.2V$                                                               |
| IPPR             | V <sub>PP</sub> Read Current                                                                         | 1              |     |     | 200 | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                                  |
| I <sub>PPW</sub> | V <sub>PP</sub> Word Write Current                                                                   | 1              |     |     | 40  | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress                       |
| IPPW             | V <sub>PP</sub> Byte Write Current                                                                   | 1              |     |     | 30  | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                       |



## DC CHARACTERISTICS: EXTENDED TEMPERATURE OPERATION (Continued)

| Symbol           | Parameter                                     | Notes | Min                   | Тур  | Max            | Unit | Test Conditions                                               |
|------------------|-----------------------------------------------|-------|-----------------------|------|----------------|------|---------------------------------------------------------------|
| IPPE             | V <sub>PP</sub> Block Erase Current           | 1     |                       |      | 30             | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress |
| IPPES            | V <sub>PP</sub> Erase Suspend Current         | 1     |                       |      | 200            | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended   |
| I <sub>RP#</sub> | RP# Boot Block Unlock<br>Current              | 1, 4  |                       | ,    | 500            | μΑ   | RP# = V <sub>HH</sub>                                         |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current | 1     |                       |      | 500            | μΑ   | $A_9 = V_{ID}$                                                |
| $V_{ID}$         | A <sub>9</sub> Intelligent Identifier Current |       | 11.5                  |      | 13.0           | ٧    |                                                               |
| V <sub>IL</sub>  | Input Low Voltage                             |       | -0.5                  |      | 0.8            | ٧    |                                                               |
| VIH              | Input High Voltage                            |       | 2.0                   |      | $V_{CC} + 0.5$ | ٧    |                                                               |
| V <sub>OL</sub>  | Output Low Voltage                            |       |                       |      | 0.45           | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                       |
| V <sub>OH1</sub> | Output High Voltage (TTL)                     |       | 2.4                   |      |                | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                      |
| V <sub>OH2</sub> | Output High Voltage (CMOS)                    |       | 0.85 V <sub>CC</sub>  |      |                | ٧    | $I_{OH} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$   |
|                  |                                               |       | V <sub>CC</sub> - 0.4 |      |                |      | $I_{OH} = -100 \mu\text{A}$<br>$V_{CC} = V_{CC} \text{Min}$   |
| $V_{PPL}$        | V <sub>PP</sub> during Normal Operations      | 3     | 0.0                   |      | 6.5            | ٧    |                                                               |
| $V_{PPH}$        | V <sub>PP</sub> during Erase/Write Operations | 7     | 11.4                  | 12.0 | 12.6           | ٧    |                                                               |
| $V_{PPH}$        | V <sub>PP</sub> during Erase/Write Operations | 8     | 10.8                  | 12.0 | 13.2           | ٧    |                                                               |
| $V_{LKO}$        | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.0                   |      |                | ٧    |                                                               |
| V <sub>HH</sub>  | RP# Unlock Voltage                            |       | 11.5                  |      | 13.0           | ٧    | Boot Block Write/Erase                                        |

## CAPACITANCE(4) T<sub>A</sub> = 25°C, f = 1 MHz

| Symbol           | Parameter          | Тур | Max | Unit | Conditions     |
|------------------|--------------------|-----|-----|------|----------------|
| C <sub>IN</sub>  | Input Capacitance  | 6   | 8   | pF   | $V_{IN} = 0V$  |
| C <sub>OUT</sub> | Output Capacitance | 10  | 12  | pF   | $V_{OUT} = 0V$ |

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (packages and speeds).
- 2. ICCES is specified with the device deselected. If the device is read while in Erase Suspend Mode, current draw is the sum of ICCES and ICCR.
- 3. Block Erases and Word/Byte Writes are inhibited when Vpp = VppL and not guaranteed in the range between VppH and
- 4. Sampled, not 100% tested.
- 5. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA typical in static operation.
- 6. CMOS Inputs are either  $V_{CC}$   $\pm 0.2 V$  or GND  $\pm 0.2 V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .
- 7.  $V_{PP}=12.0V\pm5\%$  for applications requiring 100,000 block erase cycles. 8.  $V_{PP}=12.0V\pm10\%$  for applications requiring wider  $V_{PP}$  tolerances at 100 block erase cycles.
- 9. For the 28F004BX address pin A<sub>10</sub> follows the C<sub>OUT</sub> capacitance numbers.
- 10. I<sub>CCR</sub> typical is 20 mA for X16 Active Read Current.



#### STANDARD TEST CONFIGURATION(1)

# STANDARD AC INPUT/OUTPUT REFERENCE WAVEFORM



# STANDARD AC TESTING LOAD CIRCUIT



#### HIGH SPEED TEST CONFIGURATION(2)

# HIGH SPEED AC INPUT/OUTPUT REFERENCE WAVEFORM



# HIGH SPEED AC TESTING LOAD CIRCUIT



- 1. Testing characteristics for 28F400BX-60/28F004BX-60 in standard test configuration and 28F400BX-80/28F004BX-80.
- 2. Testing characteristics for 28F400BX-60/28F004BX-60 in high speed test configuration.



## AC CHARACTERISTICS—Read Only Operations(1)

| Vers              |                  | V <sub>CC</sub> ± 5%                                                       |       |     | BX-60 <sup>(4)</sup> |                                                          |     |                                                          |     |                                                            | ,   |      |
|-------------------|------------------|----------------------------------------------------------------------------|-------|-----|----------------------|----------------------------------------------------------|-----|----------------------------------------------------------|-----|------------------------------------------------------------|-----|------|
| vers              |                  | V <sub>CC</sub> ± 10%                                                      |       |     |                      | 28F400BX-60 <sup>(5)</sup><br>28F004BX-60 <sup>(5)</sup> |     | 28F400BX-80 <sup>(5)</sup><br>28F004BX-80 <sup>(5)</sup> |     | 28F400BX-120 <sup>(5)</sup><br>28F004BX-120 <sup>(5)</sup> |     | Unit |
| Sym               | bol              | Parameter                                                                  | Notes | Min | Max                  | Min                                                      | Max | Min                                                      | Max | Min                                                        | Max |      |
| t <sub>AVAV</sub> | t <sub>RC</sub>  | Read Cycle Time                                                            |       | 60  |                      | 70                                                       |     | 80                                                       |     | 120                                                        |     | ns   |
| t <sub>AVQV</sub> | t <sub>ACC</sub> | Address to<br>Output Delay                                                 |       |     | 60                   |                                                          | 70  |                                                          | 80  |                                                            | 120 | ns   |
| t <sub>ELQV</sub> | t <sub>CE</sub>  | CE# to Output Delay                                                        | 2     |     | 60                   |                                                          | 70  |                                                          | 80  |                                                            | 120 | ns   |
| t <sub>PHQV</sub> | t <sub>PWH</sub> | RP# High to<br>Output Delay                                                |       |     | 300                  |                                                          | 300 |                                                          | 300 |                                                            | 300 | ns   |
| tGLQV             | toE              | OE# to Output Delay                                                        | 2     |     | 30                   |                                                          | 35  |                                                          | 40  |                                                            | 40  | ns   |
| tELQX             | $t_{LZ}$         | CE# to Output Low Z                                                        | 3     | 0   |                      | 0                                                        |     | 0                                                        |     | 0                                                          |     | ns   |
| t <sub>EHQZ</sub> | t <sub>HZ</sub>  | CE# High to Output<br>High Z                                               | 3     |     | 20                   |                                                          | 25  |                                                          | 30  |                                                            | 30  | ns   |
| tGLQX             | toLZ             | OE# to Output Low Z                                                        | 3     | 0   |                      | 0                                                        |     | 0                                                        |     | 0                                                          |     | ns   |
| tGHQZ             | t <sub>DF</sub>  | OE# High to Output<br>High Z                                               | 3     |     | 20                   |                                                          | 25  |                                                          | 30  |                                                            | 30  | ns   |
|                   | tон              | Output Hold from<br>Addresses,<br>CE# or OE# Change,<br>Whichever is First | 3     | 0   |                      | 0                                                        |     | 0                                                        |     | 0                                                          |     | ns   |
| t <sub>ELFL</sub> |                  | CE# to BYTE#<br>Switching<br>Low or High                                   | 3     |     | 5                    | ·                                                        | 5   |                                                          | 5   |                                                            | 5   | ns   |
| <sup>t</sup> FHQV |                  | BYTE# Switching<br>High to Valid<br>Output Delay                           | 3, 6  |     | 60                   |                                                          | 70  |                                                          | 80  |                                                            | 120 | ns   |
| t <sub>FLQZ</sub> |                  | BYTE# Switching<br>Low to<br>Output High Z                                 | 3     |     | 20                   |                                                          | 25  |                                                          | 30  |                                                            | 30  | ns   |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.
  4. See High Speed Test Configuration.
- 5. See Standard Test Configuration.
- 6.  $t_{FLQV}$ , BYTE# switching low to valid output delay, will be equal to  $t_{AVQV}$ , measured from the time  $DQ_{15}/A_{-1}$  becomes valid.



# EXTENDED TEMPERATURE OPERATION AC CHARACTERISTICS—Read Only Operations<sup>(1)</sup>

|                   |                  | Versions                                                                   |       |     | 00BX-80 <sup>(4)</sup><br>004BX-80 | Unit |  |
|-------------------|------------------|----------------------------------------------------------------------------|-------|-----|------------------------------------|------|--|
| Syn               | nbol             | Parameter                                                                  | Notes | Min | Max                                |      |  |
| t <sub>AVAV</sub> | t <sub>RC</sub>  | Read Cycle Time                                                            |       | 80  |                                    | ns   |  |
| tAVQV             | tACC             | Address to<br>Output Delay                                                 |       |     | 80                                 | ns   |  |
| tELQV             | t <sub>CE</sub>  | CE# to Output Delay                                                        |       |     | 80                                 | ns   |  |
| t <sub>PHQV</sub> | t <sub>PWH</sub> | RP# High to<br>Output Delay                                                |       |     | 300                                | ns   |  |
| t <sub>GLQV</sub> | t <sub>OE</sub>  | OE# to Output Delay                                                        | 2     |     | 40                                 | ns   |  |
| t <sub>ELQX</sub> | t <sub>LZ</sub>  | CE# to Output Low Z                                                        |       | 0   |                                    | ns   |  |
| <sup>t</sup> EHQZ | t <sub>HZ</sub>  | CE# High to Output<br>High Z                                               |       |     | 30                                 | ns   |  |
| tGLQX             | toLZ             | OE# to Output Low Z                                                        | 3     | 0   |                                    | ns   |  |
| <sup>t</sup> GHQZ | t <sub>DF</sub>  | OE# High to Output<br>High Z                                               | 3     |     | 30                                 | ns   |  |
|                   | t <sub>OH</sub>  | Output Hold from<br>Addresses,<br>CE# or OE# Change,<br>Whichever is First | 3     | 0   |                                    | ns   |  |
| telfl<br>telfh    |                  | CE# to BYTE# Switching Low or High                                         | 3     | ì   | 5                                  | ns   |  |
| t <sub>FHQV</sub> |                  | BYTE# Switching<br>High to Valid<br>Output Delay                           | 3, 5  |     | 80                                 | ns   |  |
| t <sub>FLQZ</sub> |                  | BYTE# Switching<br>Low to<br>Output High Z                                 | 3     |     | 30                                 | ns   |  |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.
- 4. See Standard Test Configuration.
- 5. t<sub>FLQV</sub>, BYTE# switching low to valid output delay, will be equal to t<sub>AVQV</sub> from the time DQ<sub>15</sub>/A<sub>-1</sub> becomes valid.











Figure 18. I<sub>CC</sub> (RMS) vs Frequency (V<sub>CC</sub> = 5.5V) for x8 Operation



Figure 19. TACC vs Output Load Capacitance



# AC CHARACTERISTICS—WE# Controlled Write Operations(1)

| V                  |                  | V <sub>CC</sub> ± 5%                                 |         |               | BX-60 <sup>(9)</sup> |                                                            |     |         |     |                                                              |     |      |
|--------------------|------------------|------------------------------------------------------|---------|---------------|----------------------|------------------------------------------------------------|-----|---------|-----|--------------------------------------------------------------|-----|------|
| Versio             | ons              | V <sub>CC</sub> ± 10%                                |         |               |                      | 28F400BX-60 <sup>(10)</sup><br>28F004BX-60 <sup>(10)</sup> |     | li e    |     | 28F400BX-120 <sup>(10)</sup><br>28F004BX-120 <sup>(10)</sup> |     | Unit |
| Symi               | bol              | Parameter                                            | Notes   | lotes Min Max |                      | Min                                                        | Max | Min Max |     | Min Max                                                      |     |      |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                                     |         | 60            |                      | 70                                                         |     | 80      |     | 120                                                          |     | ns   |
| tpHWL              | tps              | RP# High<br>Recovery to<br>WE# Going Low             |         | 215           |                      | 215                                                        |     | 215     |     | 215                                                          |     | ns   |
| tELWL              | t <sub>CS</sub>  | CE# Setup to WE#<br>Going Low                        |         | 0             |                      | 0                                                          |     | 0       | ,   | 0                                                            |     | ns   |
| tрннwн             | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to WE# Going High          | 6, 8    | 100           |                      | 100                                                        |     | 100     |     | 100                                                          |     | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE#<br>Going High           | 5, 8    | 100           |                      | 100                                                        |     | 100     |     | 100                                                          |     | ns   |
| t <sub>AVWH</sub>  | t <sub>AS</sub>  | Address Setup to<br>WE# Going High                   | 3       | 50            |                      | 50                                                         |     | 50      |     | 50                                                           |     | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to WE#<br>Going High                      | 4       | 50            |                      | 50                                                         | • : | 50      |     | 50                                                           | ,   | ns   |
| twLwH              | t <sub>WP</sub>  | WE# Pulse Width                                      |         | 50            |                      | 50                                                         | ,   | 60      |     | 60                                                           |     | ns   |
| t <sub>WHDX</sub>  | t <sub>DH</sub>  | Data Hold from<br>WE# High                           | 4       | 0             |                      | 0                                                          |     | 0       |     | 0                                                            |     | ns   |
| twhax              | t <sub>AH</sub>  | Address Hold from<br>WE# High                        | 3       | 10            |                      | 10                                                         |     | . 10    |     | 10                                                           |     | ns   |
| twheh              | t <sub>CH</sub>  | CE# Hold from<br>WE# High                            |         | 10            |                      | 10                                                         |     | 10      |     | 10                                                           |     | ns   |
| twhwL              | t <sub>WPH</sub> | WE# Pulse<br>Width High                              |         | 10            |                      | 20                                                         |     | 20      |     | 20                                                           |     | ns   |
| t <sub>WHQV1</sub> |                  | Duration of<br>Word/Byte<br>Programming<br>Operation | 2, 5    | 6             |                      | 6                                                          |     | 6       |     | 6                                                            |     | μs   |
| t <sub>WHQV2</sub> |                  | Duration of Erase<br>Operation (Boot)                | 2, 5, 6 | 0.3           |                      | 0.3                                                        |     | 0.3     |     | 0.3                                                          |     | s    |
| twHQV3             |                  | Duration of Erase<br>Operation<br>(Parameter)        | 2, 5    | 0.3           |                      | 0.3                                                        |     | 0.3     |     | 0.3                                                          |     | s    |
| t <sub>WHQV4</sub> |                  | Duration of Erase<br>Operation (Main)                | 2, 5    | 0.6           |                      | 0.6                                                        |     | 0.6     |     | 0.6                                                          |     | s    |
| t <sub>QWL</sub>   | t <sub>VPH</sub> | V <sub>PP</sub> Hold from<br>Valid SRD               | 5, 8    | 0             |                      | 0 ′                                                        |     | 0       |     | 0                                                            |     | ns   |
| t <sub>QVPH</sub>  | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold<br>from Valid SRD           | 6, 8    | 0             |                      | 0                                                          |     | 0       |     | 0                                                            |     | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block<br>Relock Delay                           | 7, 8    |               | 100                  |                                                            | 100 |         | 100 |                                                              | 100 | ns   |



#### AC CHARACTERISTICS—WE # Controlled Write Operations(1) (Continued)

#### NOTES:

- Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during Read Mode.
- 2. The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- 4. Refer to command definition table for valid D<sub>IN</sub>.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7 = 1).
- 6. For Boot Block Program/Erase, RP# should be held at VHH until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the Boot Block.
- 8. Sampled but not 100% tested.
- 9. See High Speed Test Configuration.
- 10. See Standard Test Configuration.

#### BLOCK ERASE AND WORD/BYTE WRITE PERFORMANCE $V_{PP} = 12.0V \pm 5\%$

| Parameter                          | Notes | 28F400BX-60<br>28F004BX-60 |        | 28F400BX-80<br>28F004BX-80 |     |        | 28F400BX-120<br>28F004BX-120 |     |        | Unit |   |
|------------------------------------|-------|----------------------------|--------|----------------------------|-----|--------|------------------------------|-----|--------|------|---|
|                                    |       | Min                        | Typ(1) | Max                        | Min | Typ(1) | Max                          | Min | Typ(1) | Max  |   |
| Boot/Parameter<br>Block Erase Time | 2     |                            | 1.0    | 7                          |     | 1.0    | 7                            |     | 1.0    | 7    | s |
| Main Block<br>Erase Time           | 2     |                            | 2.4    | 14                         |     | 2.4    | 14                           |     | 2.4    | 14   | s |
| Main Block Byte<br>Program Time    | 2     |                            | 1.2    | 4.2                        |     | 1.2    | 4.2                          |     | 1.2    | 4.2  | S |
| Main Block Word<br>Program Time    | 2     | -                          | 0.6    | 2.1                        |     | 0.6    | 2.1                          |     | 0.6    | 2.1  | s |

#### NOTES:

- 1. 25°C
- 2. Excludes System-Level Overhead.

#### BLOCK ERASE AND WORD/BYTE WRITE PERFORMANCE $V_{PP}=12.0V~\pm10\%$

| Parameter                          | Notes |     | 28F400BX-60<br>28F004BX-60 |     | 28F400BX-80<br>28F004BX-80 |        |     | 28F400BX-120<br>28F004BX-120 |        |     | Unit |
|------------------------------------|-------|-----|----------------------------|-----|----------------------------|--------|-----|------------------------------|--------|-----|------|
|                                    |       | Min | Typ(1)                     | Max | Min                        | Typ(1) | Max | Min                          | Typ(1) | Max |      |
| Boot/Parameter<br>Block Erase Time | 2     |     | 5.8                        | 40  |                            | 5.8    | 40  |                              | 5.8    | 40  | S    |
| Main Block<br>Erase Time           | 2     |     | 14                         | 60  |                            | 14     | 60  |                              | 14     | 60  | s    |
| Main Block Byte<br>Program Time    | 2     |     | 6.0                        | 20  |                            | 6.0    | 20  |                              | 6.0    | 20  | s    |
| Main Block Word<br>Program Time    | 2     |     | 3.0                        | 10  |                            | 3.0    | 10  |                              | 3.0    | 10  | s    |

- 1. 25°C
- Excludes System-Level Overhead.



# EXTENDED TEMPERATURE OPERATION AC CHARACTERISTICS—WE# Controlled Write Operations(1)

|                    |                  | Versions <sup>(4)</sup>                        |         |     | 0BX-80 <sup>(9)</sup><br>4BX-80 <sup>(9)</sup> | Unit |
|--------------------|------------------|------------------------------------------------|---------|-----|------------------------------------------------|------|
| Sym                | bol              | Parameter                                      | Notes   | Min | Max                                            | 1    |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                               |         | 80  |                                                | ns   |
| t <sub>PHWL</sub>  | tps              | RP# High Recovery to<br>WE# Going Low          |         | 220 | ,                                              | ns   |
| t <sub>ELWL</sub>  | t <sub>CS</sub>  | CE# Setup to WE# Going Low                     |         | 0   |                                                | ns   |
| t <sub>PHHWH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to WE#<br>Going High | 6, 8    | 100 |                                                | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE# Going High        | 5, 8    | 100 |                                                | ns   |
| <sup>t</sup> avwh  | t <sub>AS</sub>  | Address Setup to WE#<br>Going High             | 3       | 60  |                                                | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to WE# Going High                   | 4       | 60  |                                                | ns   |
| twLwH              | t <sub>WP</sub>  | WE# Pulse Width                                |         | 60  | 1 20                                           | ns   |
| twHDX              | t <sub>DH</sub>  | Data Hold from WE# High                        | 4       | 0   | -                                              | ns   |
| twhax              | t <sub>AH</sub>  | Address Hold from WE# High                     | 3       | 10  |                                                | ns   |
| t <sub>WHEH</sub>  | t <sub>CH</sub>  | CE# Hold from WE# High                         |         | `10 |                                                | ns   |
| twHWL              | t <sub>WPH</sub> | WE# Pulse Width High                           |         | 20  |                                                | ns   |
| twHQV1             |                  | Duration of Word/Byte<br>Programming Operation | 2, 5    | 7   |                                                | μs   |
| t <sub>WHQV2</sub> |                  | Duration of Erase Operation (Boot)             | 2, 5, 6 | 0.4 |                                                | S    |
| t <sub>WHQV3</sub> |                  | Duration of Erase Operation (Parameter)        | 2, 5    | 0.4 |                                                | s    |
| t <sub>WHQV4</sub> |                  | Duration of Erase Operation (Main)             | 2, 5    | 0.7 |                                                | s    |
| t <sub>QWL</sub>   | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD            | 5, 8    | 0   |                                                | ns   |
| t <sub>QVPH</sub>  | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD        | 6, 8    | 0   |                                                | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                        | 7, 8    |     | 100                                            | ns   |



#### **EXTENDED TEMPERATURE OPERATION** AC CHARACTERISTICS—WE # Controlled Write Operations(1) (Continued)

#### NOTES:

- 1. Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during Read Mode.
- 2. The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- 4. Refer to command definition table for valid D<sub>IN</sub>.
  5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7 = 1).
- 6. For Boot Block Program/Erase, RP# should be held at VHH until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the Boot Block.
- 8. Sampled but not 100% tested.
- 9. See Standard Test Configuration.

#### **EXTENDED TEMPERATURE OPERATION BLOCK ERASE AND WORD/BYTE WRITE PERFORMANCE** $V_{PP} = 12.0V \pm 5\%$

| Parameter                          | Notes |     | T28F400BX-80<br>T28F004BX-80 |      |   |  |  |
|------------------------------------|-------|-----|------------------------------|------|---|--|--|
|                                    |       | Min | Typ(1)                       | Max  |   |  |  |
| Boot/Parameter<br>Block Erase Time | 2     |     | 1.5                          | 10.5 | S |  |  |
| Main Block<br>Erase Time           | 2     |     | 3.0                          | 18   | s |  |  |
| Main Block Byte<br>Program Time    | 2     |     | 1.4                          | 5.0  | s |  |  |
| Main Block Word<br>Program Time    | 2     |     | 0.7                          | 2.5  | s |  |  |

- 1. 25°C
- 2. Excludes System-Level Overhead.



Figure 21. AC Waveforms for a Write and Erase Operations (WE #-Controlled Writes)



#### AC CHARACTERISTICS—CE#-CONTROLLED WRITE OPERATIONS(1,9)

| Vo                 |                  | V <sub>CC</sub> ± 5%                               |         |     | 3X-60 <sup>(10)</sup><br>3X-60 <sup>(10)</sup> |                                    |     |     |     | -                                                            |     |    |
|--------------------|------------------|----------------------------------------------------|---------|-----|------------------------------------------------|------------------------------------|-----|-----|-----|--------------------------------------------------------------|-----|----|
| Versi              | ons              | V <sub>CC</sub> ± 10%                              |         |     |                                                | 28F400BX-60(11)<br>28F004BX-60(11) |     | 1   |     | 28F400BX-120 <sup>(11)</sup><br>28F004BX-120 <sup>(11)</sup> |     | 1  |
| Sym                | bol              | Parameter                                          | Notes   | Min | Max                                            | Min                                | Max | Min | Max | Min                                                          | Max |    |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                                   |         | 60  |                                                | 70                                 |     | 80  |     | 120                                                          |     | ns |
| t <sub>PHEL</sub>  | t <sub>PS</sub>  | RP# High<br>Recovery<br>to CE# Going Low           |         | 215 |                                                | 215                                |     | 215 |     | 215                                                          |     | ns |
| tWLEL              | tws              | WE# Setup to<br>CE# Going Low                      |         | 0   |                                                | 0                                  |     | 0   |     | 0                                                            |     | ns |
| <sup>t</sup> PHHEH | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to<br>CE# Going High     | 6, 8    | 100 |                                                | 100                                |     | 100 |     | 100                                                          |     | ns |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE#<br>Going High         | 5, 8    | 100 |                                                | 100                                |     | 100 |     | 100                                                          |     | ns |
| tAVEH              | t <sub>AS</sub>  | Address Setup to CE# Going High                    | 3       | 50  |                                                | 50                                 |     | 50  |     | 50                                                           |     | ns |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to<br>CE# Going High                    | 4       | 50  |                                                | 50                                 |     | 50  |     | 50                                                           |     | ns |
| t <sub>ELEH</sub>  | t <sub>CP</sub>  | CE# Pulse Width                                    |         | 50  |                                                | 50                                 |     | 60  |     | 60                                                           |     | ns |
| <sup>t</sup> EHDX  | t <sub>DH</sub>  | Data Hold from<br>CE# High                         | 4       | 0   |                                                | 0                                  |     | 0   |     | 0                                                            |     | ns |
| <sup>t</sup> EHAX  | t <sub>AH</sub>  | Address Hold<br>from CE# High                      | 3       | 10  |                                                | 10                                 |     | 10  |     | 10                                                           |     | ns |
| t <sub>EHWH</sub>  | t <sub>WH</sub>  | WE# Hold from<br>CE# High                          |         | 10  |                                                | 10                                 |     | 10  |     | 10                                                           |     | ns |
| tEHEL              | t <sub>CPH</sub> | CE# Pulse<br>Width High                            |         | 10  | ,                                              | 20                                 |     | 20  |     | 20                                                           |     | ns |
| t <sub>EHQV1</sub> |                  | Duration of Word/<br>Byte Programming<br>Operation | 2, 5    | 6   |                                                | 6                                  |     | 6   |     | 6                                                            |     | μS |
| t <sub>EHQV2</sub> |                  | Duration of Erase<br>Operation (Boot)              | 2, 5, 6 | 0.3 |                                                | 0.3                                |     | 0.3 |     | 0.3                                                          |     | s  |
| t <sub>EHQV3</sub> |                  | Duration of Erase<br>Operation<br>(Parameter)      | 2, 5    | 0.3 |                                                | 0.3                                |     | 0.3 |     | 0.3                                                          |     | S  |
| t <sub>EHQV4</sub> |                  | Duration of Erase<br>Operation (Main)              | 2, 5    | 0.6 |                                                | 0.6                                |     | 0.6 |     | 0.6                                                          | 1   | s  |
| t <sub>QWL</sub>   | t <sub>VPH</sub> | V <sub>PP</sub> Hold from<br>Valid SRD             | 5, 8    | 0   |                                                | 0                                  |     | 0   |     | 0                                                            |     | ns |
| <sup>t</sup> QVPH  | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold<br>from Valid SRD         | 6, 8    | 0   |                                                | 0                                  |     | 0   |     | 0                                                            |     | ns |
| t <sub>PHBR</sub>  |                  | Boot-Block<br>Relock Delay                         | 7       |     | 100                                            |                                    | 100 |     | 100 |                                                              | 100 | ns |



#### AC CHARACTERISTICS—CE#-CONTROLLED WRITE OPERATIONS(1, 9) (Continued)

#### NOTES:

1. Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.

2, 3, 4, 5, 6, 7, 8: Refer to AC Characteristics notes for WE#-Controlled Write Operations.

9. Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during Read Mode.

10. See High Speed Test Configuration.

11. See Standard Test Configuration.

# EXTENDED TEMPERATURE OPERATION AC CHARACTERISTICS—CE#-CONTROLLED WRITE OPERATIONS(1,9)

|                    |                  | Versions                                       |         | T28F400F |     | Unit |
|--------------------|------------------|------------------------------------------------|---------|----------|-----|------|
| Syml               | bol              | Parameter                                      | Notes   | Min      | Max | J 01 |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                               |         | 80       |     | ns   |
| t <sub>PHEL</sub>  | t <sub>PS</sub>  | RP# High Recovery to CE# Going Low             |         | 220      |     | ns   |
| twLEL              | tws              | WE# Setup to CE# Going Low                     |         | 0        |     | ns   |
| t <sub>PHHEH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to CE# Going High    | 6, 8    | 100      |     | ns   |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE# Going High        | 5, 8    | 100      |     | ns   |
| t <sub>AVEH</sub>  | tAS              | Address Setup to CE# Going High                | 3       | 60       |     | ns   |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to CE# Going High                   | 4       | 60       |     | ns   |
| t <sub>ELEH</sub>  | t <sub>CP</sub>  | CE# Pulse Width                                |         | 60       |     | ns   |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from CE# High                        | 4       | 0        |     | ns   |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold from CE# High                     | 3       | 10       |     | ns   |
| t <sub>EHWH</sub>  | t <sub>WH</sub>  | WE# Hold from CE# High                         |         | 10       |     | ns   |
| t <sub>EHEL</sub>  | tCPH             | CE# Pulse Width High                           |         | 20       |     | ns   |
| t <sub>EHQV1</sub> |                  | Duration of Word/Byte Programming<br>Operation | 2, 5    | 7        |     | μs   |
| t <sub>EHQV2</sub> |                  | Duration of Erase Operation (Boot)             | 2, 5, 6 | 0.4      |     | s    |
| t <sub>EHQV3</sub> |                  | Duration of Erase Operation (Parameter)        | 2, 5    | 0.4      |     | s    |
| t <sub>EHQV4</sub> |                  | Duration of Erase Operation (Main)             | 2, 5    | 0.7      |     | S    |
| tQWL               | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD            | 5, 8    | 0        |     | ns   |
| tQVPH              | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD        | 6, 8    | 0        |     | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                        | 7       |          | 100 | ns   |

#### NOTES:

2, 3, 4, 5, 6, 7, 8: Refer to AC Characteristics for WE#-Controlled Write Operations.

10. See Standard Test Configuration.

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.

<sup>9.</sup> Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during Read Mode.





#### ORDERING INFORMATION







#### **ADDITIONAL INFORMATION**

| Order Number | Document                                                                          |
|--------------|-----------------------------------------------------------------------------------|
| 292130       | AB-57 "Boot Block Architecture for Safe Firmware Updates"                         |
| 292154       | AB-60 "2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family"                    |
| 292098       | AP-363 "Extended Flash BIOS Concepts for Portable Computers"                      |
| 292148       | AP-604 "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM" |
| 290448       | 28F002/200BX-T/B 2-Mbit Boot Block Flash Memory Datasheet                         |
| 290449       | 28F002/200BL-T/B 2-Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290450       | 28F004/400BL-T/B 4-Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290531       | 2-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290530       | 4-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290539       | 8-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |

#### **REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -001   | Original Version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| -002   | Removed -70 speed bin. Integrated -70 characteristics into -60 speed bin. Added Extended Temperature characteristics. Modified BYTE# Timing Diagram.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -003   | PWD renamed to RP# for JEDEC standardization compatibility.  Combined V <sub>CC</sub> Read current for 28F400BX Word-Wide Mode and Byte-Wide Mode and 28F004BX Byte-Wide Mode in DC Characteristics tables.  Added Boot Black Unlock Current specifications in DC Characteristics tables.  Improved I <sub>CCR</sub> and I <sub>CCW</sub> in DC Characteristics: Extended Temperature Operation table.  Improved t <sub>AVAV</sub> , t <sub>AVQV</sub> , t <sub>ELQV</sub> , t <sub>ELQV</sub> , t <sub>EHQZ</sub> , t <sub>GHQZ</sub> , t <sub>GHQZ</sub> and t <sub>FLQZ</sub> specifications for Extended Temperature Operations AC Characteristics—Read and Write Operations.                                                                                  |
| -004   | Added specifications for 120 ns access time product version; 28F400BX-120 and 28F004BX-120.  Included permanent change on write timing parameters for -80 ns product versions. Write pulse width (t <sub>WP</sub> and t <sub>CP</sub> ) increases from 50 ns to 60 ns. Write pulse width high (t <sub>WPH</sub> and t <sub>CPH</sub> ) decreases from 30 ns to 20 ns. Total write cycle time (t <sub>WC</sub> ) remains unchanged.  Added I <sub>CCR</sub> test condition note for typical frequency value in DC Characteristics table.  Added I <sub>OH</sub> CMOS specification.  Added 28F400BX interface to Intel386 <sup>TM</sup> EX Embedded Processor block diagram.  Added description of how to design for upgrading to SmartVoltage Boot Block products. |

# intel<sub>®</sub>

## 28F400BL-T/B, 28F004BL-T/B 4-MBIT (256K x 16, 512K x 8) LOW POWER BOOT BLOCK FLASH MEMORY FAMILY

- Low Voltage Operation for Very Low Power Portable Applications
  - $-V_{CC} = 3.0V 3.6V$  Read
  - $-V_{CC} = 3.15V-3.6V$  Program/Erase
- Expanded Temperature Range — -20°C to 70°C
- x8/x16 Input/Output Architecture
  - 28F400BL-T, 28F400BL-B
  - For High Performance and High Integration 16-bit and 32-bit CPUs
- x8-only Input/Output Architecture
  - 28F004BL-T, 28F004BL-B
  - For Space Constrained 8-bit Applications
- Upgradeable to Intel's SmartVoltage Products
- Optimized High Density Blocked Architecture
  - One 16-KB Protected Boot Block
  - Two 8-KB Parameter Blocks
  - One 96-KB Main Block
  - Three 128-KB Main Blocks
  - Top or Bottom Boot Locations
- Extended Cycling Capability
   10,000 Block Erase Cycles
- Automated Word/Byte Write and Block Erase
  - Command User Interface
  - Status Registers
  - Erase Suspend Capability

- SRAM-Compatible Write Interface
- Automatic Power Savings Feature
   0.8 mA typical I<sub>CC</sub> Active Current in Static Operation
- Very High-Performance Read
  - 150 ns Maximum Access Time
  - 65 ns Maximum Output Enable Time
- Low Power Consumption— 15 mA Typical Active Read Current
- Reset/Deep Power-Down Input:
  - 0.2 μA I<sub>CC</sub> Typical
  - Acts as Reset for Boot Operations
- Write Protection for Boot Block
- Hardware Data Protection Feature
  - Erase/Write Lockout During Power Transitions
- Industry Standard Surface Mount Packaging
  - 28F400BL: JEDEC ROM

Compatible

44-Lead PSOP

56-Lead TSOP

- 28F004BL: 40-Lead TSOP
- 12V Word/Byte Write and Block Erase — V<sub>PP</sub> = 12V ±5% Standard
- ETOX III Flash Technology — 3.3V Read



Intel's 4-Mbit Low Power Flash Memory Family is an extension of the Boot Block Architecture which includes block-selective erasure, automated write and erase operations and standard microprocessor interface. The 4-Mbit Low Power Flash Memory Family enhances the Boot Block Architecture by adding more density and blocks, x8/x16 input/output control, very low power, very high speed, an industry standard ROM compatible pinout and surface mount packaging. The 4-Mbit low power flash family opens a new capability for 3V battery-operated portable systems and is an easy upgrade to Intel's 2-Mbit Low Power Boot Block Flash Memory Family.

The Intel 28F400BL-T/B are 16-bit wide low power flash memory offerings. These high density flash memories provide user selectable bus operation for either 8-bit or 16-bit applications. The 28F400BL-T and 28F400BL-B are 4,194,304-bit non-volatile memories organized as either 524,288 bytes or 262,144 words of information. They are offered in 44-Lead plastic SOP and 56-Lead TSOP packages. The x8/x16 pinout conforms to the industry standard ROM/EPROM pinout. The Intel 28F004BL-T/B are 8-bit wide low power flash memories with 4,194,304 bits organized as 524,288 bytes of information. They are offered in a 40-Lead TSOP package, which is ideal for space-constrained portable systems.

These devices use an integrated Command User Interface (CUI) and Write State Machine (WSM) for simplified word/byte write and block erasure. The 28F400BL-T/28F004BL-T provide block locations compatible with Intel's Low Voltage MCS-186 family, i386™, i486™ microprocessors. The 28F400BL-B/28F004BL-B provide compatibility with Intel's 80960KX and 80960SX families as well as other low voltage embedded microprocessors.

The boot block includes a data protection feature to protect the boot code in critical applications. With a maximum access time of 150 ns, these 4-Mbit low power flash devices are very high performance memories at 3.3V which interface to a wide range of low voltage microprocessors and microcontrollers. A deep power-down mode lowers the total  $V_{CC}$  power consumption to 0.66  $\mu$ W which is critical in handheld battery powered systems such as Handy Cellular Phones. For very high speed applications using a 5V supply, refer to the Intel 28F400BX-T/B, 28F004BX-T/B 4-Mbit Boot Block Flash Memory family datasheet.

Manufactured on Intel's 0.8 micron ETOX III process, the 4-Mbit flash memory family provides world class quality, reliability and cost-effectiveness at the 4 Mbit density level.



#### 1.0 PRODUCT FAMILY OVERVIEW

Throughout this datasheet 28F400BL refers to both the 28F400BL-T and 28F400BL-B devices and 28F004BL refers to both the 28F004BL-T and 28F004BL-B devices. The 4-Mbit flash family refers to both the 28F400BL and 28F004BL products. This datasheet comprises the specifications for four separate products in the 4-Mbit flash family, Section 1 provides an overview of the 4-Mbit flash family including applications, pinouts and pin descriptions. Sections 2 and 3 describe in detail the specific memory organizations for the 28F400BL and 28F004BL products respectively, Section 4 combines a description of the family's principles of operations. Finally section 5 describes the family's operating specifications.

#### **Product Family**

| x8/x16 Products | x8-Only Products |
|-----------------|------------------|
| 28F400BL-T      | 28F004BL-T       |
| 28F400BL-B      | 28F004BL-B       |

#### 1.1 Designing for Upgrade to SmartVoltage Products

Today's high volume boot block products are upgradeable to Intel's SmartVoltage boot block products that provide program and erase operation at 5V or 12V  $V_{PP}$  and read operation at 3V or 5V  $V_{CC}$ . Intel's SmartVoltage boot block products provide the following enhancements to the boot block products described in this datasheet:

- 1. DU pin is replaced by WP# to provide a means to lock and unlock the boot block with logic signals.
- 2. 5V Program/Erase operation uses proven program and erase techniques with 5V  $\pm\,10\,\%$  applied to Vpp.
- 3. Enhanced circuits optimize performance at 3.3V V<sub>CC</sub>.

Refer to the 2, 4 or 8Mbit SmartVoltage Boot Block Flash Memory datasheets for complete specifications.

When you design with 12V V<sub>PP</sub> boot block products you should provide the capability in your board design to upgrade to SmartVoltage products.

Follow these guidelines to ensure compatibility:

- Connect DU (WP# on SmartVoltage products) to a control signal or to V<sub>CC</sub> or GND.
- 2. If adding a switch on V<sub>PP</sub> for write protection, switch to GND for complete write protection.
- 3. Allow for connecting 5V to V<sub>PP</sub> and disconnect 12V from the V<sub>PP</sub> line, if desired.

#### 1.2 Main Features

The 28F400BL/28F004BL boot block flash memory family is a very high performance 4-Mbit (4,194,304 bit) memory family organized as either 256 KWords (262,144 words) of 16 bits each or 512 Kbytes (524,288 bytes) of 8 bits each.

Seven Separately Erasable Blocks including a Hardware-Lockable boot block (16,384 Bytes), two parameter blocks (8,192 Bytes each) and four main blocks (1 block of 98,304 Bytes and 3 blocks of 131,072 Bytes) are included on the 4-Mbit family. An erase operation erases one of the main blocks in typically 3.4 seconds and the boot or parameter blocks in typically 2.0 seconds, independent of the remaining blocks. Each block can be independently erased and programmed 10,000 times.

The Boot Block is located at either the top (-T) or the bottom (-B) of the address map in order to accommodate different microprocessor protocols for boot code location. The hardware lockable boot block provides the most secure code storage. The boot block is intended to store the kernel code required for booting-up a system. When the RP# pin is between 11.4V and 12.6V the boot block is unlocked and program and erase operations can be performed. When the RP# pin is at or below 4.1V the boot block is locked and program and erase operations to the boot block are ignored.

The 28F400BL products are available in the ROM/EPROM compatible pinout and housed in the 44-Lead PSOP (Plastic Small Outline) package and the 56-Lead TSOP (Thin Small Outline, 1.2mm thick) package as shown in Figures 3 and 4, The 28F004BL products are available in the 40-Lead TSOP (1.2mm thick) package as shown in Figure 5.

The Command User Interface (CUI) serves as the interface between the microprocessor or microcontroller and the internal operation of the 28F400BL and 28F004BL flash memory products.

Program and Erase Automation allow program and erase operations to be executed using a two-write command sequence to the CUI. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verifications, thereby unburdening the microprocessor or microcontroller. Writing of memory data is performed in word or byte increments for the 28F400BL family and in byte increments for the 28F004BL family typically within 11  $\mu$ s.



The **Status Register (SR)** indicates the status of the WSM and whether the WSM successfully completed the desired program or erase operation.

Maximum Access Time of 150 ns (TACC) is achieved over the commercial temperature range (0°C to +70°C), V<sub>CC</sub> supply voltage range (3.0V to 3.6V, 4.5V to 5.5V) and 50 pF output load.

 $l_{pp}$  Program current is 40 mA for x16 operation and 30 mA for x8 operation.  $l_{pp}$  Erase current is 30 mA maximum.  $V_{pp}$  erase and programming voltage is 11.4V to 12.6V ( $V_{pp}=12V\pm5\%$ ) under all operating conditions.

Typical I<sub>CC</sub> Active Current of 15 mA is achieved for the x16 products and the x8 products.

The 4-Mbit flash family is also designed with an Automatic Power Savings (APS) feature to minimize system battery current drain and allow for very low power designs. Once the device is accessed to read the array data, APS mode will immediately put the memory in static mode of operation where I<sub>CC</sub> active current is typically 0.8 mA until the next read is initiated.

When the CE# and RP# pins are at  $V_{CC}$  and the BYTE# pin (28F400BX-L-only) is at either  $V_{CC}$  or GND the CMOS Standby mode is enabled where  $I_{CC}$  is typically 45  $\mu$ A.

A Deep Power-Down Mode is enabled when the PWD pin is at ground minimizing power consumption and providing write protection during power-up conditions. Icc current during deep power-down mode is 0.20 μA typical. An initial maximum access time or Reset Time of 600 ns is required from RP# switching until outputs are valid. Equivalently, the device has a maximum wake-up time of 1 µs until writes to the Command User Interface are recognized. When RP# is at ground the WSM is reset, the Status Register is cleared and the entire device is protected from being written to. This feature prevents data corruption and protects the code stored in the device during system reset. The system Reset pin can be tied to RP# to reset the memory to normal read mode upon activation of the Reset pin. When the CPU enters reset mode, it expects to read the contents of a memory location. Furthermore, with on-chip program/erase automation in the 4-Mbit family and the RP# functionality for data protection, when the CPU is reset and even if a program or erase command is issued, the device will not recognize any operation until RP# returns to its normal state.

For the 2SF400BL, Byte-wide or Word-wide Input/Output Control is possible by controlling the BYTE# pin. When the BYTE# pin is at a logic low the device is in the byte-wide mode (x8) and data is read and written through DQ[0:7]. During the byte-wide mode, DQ[8:14] are tri-stated and DQ15/A—1 becomes the lowest order address pin. When the BYTE# pin is at a logic high the device is in the word-wide mode (x16) and data is read and written through DQ[0:15].

#### 1.3 Applications

The 4-Mbit low power boot block flash memory family combines high density, very low power, high performance, cost-effective flash memories with blocking and hardware protection capabilities. Its flexibility and versatility will reduce costs throughout the product life cycle. Flash memory is ideal for Just-In-Time production flow, reducing system inventory and costs, and eliminating component handling during the production phase. During the product life cycle, when code updates or feature enhancements become necessary, flash memory will reduce the update costs by allowing either a user-performed code change via floppy disk or a remote code change via a serial link. The 4-Mbit flash family provides full function, blocked flash memories suitable for a wide range of applications. These applications include Extended PC BIOS and ROM-able applications storage, Handy Digital Cellular Phone program and data storage and various other low power embedded applications where both program and data storage are required.

Portable systems such as Notebook/Palmtop computers, are ideal applications for the 4-Mbit low power flash products. Portable and handheld personal computer applications are becoming more complex with the addition of power management software to take advantage of the latest microprocessor technology, the availability of ROM-based application software, pen tablet code for electronic hand writing, and diagnostic code. Figure 1 shows an example of a 28F400BL-T application.

This increase in software sophistication augments the probability that a code update will be required after the Notebook is shipped. The 4-Mbit flash products provide an inexpensive update solution for the notebook and handheld personal computers while extending their product lifetime. Furthermore, the 4-Mbit flash products' deep power-down mode provides added flexibility for these battery-operated portable designs which require operation at very low power levels.



The 4-Mbit low power flash products also provide excellent design solutions for Handy Digital Cellular Phone applications requiring low voltage supply, high performance, high density storage capability coupled with modular software designs, and a small form factor package (x8-only bus). The 4-Mbit's blocking scheme allows for an easy segmentation of the embedded code with; 16-Kbytes of Hardware-Protected Boot code, 4 Main Blocks of program code and 2 Parameter Blocks of 8-Kbytes each for frequently updatable data storage and diagnostic

messages (e.g., phone numbers, authorization codes). Figure 2 is an example of such an application with the 28F004BL-T.

These are a few actual examples of the wide range of applications for the 4-Mbit low power Boot Block flash memory family which enable system designers achieve the best possible product design. Only your imagination limits the applicability of such a versatile low power product family.



Figure 1. 28F400BL Interface to Intel386™ EX Embedded Processor



Figure 2. 28F004BL Interface to INTEL 80L188EB Low Voltage 8-bit Embedded Processor



#### 1.4 Pinouts

The 28F400BL 44-Lead PSOP pinout follows the industry standard ROM/EPROM pinout as shown in Figure 3 and provides an upgrade for the 28F200BL Low Power Boot Block flash memory family. Furthermore, the 28F400BL 56-Lead TSOP

pinout shown in Figure 4 provides density upgrades to future higher density boot block memories.

The 28F004BL 40-Lead TSOP pinout shown in Figure 5 is 100% compatible and provides a density upgrade for the 28F002BL 2-Mbit Low Power Boot Block flash memory family.



Figure 3. PSOP Lead Configuration for x8/x16 28F400BL





Figure 4. TSOP Lead Configuration for x8 28F400BL



Figure 5. TSOP Lead Configuration for x8 28F004BL



## 1.5 Pin Descriptions for x8/x16 28F400BL

| Symbol                            | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>17</sub>   | I    | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                                                |
| Ag                                | l    | <b>ADDRESS INPUT:</b> When $A_9$ is at 12V the signature mode is accessed. During this mode $A_0$ decodes between the manufacturer and device ID's. When BYTE# is at a logic low only the lower byte of the signatures are read. $DQ_{15}/A_{-1}$ is a don't care in the signature mode when BYTE# is low.                                                                                                                 |
| DQ <sub>0</sub> -DQ <sub>7</sub>  | 1/0  | <b>DATA INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the command user interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array, Intelligent Identifier and status register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled.               |
| DQ <sub>8</sub> -DQ <sub>15</sub> | 1/0  | <b>DATA INPUT/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a program command. Data is internally latched during the write and program cycles. The data pins float to tri-state when the chip is deselected or the outputs are disabled as in the byte-wide mode (BYTE# = "0"). In the byte-wide mode DQ $_{15}/A_{-1}$ becomes the lowest order address for data output on DQ $_{0}$ -DQ $_{7}$ . |
| CE#                               |      | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                                               |
| RP#                               | ı    | RESET/DEEP POWER-DOWN: Provides Three-State control. Puts the device in deep power-down mode. Locks the boot block from program/erase.                                                                                                                                                                                                                                                                                     |
|                                   |      | When RP# is at logic high level and equals 4.1V maximum the boot block is locked and cannot be programmed or erased.                                                                                                                                                                                                                                                                                                       |
|                                   |      | When RP# = 11.4V minimum the boot block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                                       |
|                                   |      | When RP# is at a logic low level the boot block is locked, the deep power-down mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions. When RP# transitions from logic low to logic high, the flash memory enters the read-array mode.                                                                                   |
| OE#                               | ı    | <b>OUTPUT ENABLE:</b> Gates the device's outputs through the data buffers during a read cycle. OE# is active low.                                                                                                                                                                                                                                                                                                          |
| WE#                               | I    | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                             |



## 1.5 Pin Descriptions for x8/x16 28F400BL (Continued)

| Symbol          | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BYTE#           |      | <b>BYTE</b> # <b>ENABLE:</b> Controls whether the device operates in the byte-wide mode (x8) or the word-wide mode (x16). BYTE# = "0" enables the byte-wide mode, where data is read and programmed on DQ $_0$ -DQ $_7$ and DQ $_{15}$ /A $_{-1}$ becomes the lowest order address that decodes between the upper and lower byte. DQ $_8$ -DQ $_{14}$ are tri-stated during the byte-wide mode. BYTE# = "1" enables the word-wide mode where data is read and programmed on DQ $_0$ -DQ $_{15}$ . |
| V <sub>PP</sub> |      | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.  Note: V <sub>PP</sub> < V <sub>PPLMAX</sub> memory contents cannot be altered.                                                                                                                                                                                                                                                                                                                    |
| V <sub>CC</sub> |      | DEVICE POWER SUPPLY (3.3V ±0.3, 5V ±10%)                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| GND             |      | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| NC              |      | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DU              |      | DON'T USE PIN: Pin should not be connected to anything.                                                                                                                                                                                                                                                                                                                                                                                                                                           |



## 1.6 Pin Descriptions for x8 28F004BL

| Symbol                           | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>18</sub>  | ı    | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                           |
| A <sub>9</sub>                   | l    | <b>ADDRESS INPUT:</b> When $A_9$ is at 12V the signature mode is accessed. During this mode $A_0$ decodes between the manufacturer and device ID's.                                                                                                                                                                                                                                                   |
| DQ <sub>0</sub> -DQ <sub>7</sub> | 1/0  | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the command user interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array, Intelligent Identifier and status register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled. |
| CE#                              |      | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE # is active low; CE # high deselects the memory device and reduces power consumption to standby levels.                                                                                                                                                                                           |
| RP#                              | ·    | RESET/DEEP POWER-DOWN: Provides Three-State control. Puts the device in deep power-down mode. Locks the Boot Block from program/erase.                                                                                                                                                                                                                                                                |
|                                  |      | When RP# is at logic high level and equals 4.1V maximum the Boot Block is locked and cannot be programmed or erased.                                                                                                                                                                                                                                                                                  |
|                                  |      | When RP# = 11.4V minimum the Boot Block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                  |
|                                  |      | When RP# is at a logic low level the Boot Block is locked, the deep power-down mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions. When RP# transitions from logic low to logic high, the flash memory enters the read-array mode.                                                              |
| OE#                              | 1    | <b>OUTPUT ENABLE:</b> Gates the device's outputs through the data buffers during a read cycle. OE # is active low.                                                                                                                                                                                                                                                                                    |
| WE#                              | .1   | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                        |
| V <sub>PP</sub>                  |      | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.  Note: Vpp < VppLMAX memory contents cannot be altered.                                                                                                                                                                                                                                                |
| V <sub>CC</sub>                  |      | DEVICE POWER SUPPLY (3.3V $\pm$ 0.3V, 5V $\pm$ 10%)                                                                                                                                                                                                                                                                                                                                                   |
| GND                              |      | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                                                                                   |
| NC                               |      | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                       |
| DU .                             |      | DON'T USE PIN: Pin should not be connected to anything.                                                                                                                                                                                                                                                                                                                                               |





Y-GATING/SENSING

96-KBYTE MAIN BLOCK 128-KBYTE MAIN BLOCK 128-KBYTE MAIN BLOCK 128-KBYTE MAIN BLOCK

8-KBYTE
PARAMETER BLOCK
8-KBYTE
PARAMETER BLOCK

16-KBYTE BOOT BLOCK WRITE STATE

MACHINE

PROGRAM/ERASE

VOLTAGE SWITCH

√ v<sub>cc</sub>

**←** GND

290450-1

Figure 6. 28F400BL Word/Byte-Wide Block Diagram

INPUT BUFFER

ADDRESS

LATCH

ADDRESS

Y-DECODER

X-DECODER



#### 2.1 28F400BL Memory Organization

#### 2.1.1 BLOCKING

The 28F400BL uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirms commands are written to the CUI. The 28F400BL is a random read/write memory, only erasure is performed by block.

# 2.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being written or erased when RP# is not at 12V. The boot block can be erased and written when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F400BL-T and 28F400BL-B.

#### 2.1.1.2 Parameter Block Operation

The 28F400BL has 2 parameter blocks (8 Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. The parameter blocks provide for more efficient memory utilization when dealing with parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F400BL-T and 28F400BL-B.

#### 2.1.1.3 Main Block Operation

Four main blocks of memory exist on the 28F400BL (3 x 128-Kbyte blocks and 1 x 96-Kbyte blocks). See the following section on Block Memory Map for the address location of these blocks for the 28F400BL-T and 28F400BL-B products.

#### 2.1.2 BLOCK MEMORY MAP

Two versions of the 28F400BL product exist to support two different memory maps of the array blocks in order to accommodate different microprocessor protocols for boot code location. The 28F400BL-T memory map is inverted from the 28F400BL-B memory map.

#### 2.1.2.1 28F400BL-B Memory Map

The 28F400BL-B device has the 16-Kbyte boot block located from 00000H to 01FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F400BL-B the first 8-Kbyte parameter block resides in memory space from 02000H to 02FFFH. The second 8-Kbyte parameter block resides in memory space from 03000H to 03FFFH. The 96-Kbyte main block resides in memory space from 04000H to 0FFFFH. The three 128-Kbyte main block resides in memory space from 10000H to 1FFFFH, 20000H to 2FFFFH and 30000H to 3FFFFH (word locations). See Figure 7.



Figure 7. 28F400BL-B Memory Map



#### 2.1.2.2 28F400BL-T Memory Map

The 28F400BL-T device has the 16-Kbyte boot block located from 3E000H to 3FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F400BX-T the first 8-Kbyte parameter block resides in memory space from 3D000H to 3DFFFH. The second 8-Kbyte parameter block resides in memory space from 3C000H to 3CFFFH. The 96-Kbyte main block resides in memory space from 30000H to 3BFFFH. The three 128-Kbyte main blocks reside in memory space from 20000H to 2FFFFH, 10000H to 1FFFFH and 00000H to 0FFFFH as shown in Figure 8.



Figure 8. 28F400BL-T Memory Map



# 3.0 28F004BL PRODUCTS DESCRIPTION



Figure 9. 28F004BL and Byte-Wide Block Diagram



#### 3.1 28F004BL Memory Organization

#### 3.1.1 BLOCKING

The 28F004BL uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirm commands are written to the CUI. The 28F004BL is a random read/write memory, only erasure is performed by block.

# 3.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being programmed or erased when RP# is not at 12V. The boot block can be erased and programmed when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while still providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F004BL-T and 28F004BL-B.

#### 3.1.1.2 Parameter Block Operation

The 28F004BL has 2 parameter blocks (8 Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. Parameter blocks provide for more efficient memory utilization when dealing with small parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F004BL-T and 28F004BL-B.

#### 3.1.1.3 Main Block Operation

Two main blocks of memory exist on the 28F004BL (3 x 128-Kbyte blocks and 1 x 96-Kbyte blocks). See the following section on Block Memory Map for the address location of these blocks for the 28F004BL-T and 28F004BL-B.

#### 3.1.2 BLOCK MEMORY MAP

Two versions of the 28F004BL product exist to support two different memory maps of the array blocks in order to accommodate different microprocessor protocols for boot code location. The 28F004BL-T memory map is inverted from the 28F004BL-B memory map.

#### 3.1.2.1 28F004BL-B Memory Map

The 28F004BL-B device has the 16-Kbyte boot block located from 00000H to 03FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F004BL-B the first 8-Kbyte parameter block resides in memory from 04000H to 05FFFH. The second 8-Kbyte parameter block resides in memory space from 06000H to 07FFFH. The 96-Kbyte main block resides in memory space from 08000H to 1FFFFH. The three 128-Kbyte main blocks reside in memory space from 20000H to 3FFFFH, 40000H to 5FFFFH and 60000H to 7FFFH. See Figure 10.



Figure 10. 28F004BL-B Memory Map



#### 3.1.2.2 28F004BL-T Memory Map

The 28F004BL-T device has the 16-Kbyte boot block located from 7C000H to 7FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F004BL-T the first 8-Kbyte parameter block resides in memory space from 7A000H to 7BFFFH. The second 8-Kbyte parameter block resides in memory space from 78000H to 79FFFH. The 96-Kbyte main block resides in memory space from 60000H to 7FFFH. The three 128-Kbyte main blocks reside in memory space from 40000H to 5FFFFH, 20000H to 3FFFFH and 00000H to 1FFFFH.



Figure 11. 28F004BL-T Memory Map

# 4.0 PRODUCT FAMILY PRINCIPLES OF OPERATION

Flash memory augments EPROM functionality with in-circuit electrical write and erase. The 4-Mbit flash memory family utilizes a Command User Interface (CUI) and internally generated and timed algorithms to simplify write and erase operations.

The CUI allows for fixed power supplies during erasure and programming, and maximum EPROM compatibility.

In the absence of high voltage on the V<sub>PP</sub> pin, the 4-Mbit flash family will only successfully execute the following commands: Read Array, Read Status Register, Clear Status Register and Intelligent Identifier mode. The device provides standard EPROM read, standby and output disable operations. Manufacturer Identification and Device Identification data can be accessed through the CUI or through the standard EPROM A9 high voltage access (V<sub>ID</sub>) (for PROM programmer equipment).

The same EPROM read, standby and output disable functions are available when high voltage is applied to the  $V_{PP}$  pin. In addition, high voltage on  $V_{PP}$  allows write and erase of the device. All functions associated with altering memory contents: write and erase, Intelligent Identifier read and Read Status are accessed via the CUI.

The purpose of the Write State Machine (WSM) is to completely automate the write and erasure of the device. The WSM will begin operation upon receipt of a signal from the CUI and will report status back through a Status Register. The CUI will handle the WE# interface to the data and address latches, as well as system software requests for status while the WSM is in operation.

#### 4.1 28F400BL Bus Operations

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles.



Table 1. Bus Operations for WORD-WIDE Mode (BYTE# =  $V_{IH}$ )

| Mode                            | Notes    | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-15</sub> |
|---------------------------------|----------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|
| Read                            | 1, 2, 3  | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Doụt               |
| Output Disable                  |          | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | X               | Х               | High Z             |
| Standby                         |          | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х               | High Z             |
| Deep Power-Down                 | 9        | V <sub>IL</sub> | Х               | Х               | X               | Х               | Х               | Х               | High Z             |
| Intelligent Identifier (Mfr)    | 4        | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | VIH             | V <sub>ID</sub> | V <sub>IL</sub> | Х               | 0089H              |
| Intelligent Identifier (Device) | 4, 5, 10 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | X               | 4470H<br>4471H     |
| Write                           | 6, 7, 8  | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х               | D <sub>IN</sub>    |

#### Table 2. Bus Operations for BYTE-WIDE Mode (BYTE# = VII)

|                                    |          |                   |                 |                 |                 |                 |                 |                 | · IL/           |                   |                    |
|------------------------------------|----------|-------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|--------------------|
| Mode                               | Notes    | RP#               | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | A <sub>-1</sub> | V <sub>PP</sub> | DQ <sub>0-7</sub> | DQ <sub>8-14</sub> |
| Read                               | 1, 2, 3  | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | D <sub>OUT</sub>  | High Z             |
| Output Disable                     |          | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | High Z            | High Z             |
| Standby                            |          | V <sub>IH</sub>   | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х               | Х               | High Z            | High Z             |
| Deep Power-Down                    |          | · V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х               | Х               | Х               | High Z            | High Z             |
| Intelligent Identifier<br>(Mfr)    | 4        | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х               | х               | 89H               | High Z             |
| Intelligent Identifier<br>(Device) | 4, 5, 10 | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | Х               | 70H<br>71H        | High Z             |
| Write                              | 6, 7, 8  | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IH</sub> | VIL             | Х               | Х               | Х               | Х               | D <sub>IN</sub>   | High Z             |

- 1. Refer to DC Characteristics.
- 2. X can be  $V_{IL}$  or  $V_{IH}$  for control pins and addresses,  $V_{PPL}$  or  $V_{PPH}$  for  $V_{PP}$ . 3. See DC Characteristics for  $V_{PPL}$ ,  $V_{PPH}$ ,  $V_{HH}$ ,  $V_{ID}$  voltages.
- 4. Manufacturer and Device codes may also be accessed via a CUI write sequence.  $A_1-A_{17}=V_{IL}$ . 5. Device ID = 4470H for 28F400BL-T and 4471H for 28F400BL-B.
- 6. Refer to Table 4 for valid DIN during a write operation.
- 7. Command writes for Block Erase or Word/Byte Write are only executed when V<sub>PP</sub> = V<sub>PPH</sub>.
- 8. To write or erase the boot block, hold RP# at VHH.
- 9. RP# must be at GND  $\pm 0.2$ V to meet the 1.2  $\mu$ A maximum deep power-down current.
- 10. The device ID codes are identical to those of the 28F400BX 5V version and SmartVoltage equivalent.



#### 4.2 28F004BL Bus Operations

#### Table 3. Bus Operations

| Mode                            | Notes    | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-7</sub> |
|---------------------------------|----------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|
| Read                            | 1, 2, 3  | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х               | D <sub>OUT</sub>  |
| Output Disable                  |          | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | High Z            |
| Standby                         | ,        | V <sub>IH</sub> | V <sub>IH</sub> | Х               | X               | Х               | Х               | Х               | High Z            |
| Deep Power-Down                 | 9        | V <sub>IL</sub> | Х               | Х               | Х               | X               | Х               | Х               | High Z            |
| Intelligent Identifier (Mfr)    | 4        | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х               | 89H               |
| Intelligent Identifier (Device) | 4, 5, 10 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | 78H<br>79H        |
| Write                           | 6, 7, 8  | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | VIL             | Х               | Х               | Х               | D <sub>IN</sub>   |

#### NOTES:

- 1. Refer to DC Characteristics.
- 2. X can be VIL or VIH for control pins and addresses, VPPL or VPPH for VPP.
- 3. See DC Characteristics for VPPL, VPPH, VHH, VID voltages.
- 4. Manufacturer and Device codes may also be accessed via a CUI write sequence. A<sub>1</sub>-A<sub>8</sub>, A<sub>10</sub>-A<sub>18</sub> = V<sub>II</sub>.
- 5. Device ID = 78H for 28F004BL-T and 79H for 28F004BL-B.
- 6. Refer to Table 4 for valid DIN during a write operation.
- 7. Command writes for Block erase or byte program are only executed when VPP = VPPH.
- 8. Program or erase the Boot block by holding RP# at VHH.
- 9. RP# must be at GND  $\pm 0.2$ V to meet the 1.2  $\mu$ A maximum deep power-down current.
- 10. The device ID codes are identical to those of the 28F004BX 5V version and SmartVoltage equivalent.

#### 4.3 Read Operations

The 4-Mbit flash family has three user read modes; Array, Intelligent Identifier, and Status Register. Status Register read mode will be discussed in detail in the "Write Operations" section.

During power-up conditions ( $V_{CC}$  supply ramping), it takes a maximum of 600 ns from  $V_{CC}$  at 3.0V minimum to obtain valid data on the outputs.

#### 4.3.1 READ ARRAY

If the memory is not in the Read Array mode, it is necessary to write the appropriate read mode command to the CUI. The 4-Mbit flash family has three control functions, all of which must be logically active, to obtain data at the outputs. Chip-Enable CE# is the device selection control. Power-Down RP# is the device power control. Output-Enable OE# is the DATA INPUT/OUTPUT (DQ[0:15] or DQ[0:7]) direction control and when active is used to drive data from the selected memory onto the I/O bus.

#### 4.3.1.1 Output Control

With OE# at logic-high level (V<sub>IH</sub>), the output from the device is disabled and data input/output pins (DQ[0:15] or DQ[0:7] are tri-stated. Data input is then controlled by WE#.

#### 4.3.1.2 Input Control

With WE# at logic-high level (V<sub>IH</sub>), input to the device is disabled. Data Input/Output pins (DQ[0:15] or DQ[0:7]) are controlled by OE#.

#### 4.3.2 INTELLIGENT IDENTIFIERS

#### 28F400BL PRODUCTS

The manufacturer and device codes are read via the CUI or by taking the A9 pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 0089H, and location 00001H outputs the device code; 4470H for 28F400BL-T, 4471H for 28F4001BL-B. When  ${\bf BYTE}\#$  is at a logic low only the lower byte of the above signatures is read and  ${\bf DQ}_{15}/{\bf A}_{-1}$  is a "don't care" during Intelligent Identifier mode. A read array command must be written to the CUI to return to the read array mode.



#### 28F004BL PRODUCTS

The manufacturer and device codes are also read via the CUI or by taking the A9 pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 89H, and location 00001H outputs the device code; 78H for 28F004BL-T, 79H for 28F004BL-B.

#### 4.4 Write Operations

Commands are written to the CUI using standard microprocessor write timings. The CUI serves as the interface between the microprocessor and the internal chip operation. The CUI can decipher Read Array, Read Intelligent Identifier, Read Status Register, Clear Status Register, Erase and Program commands. In the event of a read command, the CUI simply points the read path at either the array, the Intelligent Identifier, or the status register depending on the specific read command given. For a program or erase cycle, the CUI informs the write state machine that a write or erase has been requested. During a program cycle, the Write State Machine will control the program sequences and the CUI will only respond to status reads. During an erase cycle, the CUI will respond to status reads and erase suspend. After the Write State Machine has completed its task, it will allow the CUI to respond to its full command set. The CUI will stay in the current command state until the microprocessor issues another command.

The CUI will successfully initiate an erase or write operation only when V<sub>PP</sub> is within its voltage range. Depending upon the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable, available only when memory updates are desired. The system designer can also choose to "hard-wire" V<sub>PP</sub> to 12V. The 4-Mbit flash memory family is designed to accommodate either design practice. It is recommended that RP# be tied to logical Reset for data protection during unstable CPU reset function as described in the "Product Family Overview" section.

#### 4.4.1 BOOT BLOCK WRITE OPERATIONS

In the case of Boot Block modifications (write and erase), RP# is set to  $V_{HH}=12V$  typically, in addition to  $V_{PP}$  at high voltage.

However, if RP# is not at V<sub>HH</sub> when a program or erase operation of the boot block is attempted, the corresponding status register bit (Bit 4 for Program and Bit 5 for Erase, refer to Table 5 for Status Register Definitions) is set to indicate the failure to complete the operation.

#### 4.4.2 COMMAND USER INTERFACE (CUI)

The Command User Interface (CUI) serves as the interface to the microprocessor. The CUI points the read/write path to the appropriate circuit block as described in the previous section. After the WSM has completed its task, it will set the WSM Status bit to a "1", which will also allow the CUI to respond to its full command set. Note that after the WSM has returned control to the CUI, the CUI will remain in its current state.

#### 4.4.2.1 Command Set

| Command<br>Codes | Device Mode                |
|------------------|----------------------------|
| 00               | Invalid/Reserved           |
| 10               | Alternate Program Setup    |
| 20               | Erase Setup                |
| 40               | Program Setup              |
| 50               | Clear Status Register      |
| 70               | Read Status Register       |
| 90               | Intelligent Identifier     |
| B0               | Erase Suspend              |
| D0               | Erase Resume/Erase Confirm |
| · FF             | Read Array                 |

#### 4.4.2.2 Command Function Descriptions

Device operations are selected by writing specific commands into the CUI. Table 4 below defines the 4-Mbit flash memory family commands.



**Table 4. Command Definitions** 

| Command                                  | Bus<br>Cycles | Notes | First     | Bus Cycle |      | Second Bus Cycle |         |      |  |
|------------------------------------------|---------------|-------|-----------|-----------|------|------------------|---------|------|--|
|                                          | Req'd         | 8     | Operation | Address   | Data | Operation        | Address | Data |  |
| Read Array                               | 1             | 1     | Write     | Х         | FFH  |                  |         |      |  |
| Intelligent Identifier                   | 3             | 2, 4  | Write     | Х         | 90H  | Read             | IA      | IID  |  |
| Read Status Register                     | 2             | 3     | Write     | Х         | 70H  | Read             | Х       | SRD  |  |
| Clear Status Register                    | 1             |       | Write     | Х         | 50H  |                  |         |      |  |
| Erase Setup/Erase Confirm                | 2             | 5     | Write     | ВА        | 20H  | Write            | ВА      | D0H  |  |
| Word/Byte Write<br>Setup/Write           | 2             | 6, 7  | Write     | WA        | 40H  | Write            | WA      | WD   |  |
| Erase Suspend/Erase Resume               | 2             |       | Write     | Х         | вон  | Write            | Х       | D0H  |  |
| Alternate Word/Byte Write<br>Setup/Write | 2             | WD    | 2, 3, 7   | Write     | WA   | 10H              | Write   | WA   |  |

#### NOTES:

- 1. Bus operations are defined in Tables 1, 2, 3.
- 2. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
- 3. SRD = Data read from Status Register.
- 4. IID = Intelligent Identifier Data.

Following the Intelligent Identifier command, two read operations access manufacturer and device codes.

- 5. BA = Address within the block being erased.
- 6. WA = Address to be written.
- WD = Data to be written at location WA.
- 7. Either 40H or 10H commands is valid.
- 8. When writing commands to the device the upper data bus  $[DQ_8-DQ_{15}] = X$  (28F400BL-only) which is either  $V_{CC}$  or  $V_{SS}$  to avoid burning additional current.

#### Invalid/Reserved

These are unassigned commands. It is not recommended that the customer use any command other than the valid commands specified above. Intel reserves the right to redefine these codes for future functions.

#### Read Array (FFH)

This single write command points the read path at the array. If the host CPU performs a CE#/OE# controlled read immediately following a two-write sequence that started the WSM, then the device will output status register contents. If the Read Array command is given after Erase Setup the device is reset to read the array. A two Read Array command sequence (FFH) is required to reset to Read Array after Program Setup.

#### Intelligent Identifier (90H)

After this command is executed, the CUI points the output path to the Intelligent Identifier circuits. Only Intelligent Identifier values at addresses 0 and 1 can be read (only address A0 is used in this mode, all other address inputs are ignored).

#### Read Status Register (70H)

This is one of the two commands that is executable while the state machine is operating. After this command is written, a read of the device will output the contents of the status register, regardless of the address presented to the device.

The device automatically enters this mode after program or erase has completed.

#### Clear Status Register (50H)

The WSM can only set the Program Status and Erase Status bits in the status register, it can not clear them. Two reasons exist for operating the status register in this fashion. The first is a synchronization. The WSM does not know when the host CPU has read the status register, therefore it would not know when to clear the status bits. Secondly, if the CPU is programming a string of bytes, it may be more efficient to query the status register after programming the string. Thus, if any errors exist while programming the string, the status register will return the accumulated error status.





## Program Setup (40H or 10H)

This command simply sets the CUI into a state such that the next write will load the address and data registers. Either 40H or 10H can be used for Program Setup. Both commands are included to accommodate efforts to achieve an industry standard command code set.

## **Program**

The second write after the program setup command, will latch addresses and data. Also, the CUI initiates the WSM to begin execution of the program algorithm. While the WSM finishes the algorithm, the device will output Status Register contents. Note that the WSM cannot be suspended during programming.

## Erase Setup (20H)

Prepares the CUI for the Erase Confirm command. No other action is taken. If the next command is not an Erase Confirm command then the CUI will set both the Program Status and Erase Status bits of the Status Register to a "1", place the device into the Read Status Register state, and wait for another command.

## Erase Confirm (D0H)

If the previous command was an Erase Setup command, then the CUI will enable the WSM to erase, at the same time closing the address and data latches, and respond only to the Read Status Register and Erase Suspend commands. While the WSM is executing, the device will output Status Register data when OE# is toggled low. Status Register data can only be updated by toggling either OE# or CE# low.

## Erase Suspend (B0H)

This command only has meaning while the WSM is executing an Erase operation, and therefore will only be responded to during an erase operation. After this command has been executed, the CUI will initiate the WSM to suspend Erase operations, and then return to responding to only Read Status Register or to the Erase Resume commands. Once the WSM has reached the Suspend state, it will set an output into the CUI which allows the CUI to respond to the Read Array, Read Status Register, and Erase Resume commands. In this mode, the CUI will not respond to any other commands. The WSM will also set the WSM Status bit to a "1". The WSM will con-

tinue to run, idling in the SUSPEND state, regardless of the state of all input control pins, with the exclusion of RP#. RP# low will immediately shut down the WSM and the remainder of the chip.

## Erase Resume (D0H)

This command will cause the CUI to clear the Suspend state and set the WSM Status bit to a "0", but only if an Erase Suspend command was previously issued. Erase Resume will not have any effect in all other conditions.

## 4.4.3 STATUS REGISTER

The 4 Mbit flash family contains a status register which may be read to determine when a program or erase operation is complete, and whether that operation completed successfully. The status register may be read at any time by writing the Read Status command to the CUI. After writing this command, all subsequent Read operations output data from the status register until another command is written to the CUI. A Read Array command must be written to the CUI to return to the Read Array mode.

The status register bits are output on DQ[0:7] whether the device is in the byte-wide (x8) or word-wide (x16) mode for the 28F400BL. In the word-wide mode the upper byte, DQ[8:15] is set to 00H during a Read Status command. In the byte-wide mode, DO[8:14] is tri-stated and DQ15/A-1 retains the low order address function.

It should be noted that the contents of the status register are latched on the falling edge of OE# or CE# whichever occurs last in the read cycle. This prevents possible bus errors which might occur if the contents of the status register change while reading the status register. CE# or OE# must be toggled with each subsequent status read, or the completion of a program or erase operation will not be evident.

The Status Register is the interface between the microprocessor and the Write State Machine (WSM). When the WSM is active, this register will indicate the status of the WSM, and will also hold the bits indicating whether or not the WSM was successful in performing the desired operation. The WSM sets status bits "Three" through "Seven" and clears bits "Six" and "Seven", but cannot clear status bits "Three" through "Five". These bits can only be cleared by the controlling CPU through the use of the Clear Status Register command.



## 4.4.3.1 Status Register Bit Definition

**Table 5. Status Register Definitions** 



## NOTES:

SR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

SR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

SR.4 = PROGRAM STATUS

1 = Error in Byte/Word Program

0 = Successful Byte/Word Program

SR.3 = V<sub>PP</sub> STATUS

1 = VPP Low Detect; Operation Abort

 $0 = V_{PP} OK$ 

Write State Machine Status bit must first be checked to determine byte/word program or block erase completion, before the Program or Erase Status bits are checked for success.

When Erase Suspend is issued, WSM halts execution and sets both WSMS and ESS bits to "1". ESS bit remains set to "1" until an Erase Resume command is issued.

When this bit is set to "1". WSM has applied the maximum number of erase pulses to the block and is still unable to successfully perform an erase verify.

When this bit is set to "1", WSM has attempted but failed to Program a byte or word.

The V<sub>PP</sub> Status bit unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM interrogates the V<sub>PP</sub> level only after the byte write or block erase command sequences have been entered and informs the system if V<sub>PP</sub> has not been switched on. The V<sub>PP</sub> Status bit is not guaranteed to report accurate feedback between V<sub>PPL</sub> and V<sub>PPH</sub>.

SR.2-SR.0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use and should be masked out when polling the Status Register.

## 4.4.3.2 Clearing the Status Register

Certain bits in the status register are set by the write state machine, and can only be reset by the system software. These bits can indicate various failure conditions. By allowing the system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several bytes or erasing multiple blocks in sequence). The status register may then be read to determine if an error occurred during that programming or erasure series. This adds flexibility to the way the device may be programmed or erased. To clear the status register, the Clear Status Register command is written to the CUI. Then, any other command may be issued to the CUI. Note again that before a read cycle can be initiated, a Read command must be written to the CUI to specify whether the read data is to come from the array, status register, or Intelligent Identifier.

## 4.4.4 PROGRAM MODE

Program is executed by a two-write sequence. The Program Setup command is written to the CUI followed by a second write which specifies the address and data to be programmed. The write state machine will execute a sequence of internally timed events to:

- program the desired bits of the addressed memory word (byte), and
- verify that the desired bits are sufficiently programmed.

Programming of the memory results in specific bits within a byte or word being changed to a "0".

If the user attempts to program "1"s, there will be no change of the memory cell content and no error occurs.



Similar to erasure, the status register indicates whether programming is complete. While the program sequence is executing, bit 7 of the status register is a "0". The status register can be polled by toggling either CE# or OE# to determine when the program sequence is complete. Only the Read Status Register command is valid while programming is active.

When programming is complete, the status bits, which indicate whether the program operation was successful, should be checked. If the programming operation was unsuccessful, Bit 4 of the status register is set to a "1" to indicate a Program Failure. If Bit 3 is set then V<sub>PP</sub> was not within acceptable limits, and the WSM will not execute the programming sequence.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after programming is completed; however, it must be recognized that reads from the memory, status register, or Intelligent Identifier cannot be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 12 shows a system software flowchart for device byte programming operation. Figure 13 shows a similar flowchart for device word programming operation (28F400BL-only).

## 4.4.5 ERASE MODE

Erasure of a single block is initiated by writing the Erase Setup and Erase Confirm commands to the CUI, along with the addresses, A[12:17] for the 28F400BL or A[12:18] for the 28F004BL, identifying the block to be erased. These addresses are latched internally when the Erase Confirm command is issued. Block erasure results in all bits within the block being set to "1".

The WSM will execute a sequence of internally timed events to:

- 1. program all bits within the block
- verify that all bits within the block are sufficiently programmed
- 3. erase all bits within the block and
- verify that all bits within the block are sufficiently erased

While the erase sequence is executing, Bit 7 of the status register is a "0".

When the status register indicates that erasure is complete, the status bits, which indicate whether the erase operation was successful, should be checked. If the erasure operation was unsuccessful, Bit 5 of the status register is set to a "1" to indicate an Erase Failure. If  $V_{PP}$  was not within acceptable limits after the Erase Confirm command is issued, the WSM will not execute an erase sequence; instead, Bit 5 of the status register is set to a "1" to indicate an Erase Failure, and Bit 3 is set to a "1" to identify that  $V_{PP}$  supply voltage was not within acceptable limits.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after erasure is completed; however, it must be recognized that reads from the memory array, status register, or Intelligent Identifier can not be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 13 shows a system software flowchart for Block Erase operation.

## 4.4.5.1 Suspending and Resuming Erase

Since an erase operation typically requires 2 seconds to 5 seconds to complete, an Erase Suspend command is provided. This allows erase-sequence interruption in order to read data from another block of the memory. Once the erase sequence is started, writing the Erase Suspend command to the CUI requests that the Write State Machine (WSM) pause the erase sequence at a predetermined point in the erase algorithm. The status register must be read to determine when the erase operation has been suspended.

At this point, a Read Array command can be written to the CUI in order to read data from blocks other than that which is being suspended. The only other valid command at this time is the Erase Resume command or Read Status Register operation.

Figure 14 shows a system software flowchart detailing the operation.

During Erase Suspend mode, the chip can go into a pseudo-standby mode by taking CE# to  $V_{IH}$  and the active current is now a maximum of 6 mA. If the chip is enabled while in this mode by taking CE# to  $V_{IL}$ , the Erase Resume command can be issued to resume the erase operation.



Upon completion of reads from any block other than the block being erased, the Erase Resume command must be issued. When the Erase Resume command is given, the WSM will continue with the erase sequence and complete erasing the block. As with the end of erase, the status register must be read, cleared, and the next instruction issued in order to continue.

## 4.4.6 EXTENDED CYCLING

Intel has designed extended cycling capability into its ETOX III flash memory technology. The 4-Mbit low voltage flash memory family is designed for 10,000 program/erase cycles on each of the seven blocks. The combination of low electric fields, clean oxide processing and minimized oxide area per memory cell subjected to the tunneling electric field, results in very high cycling capability.





| Bus<br>Operation | Command          | Comments                                                          |
|------------------|------------------|-------------------------------------------------------------------|
| Write            | Setup<br>Program | Data = 40H<br>Address = Byte to be<br>programmed                  |
| Write            | Program          | Data to be programmed<br>Address = Byte to be<br>programmed       |
| Read             |                  | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                  | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent bytes.

Full status check can be done after each byte or after a sequence of bytes.

Write FFH after the last byte programming operation to reset the device to Read Array Mode.

## **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4<br>1 = Byte Program Error         |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple bytes are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 12. Automated Byte Programming Flowchart





| Bus<br>Operation | Command          | Comments                                                                |
|------------------|------------------|-------------------------------------------------------------------------|
| Write            | Setup<br>Program | Data = 40H<br>Address = Word to be<br>programmed                        |
| Write            | Program          | Data to be programmed<br>Address = Word to be<br>programmed             |
| Read             |                  | Status Register Data.<br>Toggle OE# or CE# to update<br>Status Register |
| Standby          |                  | Check SR.7<br>1 = Ready, 0 = Busy                                       |

Repeat for subsequent words.

Full status check can be done after each word or after a sequence of words.

Write FFH after the last word programming operation to reset the device to Read Array Mode.

## Full Status Check Procedure



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4<br>1 = Byte Program Error         |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple words are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 13. Automated Word Programming Flowchart





| Bus<br>Operation | Command        | Comments                                                          |
|------------------|----------------|-------------------------------------------------------------------|
| Write            | Setup<br>Erase | Data = 20H<br>Address = Within block to be<br>erased              |
| Write            | Erase          | Data = D0H<br>Address = Within block to be<br>erased              |
| Read             |                | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent blocks.

Full status check can be done after each block or after a sequence of blocks.

Write FFH after the last block erase operation to reset the device to Read Array Mode.

## **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4,5 Both 1 = Command Sequence Error |
| Standby          |         | Check SR.5<br>1 = Block Erase Error          |

SR.3 MUST be cleared, if set during an erase attempt, before further attempts are allowed by the Write State Machine.

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 14. Automated Block Erase Flowchart





Figure 15. Erase Suspend/Resume Flowchart

## 4.5 Power Consumption

## 4.5.1 ACTIVE POWER

With **CE**# at a logic-low level and **RP**# at a logic-high level, the device is placed in the active mode. The device I<sub>CC</sub> current is a maximum of 22 mA at 5 MHz.

## 4.5.2 AUTOMATIC POWER SAVINGS

Automatic Power Savings (APS) is a low power feature during active mode of operation. The 4-Mbit family of products incorporate Power Reduction Control (PRC) circuitry which basically allows the device to put itself into a low current state when it is not being accessed. After data is read from the memory array, PRC logic controls the device's power consumption by entering the APS mode where

typical  $I_{CC}$  current is 0.8 mA and maximum  $I_{CC}$  current is 2 mA. The device stays in this static state with outputs valid until a new memory location is read.

## 4.5.3 STANDBY POWER

With CE# at a logic-high level (V<sub>IH</sub>), and the CUI read mode, the memory is placed in standby mode where the maximum I<sub>CC</sub> standby current is 120 μA with CMOS input signals. The standby operation disables much of the device's circuitry and substantially reduces device power consumption. The outputs (DQ[0:15] or DQ[0:7] are placed in a high-impedance state independent of the status of the OE# signal. When the 4-Mbit flash family is deselected during erase or program functions, the devices will continue to perform the erase or program function and consume program or erase active power until program or erase is completed.



## 4.5.4 RESET/DEEP POWER-DOWN

The 4-Mbit flash family supports a typical  $I_{CC}$  of 0.2  $\mu$ A in deep power-down mode. One of the target markets for these devices is in portable equipment where the power consumption of the machine is of prime importance. The 4-Mbit flash family has a RP# pin which places the device in the deep power-down mode. When RP# is at a logic-low (GND  $\pm$  0.2V), all circuits are turned off and the device typically draws 0.2  $\mu$ A of  $V_{CC}$  current.

During read modes, the RP# pin going low deselects the memory and places the output drivers in a high impedance state. Recovery from the deep power-down state, requires a maximum of 600 ns to access valid data (tpHOV).

During erase or program modes, RP# low will abort either erase or program operation. The contents of the memory are no longer valid as the data has been corrupted by the RP# function. As in the read mode above, all internal circuitry is turned off to achieve the 0.2  $\mu$ A current level.

RP# transitions to  $V_{IL}$  or turning power off to the device will clear the status register.

This use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset it expects to read from the flash memory. Automated flash memories provide status information when accessed during write/erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input. In this application RP# is controlled by the same RESET# signal that resets the system CPU.

## 4.6 Power-up Operation

The 4-Mbit flash memory family is designed to offer protection against accidental block erasure or programming during power transitions. Upon power-up the 4-Mbit flash memory family is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers-up first. Power supply sequencing is not required.

The 4-Mbit flash memory family ensures the CUI is reset to the read mode on power-up.

In addition, on power-up the user must either drop CE# low or present a new address to ensure valid data at the outputs.

A system designer must guard against spurious writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is

active. Since both WE# and CE# must be low for a command write, driving either signal to  $V_{IH}$  will inhibit writes to the device. The CUI architecture provides an added level of protection since alteration of memory contents can only occur after successful completion of the two-step command sequences. Finally the device is disabled until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. This feature provides yet another level of memory protection.

## 4.7 Power Supply Decoupling

Flash memory's power switching characteristics require careful device decoupling methods. System designers are interested in 3 supply current issues:

- Standby current levels (I<sub>CCS</sub>)
- Active current levels (I<sub>CCR</sub>)
- Transient peaks produced by falling and rising edges of CE#.

Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress these transient voltage peaks. Each flash device should have a 0.1 µF ceramic capacitor connected between each V<sub>CC</sub> and GND, and between its V<sub>PP</sub> and GND. These high frequency, low-inherent inductance capacitors should be placed as close as possible to the package leads.

# 4.7.1 V<sub>PP</sub> TRACE ON PRINTED CIRCUIT BOARDS

Writing to flash memories while they reside in the target system, requires special consideration of the  $V_{PP}$  power supply trace by the printed circuit board designer. The  $V_{PP}$  pin supplies the flash memory cell's current for programming and erasing. One should use similar trace widths and layout considerations given to the  $V_{CC}$  power supply trace. Adequate  $V_{PP}$  supply traces and decoupling will decrease spikes and overshoots.

## 4.7.2 VCC, VPP AND RP# TRANSITIONS

The CUI latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its state upon power-up, after exit from deep power-down mode or after  $V_{CC}$  transitions below  $V_{LKO}$  (Lockout voltage), is Read Array mode.

After any word/byte write or block erase operation is complete and even after  $V_{PP}$  transitions down to  $V_{PPL}$ , the CUI must be reset to Read Array mode via the Read Array command when accesses to the flash memory are desired.



## 5.0 OPERATING SPECIFICATIONS

## ABSOLUTE MAXIMUM RATINGS

Operating Temperature During Read .....  $-20^{\circ}$ C to  $+70^{\circ}$ C(1) During Block Erase/Byte Write ....0°C to +70°C Temperature Under Bias . . . . . . . - 20°C to +80°C Storage Temperature .....-65°C to +125°C Voltage on any Pin (except V<sub>CC</sub>, V<sub>PP</sub>, A<sub>9</sub> and RP#) with Respect to GND ...... -2.0V to +7.0V<sup>(2)</sup> Voltage on Pin RP# or Pin Ag with Respect to GND  $\dots$  -2.0V to +13.5V(2, 3) V<sub>CC</sub> Program Voltage with Respect to GND during Block Erase and Word/Byte Write  $\dots$  -2.0V to +14.0V(2, 3) V<sub>CC</sub> Supply Voltage with Respect to GND  $\dots$  -2.0V to +7.0V(2)  NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## NOTES:

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC} + 0.5V$  which during transitions may overshoot to  $V_{CC} + 2.0V$  for periods < 20 ns.
- 3. Maximum DC voltage on  $V_{PP}$  may overshoot to  $\pm 14.0 \text{V}$  for periods < 20 ns. Maximum DC voltage on RP# or Ag may overshoot to 13.5V for periods < 20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.
- 5. AC specifications are valid at both voltage ranges. See DC Characteristics tables for voltage range-specific specifications.

## **OPERATING CONDITIONS**

| Symbol          | Parameter                      | Notes         | Min  | Max  | Unit |
|-----------------|--------------------------------|---------------|------|------|------|
| TA              | Operating Temperature          |               | -20  | 70   | °C   |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage | Program/Erase | 3.15 | 3.60 | ٧    |
|                 |                                | Read          | 3.00 | 3.60 | ٧    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage | 5             | 4.50 | 5.50 | ٧    |

## DC CHARACTERISTICS V<sub>CC</sub> = 3.3V ±0.3V Read, 3.15V-3.6V Program/Erase

|        |                        |       |     |     |      | <u> </u> |                                                    |
|--------|------------------------|-------|-----|-----|------|----------|----------------------------------------------------|
| Symbol | Parameter              | Notes | Min | Тур | Max  | Unit     | Test Conditions                                    |
| ILI    | Input Load Current     | 1     |     |     | ±1.0 | μΑ       | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$  |
| ILO    | Output Leakage Current | 1     |     |     | ±10  | μΑ       | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$ |



# **DC CHARACTERISTICS** $V_{CC} = 3.3V \pm 0.3V$ Read, 3.15V-3.6V Program/Erase (Continued)

| Symbol           | Parameter                                                                          | Notes     | Min  | Тур  | Max                   | Unit | Test Conditions                                                                                                                                              |
|------------------|------------------------------------------------------------------------------------|-----------|------|------|-----------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Iccs             | V <sub>CC</sub> Standby Current                                                    | 1, 3      |      | 45   | 120                   | μΑ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = RP# = V <sub>IH</sub>                                                                                         |
|                  |                                                                                    |           |      | 45   | 120                   | μΑ   | $\begin{split} &V_{CC}=V_{CC}\text{Max}\\ &CE\#=\text{RP}\#=V_{CC}\pm0.2V\\ &28\text{F400BX:}\\ &\text{BYTE}\#=V_{CC}\pm0.2V\text{or}\text{GND} \end{split}$ |
| ICCD             | V <sub>CC</sub> Deep Power-Down Current                                            | 1         |      | 0.20 | 1.2                   | μΑ   | $RP# = GND \pm 0.2V$                                                                                                                                         |
| ICCR             | V <sub>CC</sub> Read Current for<br>28F400BX-L Word-Wide and<br>Byte-Wide Mode and | 1<br>5, 6 |      | 15   | 25                    | mA   | $V_{\rm CC} = V_{\rm CC}$ Max, ${\rm CE}\# = {\rm GND}$ f = 5 MHz, ${\rm I}_{\rm OUT} = 0$ mA CMOS Inputs                                                    |
|                  | 28F004BX-L Byte-Wide Mode                                                          |           | •    | 15   | 25                    | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$ f = 5 MHz, $I_{OUT} = 0 mA$ TTL Inputs                                                                                  |
| Iccw             | V <sub>CC</sub> Word Write Current                                                 | 1         |      |      | 30                    | mA   | Word Write in Progress                                                                                                                                       |
| Iccw             | V <sub>CC</sub> Byte Write Current                                                 | 1         |      |      | 30                    | mΑ   | Byte Write in Progress                                                                                                                                       |
| ICCE             | V <sub>CC</sub> Block Erase Current                                                | . 1       |      |      | 20                    | mΑ   | Block Erase in Progress                                                                                                                                      |
| ICCES            | V <sub>CC</sub> Erase Suspend Current                                              | 1, 2      |      | 3    | 6                     | mA   | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                                                                                              |
| I <sub>PPS</sub> | V <sub>PP</sub> Standby Current                                                    | 1         |      |      | ± 15                  | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                                                                                            |
| I <sub>PPD</sub> | V <sub>PP</sub> Deep Power-Down Current                                            | 1         |      |      | 5.0                   | μΑ   | $RP# = GND \pm 0.2V$                                                                                                                                         |
| IPPR .           | V <sub>PP</sub> Read Current                                                       | 1, 4      |      |      | 200                   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                                                                                                            |
| IPPW             | V <sub>PP</sub> Word Write Current                                                 | 1, 4      |      |      | 40                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress                                                                                                 |
| IPPW             | V <sub>PP</sub> Byte Write Current                                                 | 1, 4      |      |      | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                                                                                                 |
| IPPE             | V <sub>PP</sub> Block Erase Current                                                | 1, 4      |      |      | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                                                                                                |
| IPPES            | V <sub>PP</sub> Erase Suspend Current                                              | 1         |      |      | 200                   | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                                                                                                  |
| I <sub>RP#</sub> | RP# Boot Block Unlock Current                                                      | 1, 4      |      |      | 500                   | μΑ   | RP# = V <sub>HH</sub>                                                                                                                                        |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current                                      | 1, 4      |      |      | 500                   | μΑ   | $A_9 = V_{ID}$                                                                                                                                               |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Voltage                                      |           | 11.4 | 12.0 | 13.0                  | >    |                                                                                                                                                              |
| V <sub>IL</sub>  | Input Low Voltage                                                                  |           | -0.5 |      | 0.6                   | ٧    |                                                                                                                                                              |
| V <sub>IH</sub>  | Input High Voltage                                                                 |           | 2.0  |      | V <sub>CC</sub> + 0.5 | >    |                                                                                                                                                              |
| V <sub>OL</sub>  | Output Low Voltage                                                                 |           |      |      | 0.4                   | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 2 mA$                                                                                                                        |



## DC CHARACTERISTICS V<sub>CC</sub> = 3.3V ±0.3V Read, 3.15V-3.6V Program/Erase (Continued)

| Symbol           | Parameter                                     | Notes | Min                  | Тур  | Max  | Unit | Test Conditions                                                                                                    |
|------------------|-----------------------------------------------|-------|----------------------|------|------|------|--------------------------------------------------------------------------------------------------------------------|
| V <sub>OH1</sub> | Output High Voltage (TTL)                     |       | 2.4                  |      |      | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2 mA$                                                                             |
| V <sub>OH2</sub> | Output High Voltage<br>(CMOS)                 |       | 0.85 V <sub>CC</sub> |      |      | >    | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$ $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{ Min}$ |
| V <sub>PPL</sub> | V <sub>PP</sub> during Normal Operations      | 3     | 0.0                  |      | 4.1  | >    |                                                                                                                    |
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write Operations |       | 11.4                 | 12.0 | 12.6 | ٧    |                                                                                                                    |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.0                  |      |      | ٧    |                                                                                                                    |
| $V_{HH}$         | RP# Unlock Voltage                            |       | 11.4                 | 12.0 | 13.0 | ٧    | Boot Block Write/Erase                                                                                             |

# CAPACITANCE(4) T<sub>A</sub> = 25°C, f = 1 MHz

| Symbol           | Parameter          | Тур | Max | Unit | Condition             |
|------------------|--------------------|-----|-----|------|-----------------------|
| C <sub>IN</sub>  | Input Capacitance  | 6   | 8   | pF   | $V_{IN} = 0V$         |
| C <sub>OUT</sub> | Output Capacitance | 10  | 12  | pF   | V <sub>OUT</sub> = 0V |

## NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 3.3V$ ,  $V_{PP} = 12.0V$ ,  $T = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).
- 2. ICCES is specified with the device deselected. If the device is read while in Erase Suspend Mode, current draw is the sum

of ICCES and ICCR.

- on coes and icon.

  3. Block Erase and Word/Byte Writes are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between  $V_{PPH}$  and  $V_{PPI}$ .
- 4. Sampled, not 100% tested.
- 5. Automatic Power Savings (APS) reduces  $I_{\mbox{\scriptsize CCR}}$  to less than 1 mA in static operation.
- 6. CMOS Inputs are either  $V_{CC}$   $\pm 0.2 V$  or GND  $\pm 0.2 V$ . TTL Inputs are either  $V_{IL}$  or  $V_{IH}$ .



# DC CHARACTERISTICS(4) $V_{CC} = 5.0V \pm 10\%$

| Symbol           | Parameter                                                                           | Notes | Min  | Тур  | Max  | Unit | Test Conditions                                                                   |
|------------------|-------------------------------------------------------------------------------------|-------|------|------|------|------|-----------------------------------------------------------------------------------|
| I <sub>LI</sub>  | Input Load Current                                                                  | 1     |      |      | ±1.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                 |
| LO               | Output Leakage Current                                                              | 1     |      |      | ±10  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                |
| Iccs             | V <sub>CC</sub> Standby Current                                                     | 1 .   |      |      | 1.5  | mA   | $V_{CC} = V_{CC} Max$ $CE\# = RP\# = V_{IH}$                                      |
|                  |                                                                                     |       |      |      | 100  | μΑ   | $V_{CC} = V_{CC} Max$<br>$CE # = RP # = V_{CC} \pm 0.2V$                          |
| ICCD             | V <sub>CC</sub> Deep Power-Down Current                                             | 1     | ,    |      | 1.2  | μΑ   | $RP\# = GND \pm 0.2V$ $I_{OUT} = 0 \text{ mA}$                                    |
| ICCR             | V <sub>CC</sub> Read Current for<br>28F400BX-L Word-Wide Mode<br>and Byte Wide Mode | 1     | ,    |      | 40   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>f = 5 MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs |
|                  | and 28F004BX-L                                                                      |       |      |      | 40   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$ f = 5 MHz, $I_{OUT} = 0$ mA TTL Inputs     |
| Iccw             | V <sub>CC</sub> Word Byte Write Current                                             | 1,4   |      |      | 70   | mA   | Word Write in Progress                                                            |
| ICCE             | V <sub>CC</sub> Block Erase Current                                                 | 1, 4  |      |      | 30   | mA   | Block Erase in Progress                                                           |
| ICCES            | V <sub>CC</sub> Erase Suspend Current                                               | 1, 2  |      |      | 10   | mA   | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                   |
| I <sub>PPS</sub> | V <sub>PP</sub> Standby Current                                                     | 1     |      |      | ±10  | μΑ   | $V_{PP} \leq V_{CC}$                                                              |
| I <sub>PPD</sub> | V <sub>PP</sub> Deep Power-Down Current                                             | 1     |      |      | 5.0  | μΑ   | $RP# = GND \pm 0.2V$                                                              |
| IPPR             | V <sub>PP</sub> Read Current                                                        | 1     |      |      | 200  | μΑ   | $V_{PP} > V_{CC}$                                                                 |
| I <sub>PPW</sub> | V <sub>PP</sub> Word Write Current                                                  | 1, 4  |      |      | 40   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress                      |
| I <sub>PPW</sub> | V <sub>PP</sub> Byte Write Current                                                  | 1, 4  |      |      | 30   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                      |
| I <sub>PPE</sub> | V <sub>PP</sub> Block Erase Current                                                 | 1, 4  |      |      | 30   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                     |
| IPPES            | V <sub>PP</sub> Erase Suspend Current                                               | 1     |      | -    | 200  | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                       |
| I <sub>RP#</sub> | RP# Boot Block<br>Unlock Current                                                    | 1, 4  |      |      | 500  | μĄ   | RP# = V <sub>HH</sub>                                                             |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent<br>Identifier Current                                    | 1, 4  |      |      | 500  | μΑ   | $A_9 = V_{ID}$                                                                    |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent<br>Identifier Voltage                                    |       | 11.4 | 12.0 | 13.0 | ٧    |                                                                                   |



## DC CHARACTERISTICS(4) $V_{CC} = 5.0V \pm 10\%$ (Continued)

| Symbol           | Parameter                                     | Notes | Min                  | Тур  | Max                   | Unit | Test Condition                                              |
|------------------|-----------------------------------------------|-------|----------------------|------|-----------------------|------|-------------------------------------------------------------|
| $V_{IL}$         | Input Low Voltage                             |       | -0.5                 |      | 0.8                   | ٧    |                                                             |
| V <sub>IH</sub>  | Input High Voltage                            |       | 2.0                  |      | V <sub>CC</sub> + 0.5 | ٧    |                                                             |
| V <sub>OL</sub>  | Output Low Voltage                            |       |                      |      | 0.45                  | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                     |
| V <sub>OH1</sub> | Output High Voltage (TTL)                     |       | 2.4                  |      |                       | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                    |
| V <sub>OH2</sub> | Output High Voltage<br>(CMOS)                 |       | 0.85 V <sub>CC</sub> |      |                       | ٧    | $I_{OL} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$ |
|                  |                                               |       | V <sub>CC</sub> −0.4 |      |                       |      | $I_{OL} = -100 \mu A$ $V_{CC} = V_{CC} Min$                 |
| $V_{PPL}$        | V <sub>PP</sub> during Normal Operations      | 3     | 0.0                  |      | 6.5                   | ٧    |                                                             |
| $V_{PPH}$        | V <sub>PP</sub> during Erase/Write Operations |       | 11.4                 | 12.0 | 12.6                  | ٧    |                                                             |
| $V_{LKO}$        | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.2                  |      | ·                     | ٧    |                                                             |
| $V_{HH}$         | RP# Unlock Voltage                            |       | 11.4                 | 12.0 | 13.0                  | ٧    | Boot Block Write/Erase                                      |

### NOTES

1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).

2. I<sub>CCES</sub> is specified with the device deselected. If the device is read while in Erase Suspend Mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCES</sub>.

3. Block Erases and Word/Byte Writes are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between  $V_{PPH}$  and  $V_{PPL}$ .

4. All parameters are sampled, not 100% tested.

## AC INPUT/OUTPUT REFERENCE WAVEFORM



## **AC TESTING LOAD CIRCUIT**





# AC CHARACTERISTICS-Read-Only Operations(1) $V_{CC} = 3.3V \pm 0.3V, 5.0V \pm 10\%$

| Versions                               |                 |                                                                   |       |     | 28F400BL-150<br>28F004BL-150 |    |  |
|----------------------------------------|-----------------|-------------------------------------------------------------------|-------|-----|------------------------------|----|--|
| Sym                                    | bol             | Parameter                                                         | Notes | Min | Max                          |    |  |
| t <sub>AVAV</sub>                      | t <sub>RC</sub> | Read Cycle Time                                                   |       | 150 |                              | ns |  |
| t <sub>AVQV</sub>                      | tACC            | Address to Output Delay                                           |       |     | 150                          | ns |  |
| tELQV                                  | tCE             | CE# to Output Delay                                               | 2     |     | 150                          | ns |  |
| t <sub>PHQV</sub>                      | tpwH            | RP# High to Output Delay                                          |       |     | 600                          | ns |  |
| tGLQV                                  | toE             | OE# to Output Delay                                               | 2     |     | 65                           | ns |  |
| t <sub>ELQX</sub>                      | t <sub>LZ</sub> | CE# to Output Low Z                                               | 3     | 0   |                              | ns |  |
| t <sub>EHOZ</sub>                      | t <sub>HZ</sub> | CE# High to Output High Z                                         | 3     | ,   | 55                           | ns |  |
| t <sub>GLQX</sub>                      | toLZ            | OE# to Output Low Z                                               | 3     | 0   |                              | ns |  |
| t <sub>GHQZ</sub>                      | t <sub>DF</sub> | OE# High to Output High Z                                         | 3     |     | 45                           | ns |  |
|                                        | tон             | Output Hold from Addresses, CE# or OE# Change, Whichever is First | 3     | 0   |                              | ns |  |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> |                 | CE# to BYTE# Switching Low or High                                | 3     |     | 5                            | ns |  |
| t <sub>FHQV</sub>                      |                 | BYTE# Switching High to Valid Output Delay                        | 3, 4  |     | 150                          | ns |  |
| tFLQZ                                  |                 | BYTE# Switching Low to Output High Z                              | 3     |     | 45                           | ns |  |

## NOTES:

- See AC Input/Output Reference Waveform for timing measurements.
   OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.
- 4. t<sub>FLQV</sub>, BYTE# switching low to valid output delay will be equal to t<sub>AVQV</sub>, measured from the time DQ<sub>15</sub>/A<sub>.1</sub> becomes







Figure 17. BYTE# Timing Diagram for Both Read and Write Operations



# **AC CHARACTERISTICS** For $\overline{\text{WE}}$ -Controlled Write Operations(1) $V_{CC} = 3.15V - 3.6V$ , 5.0V $\pm 10\%$

|                    |                  | Versions <sup>(4)</sup>                        |         | 28F400BL-150<br>28F004BL-150 |     |    |
|--------------------|------------------|------------------------------------------------|---------|------------------------------|-----|----|
| Syml               | bol              | Parameter                                      | Notes   | Min                          | Max | 1  |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                               |         | 150                          |     | ns |
| t <sub>PHWL</sub>  | t <sub>PS</sub>  | RP# High Recovery to WE# Going Low             |         | 1.0                          |     | μs |
| <sup>t</sup> ELWL  | tcs              | CE# Setup to WE# Going Low                     |         | 0                            |     | ns |
| t <sub>PHHWH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to WE#<br>Going High | 6, 8    | 200                          |     | ns |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE# Going High        | 5, 8    | 200                          |     | ns |
| t <sub>AVWH</sub>  | tas              | Address Setup to WE#<br>Going High             | 3       | 95                           |     | ns |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to WE# Going High                   | 4       | 100                          |     | ns |
| twLwH              | t <sub>WP</sub>  | WE# Pulse Width                                |         | 100                          |     | ns |
| twHDX              | t <sub>DH</sub>  | Data Hold from WE# High<br>WE# High            | 4       | 0                            |     | ns |
| twhax              | t <sub>AH</sub>  | Address Hold from WE# High                     | 3       | 10                           |     | ns |
| twheh              | t <sub>CH</sub>  | CE# Hold from WE# High                         |         | 10                           |     | ns |
| twhwL              | twpH             | WE# Pulse Width High                           |         | 50                           |     | ns |
| twHQV1             |                  | Duration of Word/Byte Programming Operation    | 2, 5, 6 | 6                            | į   | μs |
| t <sub>WHQV2</sub> | -                | Duration of Erase<br>Operation (Boot)          | 2, 5, 6 | 0.3                          |     | S  |
| t <sub>WHQV3</sub> |                  | Duration of Erase<br>Operation (Parameter)     | 2, 5, 6 | 0.3                          |     | s  |
| <sup>t</sup> WHQV4 |                  | Duration of Erase<br>Operation (Main)          | 2, 5, 6 | 0.6                          |     | s  |
| tQWL               | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD            | 5, 8    | . 0                          |     | ns |
| t <sub>QVPH</sub>  | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD        | 6, 8    | 0                            |     | ns |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                        | 7, 8    |                              | 200 | ns |

## NOTES:

- Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during Read Mode.
- 2. The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- 4. Refer to command definition table for valid DIN.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7=1).
- 6. For Boot Block Program/Erase, PWD# should be held at VHH until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the Boot Block.
- 8. Sampled but not 100% tested.



## BLOCK ERASE AND BYTE/WORD WRITE PERFORMANCE $V_{CC}=3.15V-3.6V,\,5.0V\,\pm10\%$

| Parameter                       | Notes |  | Unit   |      |   |
|---------------------------------|-------|--|--------|------|---|
|                                 |       |  | Typ(1) | Max  | • |
| Boot/Parameter Block Erase Time | 2     |  | 2.0    | 8.6  | s |
| Main Block Erase Time           | 2     |  | 3.4    | 17.0 | s |
| Main Block Byte Program Time    | 2     |  | 1.4    | 5.3  | s |
| Main Blok Word Program Time     | 2     |  | 0.7    | 2.7  | s |

- NOTES: 1. 25°C, 12.0V Vpp. 2. Excludes System-Level Overhead.







## AC CHARACTERISTICS FOR CE#-CONTROLLED WRITE OPERATIONS

 $V_{CC} = 3.15V - 3.6V, 5.0V \pm 10\%$ 

| Versions           |                  |                                                |         |     | 28F400BL-150<br>28F004BL-150 |    |
|--------------------|------------------|------------------------------------------------|---------|-----|------------------------------|----|
| Symbol             |                  | Parameter                                      |         | Min | Max                          | 1  |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                               |         | 150 |                              | ns |
| t <sub>PHEL</sub>  | t <sub>PS</sub>  | RP# High Recovery to CE# Going Low             |         | 1.0 |                              | μs |
| t <sub>WLEL</sub>  | t <sub>WS</sub>  | WE# Setup to CE# Going Low                     |         | 0   |                              | ns |
| t <sub>PHHEH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to CE# Going High    | 6, 8    | 200 |                              | ns |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE# Going High        | 5, 8    | 200 |                              | ns |
| t <sub>AVEH</sub>  | t <sub>AS</sub>  | Address Setup to CE# Going High                | 3       | 95  |                              | ns |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to CE# Going High                   | 4       | 100 |                              | ns |
| tELEH              | t <sub>CP</sub>  | CE# Pulse Width                                |         | 100 |                              | ns |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from CE# High                        | 4       | 0   |                              | ns |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold from CE# High                     | 3       | 10  |                              | ns |
| t <sub>EHWH</sub>  | t <sub>WH</sub>  | WE# Hold from CE# High                         |         | 10  |                              | ns |
| t <sub>EHEL</sub>  | t <sub>CPH</sub> | CE# Pulse Width High                           |         | 50  |                              | ns |
| t <sub>EHQV1</sub> |                  | Duration of Programming<br>Operation Word/Byte | 2, 5, 6 | 6   |                              | μs |
| t <sub>EHQV2</sub> |                  | Duration of Erase Operation (Boot)             | 2, 5, 6 | 0.3 |                              | s  |
| <sup>t</sup> EHQV3 |                  | Duration of Erase<br>Operation (Parameter)     | 2, 5, 6 | 0.3 |                              | s  |
| t <sub>EHQV4</sub> |                  | Duration of Erase Operation (Main)             | 2, 5, 6 | 0.6 | ,                            | s  |
| tQWL               | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD            | 5, 8    | 0   |                              | ns |
| t <sub>QVPH</sub>  | tppH             | RP# V <sub>HH</sub> Hold from Valid SRD        | 6, 8    | 0   |                              | ns |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                        | 7,8     |     | 200                          | ns |

## NOTES:

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.

<sup>2, 3, 4, 5, 6, 7, 8.</sup> Refer to AC Characteristics for WE#-Controlled Write operations.

<sup>9.</sup> Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during Read Mode.





Figure 19. Alternate AC Waveforms for Write and Erase Operations (CE#-Controlled Writes)



# **ORDERING INFORMATION**





## **ADDITIONAL INFORMATION**

| Order<br>Number | Document                                                                          |
|-----------------|-----------------------------------------------------------------------------------|
| 292130          | AB-57 "Boot Block Architecture for Safe Firmware Updates"                         |
| 292154          | AB-60 "2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family"                    |
| 292098          | AP-363 "Extended Flash BIOS Concepts for Portable Computers"                      |
| 292148          | AP-604 "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM" |
| 290448          | 28F002/200-T/B Mbit Boot Block Flash Memory Datasheet                             |
| 290449          | 28F002/200BL-T/B 2 Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290451          | 28F004/400BX-T/B 4-Mbit Boot Block Flash Memory Datasheet                         |
| 290531          | 2-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290530          | 4-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290539          | 8-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |



# **REVISION HISTORY**

| Number | Description                                                                                                                                                                        |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -001   | Original Version                                                                                                                                                                   |
| -002   | Modified BYTE # Timing Waveforms  Modified t <sub>DVWH</sub> parameter for AC Characteristics for Write Operations                                                                 |
| -003   | PWD renamed to RP# for JEDEC standarization compatibility.                                                                                                                         |
|        | Combined V <sub>CC</sub> Read Current for 28F400BX-L Word-Wide and Byte-Wide Mode and 28F004BX-L Byte Wide Mode in DC Characteristics tables.                                      |
|        | Changed I <sub>PPS</sub> current spec from $\pm 10~\mu A$ to $\pm 15~\mu A$ in DC Characteristics table.                                                                           |
|        | Added Boot Block Unlock current spec in DC Characteristics tables.                                                                                                                 |
|        | Improved tpWH spec to 600 ns (was 700 ns).                                                                                                                                         |
|        | Changed I <sub>CCR</sub> maximum spec from 20 mA to 25 mA, and added 15 mA typical spec in DC Characteristics Table.                                                               |
| -004   | Added I <sub>OH</sub> CMOS specification.                                                                                                                                          |
|        | Expanded temperature operating range from 0°C-70°C to -20°C-70°C                                                                                                                   |
|        | Product naming changed: 28F400BX-TL/BL changed to 28F400BL-T/B 28F004BX-TL/BL changed to 28F004BL-T/B                                                                              |
|        | Typographical errors corrected.                                                                                                                                                    |
|        | Added 28F400BX interface to Intel386™ EX Embedded Processor block diagram.                                                                                                         |
|        | Added upgrade considerations for SmartVoltage Boot Block products.                                                                                                                 |
|        | Previously specified V <sub>CC</sub> tolerance of 3.0V to 3.6V for Read, Program and Erase has been changed to 3.15V to 3.6V for Program and Erase while Read remains 3.0V to 3.6V |

intel<sub>®</sub>

# 28F200BX-T/B, 28F002BX-T/B 2-MBIT (128K x 16, 256K x 8) BOOT BLOCK FLASH MEMORY FAMILY

- **■** x8/x16 Input/Output Architecture
  - 28F200BX-T, 28F200BX-B
  - For High Performance and High Integration 16-bit and 32-bit CPUs
- x8-only Input/Output Architecture
  - -- 28F002BX-T 28F002BX-B
  - For Space Constrained 8-bit Applications
- Upgradable to Intel's SmartVoltage Products
- Optimized High Density Blocked Architecture
  - One 16-KB Protected Boot Block
  - Two 8-KB Parameter Blocks
  - One 96-KB Main Block
  - One 128 KB Main Block
  - Top or Bottom Boot Locations
- Extended Cycling Capability — 100,000 Block Erase Cycles
- Automated Word/Byte Write and Block Erase
  - Command User Interface
  - Status Registers
  - Erase Suspend Capability
- SRAM-Compatible Write Interface
- Automatic Power Savings Feature
  - 1 mA Typical I<sub>CC</sub> Active Current in Static Operation

- Hardware Data Protection Feature
   Erase/Write Lockout during Power Transitions
- Very High-Performance Read
  - -- 60/80/120 ns Maximum Access Time
  - 30/40/40 ns Maximum Output Enable Time
- Low Power Consumption
  - 20 mA Typical Active Read Current
- Reset/Deep Power-Down Input
  - 0.2 μA I<sub>CC</sub> Typical
  - Acts as Reset for Boot Operations
- Extended Temperature Operation— -40°C to +85°C
- Write Protection for Boot Block
- Industry Standard Surface Mount Packaging
  - 28F200BX: JEDEC ROM Compatible

44-Lead PSOP

56-Lead TSOP

- -- 28F002BX: 40-Lead TSOP
- 12V Word/Byte Write and Block Erase
  - $-V_{DD} = 12V \pm 5\%$  Standard
  - $-V_{pp} = 12V \pm 10\%$  Option
- ETOX III Flash Technology — 5V Read
- Independent Software Vendor Support





Intel's 2-Mbit Flash Memory Family is an extension of the Boot Block Architecture which includes block-selective erasure, automated write and erase operations and standard microprocessor interface. The 2-Mbit Flash Memory Family enhances the Boot Block Architecture by adding more density and blocks, x8/x16 input/out-put control, very high speed, low power, an industry standard ROM compatible pinout and surface mount packaging. The 2-Mbit flash family allows for an easy upgrade to Intel's 4-Mbit Boot Block Flash Memory Family.

The Intel 28F200BX-T/B are 16-bit wide flash memory offerings. These high density flash memories provide user selectable bus operation for either 8-bit or 16-bit applications. The 28F200BX-T and 28F200BX-B are 2,097,152-bit non-volatile memories organized as either 262,144 bytes or 131,072 words of information. They are offered in 44-Lead plastic SOP and 56-Lead TSOP packages. The x8/x16 pinout conforms to the industry standard ROM/EPROM pinout.

The Intel 28F002BX-T/B are 8-bit wide flash memories with 2,097,152 bits organized as 262,144 bytes of information. They are offered in a 40-Lead TSOP package, which is ideal for space-constrained portable systems.

These devices use an integrated Command User Interface (CUI) and Write State Machine (WSM) for simplified word/byte write and block erasure. The 28F200BX-T/28F002BX-T provide block locations compatible with Intel's MCS-186 family, 80286, i386™, i486™, i486™, i860™ and 80960CA microprocessors. The 28F200BX-B/28F002BX-B provide compatibility with Intel's 80960KX and 80960SX families as well as other embedded microprocessors.

The boot block includes a data protection feature to protect the boot code in critical applications. With a maximum access time of 60 ns, these 2-Mbit flash devices are very high performance memories which interface at zero-wait-state to a wide range of microprocessors and microcontrollers. A deep power-down mode lowers the total  $V_{CC}$  power consumption to 1  $\mu$ W typical. This is critical in handheld battery powered systems. For very low power applications using a 3.3V supply, refer to the Intel 28F200BX-TL/BL, 28F002BX-TL/BL 2-Mbit Boot Block Flash Memory Family datasheet.

Manufactured on Intel's 0.8 micron ETOXIII process, the 2-Mbit flash memory family provides world class quality, reliability and cost-effectiveness at the 2-Mbit density level.



## 1.0 PRODUCT FAMILY OVERVIEW

Throughout this datasheet the 28F200BX refers to both the 28F200BX-T and 28F200BX-B devices and 28F002BX refers to both the 28F002BX-T and 28F002BX-B devices. The 2-Mbit flash memory family refers to both the 28F200BX and 28F002BX products. This datasheet comprises the specifications for four separate products in the 2-Mbit flash memory family. Section 1 provides an overview of the 2-Mbit flash memory family including applications, pinouts and pin descriptions. Sections 2 and 3 describe in detail the specific memory organizations for the 28F200BX and 28F002BX products respectively. Section 4 combines a description of the family's principles of operations. Finally Section 5 describes the family's operating specifications.

## PRODUCT FAMILY

| x8/x16 Products | x8-Only Products |
|-----------------|------------------|
| 28F200BX-T      | 28F002BX-T       |
| 28F200BX-B      | 28F002BX-B       |

## 1.1 Designing for Upgrade to SmartVoltage Products

Today's high volume boot block products are upgradable to Intel's SmartVoltage boot block products that provide program and erase operation at 5V or 12V  $V_{PP}$  and read operation at 3V or 5V  $V_{CC}$ . Intel's SmartVoltage boot block products provide the following enhancements to the boot block products described in this data sheet:

- DU pin is replaced by WP# to provide a means to lock and unlock the boot block with logic signals.
- 5V Program/Erase operation uses proven program and erase techniques with 5V ±10% applied to VPP.
- Enhanced circuits optimize performance at 3.3V Vcc.

Refer to the 2, 4 or 8 Mbit SmartVoltage Boot Block Flash Memory Data Sheets for complete specifications.

When you design with 12V V<sub>PP</sub> boot block products you should provide the capability in your board design to upgrade to SmartVoltage products.

Follow these guidelines to ensure compatibility:

- Connect DU (WP# on SmartVoltage products) to a control signal or to V<sub>CC</sub> or GND.
- If adding a switch on V<sub>PP</sub> for write protection, switch to GND for complete write protection.
- Allow for connecting 5V to V<sub>PP</sub> and disconnect 12V from the V<sub>PP</sub> line, if desired.

## 1.2 Main Features

The 28F200BX/28F002BX boot block flash memory family is a very high performance 2-Mbit (2,097,152 bit) memory family organized as either 128 KWords (131,072 words) of 16 bits each or 256 Kbytes (262,144 bytes) of 8 bits each.

Five Separately Erasable Blocks including a hardware-lockable boot block (16,384 Bytes), two parameter blocks (8,192 Bytes each) and two main blocks (1 block of 98,304 Bytes and 1 block of 131,072 Bytes) are included on the 2-Mbit family. An erase operation erases one of the main blocks in typically 2.4 seconds, and the boot or parameter blocks in typically 1.0 second. Each block can be independently erased and programmed 100,000 times.

The Boot Block is located at either the top (28F200BX-T, 28F002BX-T) or the bottom (28F200BX-B, 28F002BX-B) of the address map in order to accommodate different microprocessor protocols for boot code location. The hardware lockable boot block provides the most secure code storage. The boot block is intended to store the kernel code required for booting-up a system. When the RP# pin is between 11.4V and 12.6V the boot block is unlocked and program and erase operations can be performed. When the RP# pin is at or below 6.5V the boot block is locked and program and erase operations to the boot block are ignored.

The 28F200BX products are available in the ROM/EPROM compatible pinout and housed in the 44-Lead PSOP (Plastic Small Outline) package and the 56-Lead TSOP (Thin Small Outline, 1.2mm thick) package as shown in Figures 3 and 4. The 28F002BX products are available in the 40-Lead TSOP (1.2mm thick) package as shown in Figure 5.

The Command User Interface (CUI) serves as the interface between the microprocessor or microcontroller and the internal operation of the 28F200BX and 28F002BX flash memory products.

Program and Erase Automation allows program and erase operations to be executed using a two-write command sequence to the CUI. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verifications, thereby unburdening the microprocessor or microcontroller. Writing of memory data is performed in word or byte increments for the 28F200BX family and in byte increments for the 28F002BX family typically within 9  $\mu s$  which is a 100% improvement over current flash memory products.



The **Status Register (SR)** indicates the status of the WSM and whether the WSM successfully completed the desired program or erase operation.

Maximum Access Time of **60 ns (TACC)** is achieved over the commercial temperature range (0°C to 70°C), 5%  $V_{CC}$  supply voltage range (4.75V to 5.25V) and 30 pF output load. Refer to Figure 19;  $T_{ACC}$  vs Output Load Capacitance for larger output loads. Maximum Access Time of **80 ns (TACC)** is achieved over the commercial temperature range, 10%  $V_{CC}$  supply range (4.5V to 5.5V) and 100 pF output load.

lpp maximum Program current is 40 mA for x16 operation and 30 mA for x8 operation. lpp Erase current is 30 mA maximum. Vpp erase and programming voltage is 11.4V to 12.6V (Vpp = 12V  $\pm 5\%$ ) under all operating conditions. As an option, Vpp can also vary between 10.8V to 13.2V (Vpp = 12V  $\pm 10\%$ ) with a guaranteed number of 100 block erase cycles.

Typical I<sub>CC</sub> Active Current of 25 mA is achieved for the x16 products (28F200BX), typical I<sub>CC</sub> Active Current of 20 mA is achieved for the x8 products (28F200BX, 28F002BX). Refer to the I<sub>CC</sub> active current derating curves in this datasheet.

The 2-Mbit boot block flash family is also designed with an Automatic Power Savings (APS) feature to minimize system battery current drain and allow for very low power designs. Once the device is accessed to read array data, APS mode will immediately put the memory in static mode of operation where I<sub>CC</sub> active current is typically 1 mA until the next read is initiated.

When the CE# and RP# pins are at  $V_{CC}$  and the BYTE# pin (28F200BX-only) is at either  $V_{CC}$  or GND the **CMOS Standby** mode is enabled where  $I_{CC}$  is typically 50  $\mu$ A.

A Deep Power-Down Mode is enabled when the RP# pin is at ground minimizing power consumption and providing write protection during power-up conditions. Icc current during deep power-down mode is 0.20 µA typical. An initial maximum access time or Reset Time of 300 ns is required from RP# switching until outputs are valid. Equivalently, the device has a maximum wake-up time of 215 ns until writes to the Command User Interface are recognized. When RP# is at ground the WSM is reset, the Status Register is cleared and the entire device is protected from being written to. This feature prevents data corruption and protects the code stored in the device during system reset. The system Reset pin can be tied to RP# to reset the memory to normal read mode upon activation of the Reset pin. With on-chip program/erase automation in the 2-Mbit family and the RP# functionality for data protection, when the CPU is reset and even if a program or erase command is issued, the device will not recognize any operation until RP# returns to its normal state.

For the 28F200BX, Byte-wide or Word-wide Input/Output Control is possible by controlling the BYTE# pin. When the BYTE# pin is at a logic low the device is in the byte-wide mode (x8) and data is read and written through DQ[0:7]. During the byte-wide mode, DQ[8:14] are tri-stated and DQ15/A-1 becomes the lowest order address pin. When the BYTE# pin is at a logic high the device is in the word-wide mode (x16) and data is read and written through DQ[0:15].

## 1.3 Applications

The 2-Mbit boot block flash family combines high density, high performance, cost-effective flash memories with blocking and hardware protection capabilities. Its flexibility and versatility will reduce costs throughout the product life cycle. Flash memory is ideal for Just-In-Time production flow, reducing system inventory and costs, and eliminating component handling during the production phase. During the product life cycle, when code updates or feature enhancements become necessary, flash memory will reduce the update costs by allowing either a userperformed code change via floppy disk or a remote code change via a serial link. The 2-Mbit boot block flash family provides full function, blocked flash memories suitable for a wide range of applications. These applications include Extended PC BIOS, Digital Cellular Phone program and data storage, Telecommunication boot/firmware, and various other embedded applications where both program and data storage are required.

Reprogrammable systems such as personal computers, are ideal applications for the 2-Mbit flash products. Portable and handheld personal computer applications are becoming more complex with the addition of power management software to take advantage of the latest microprocessor technology, the availability of ROM-based application software, pen tablet code for electronic hand writing, and diagnostic code. Figure 1 shows an example of a 28F200BX-T application.

This increase in software sophistication augments the probability that a code update will be required after the PC is shipped. The 2-Mbit flash products provide an inexpensive update solution for the notebook and handheld personal computers while extending their product lifetime. Furthermore, the 2-Mbit flash products' power-down mode provides added flexibility for these battery-operated portable designs which require operation at very low power levels.



The 2-Mbit flash products also provide excellent design solutions for Digital Cellular Phone and Telecommunication switching applications requiring high performance, high density storage capability coupled with modular software designs, and a small form factor package (x8-only bus). The 2-Mbit's blocking scheme allows for an easy segmentation of the embedded code with; 16 Kbytes of Hardware-Protected Boot code, 2 Main Blocks of program code and 2 Parameter Blocks of 8 Kbytes each for frequently updatable data storage and diagnostic

messages (e.g. phone numbers, authorization codes). Figure 2 is an example of such an application with the 28F002BX-T.

These are a few actual examples of the wide range of applications for the 2-Mbit Boot Block flash memory family which enable system designers to achieve the best possible product design. Only your imagination limits the applicability of such a versatile product family.



Figure 1. 28F200BX Interface to Intel386™ EX Embedded Processor



Figure 2. 28F002BX Interface to INTEL 80C188EB 8-Bit Embedded Microprocessor



## 1.4 Pinouts

The 28F200BX 44-Lead PSOP pinout follows the industry standard ROM/EPROM pinout as shown in Figure 3 with an upgrade to the 28F400BX (4-Mbit flash family). Furthermore, the 28F200BX 56-Lead TSOP pinout shown in Figure 4 provides density upgrades to the 28F400BX and to future higher density boot block memories.

The 28F002BX 40-Lead TSOP pinout shown in Figure 5 is 100% compatible and provides a density upgrade to the 28F004BX 4-Mbit Boot Block flash memory.



Figure 3. PSOP Lead Configuration for x8/x16 28F200BX





Figure 4. TSOP Lead Configuration for x8/x16 28F200BX



Figure 5. TSOP Lead Configuration for x8 28F002BX



# 1.5 Pin Descriptions for the x8/x16 28F200BX

| Symbol                            | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>16</sub>   | ı    | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| A <sub>9</sub>                    | l    | <b>ADDRESS INPUT:</b> When A <sub>9</sub> is at 12V the signature mode is accessed. During this mode A <sub>0</sub> decodes between the manufacturer and device ID's. When BYTE# is at a logic low only the lower byte of the signatures are read. $DQ_{15}/A_{-1}$ is a don't care in the signature mode when BYTE# is low.                                                                                                                                                                                                                           |
| DQ <sub>0</sub> -DQ <sub>7</sub>  | 1/0  | <b>DATA INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the Command User Interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array, Intelligent Identifier and Status Register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled.                                                                                                                                           |
| DQ <sub>8</sub> -DQ <sub>15</sub> | 1/0  | <b>DATA INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a program command. Data is internally latched during the write and program cycles. Outputs array data. The data pins float to tri-state when the chip is deselected or the outputs are disabled as in the byte-wide mode (BYTE# = "0"). In the byte-wide mode DQ $_{15}/A_{-1}$ becomes the lowest order address for data output on DQ $_{0}$ -DQ $_{7}$ .                                                                                                        |
| CE#                               | ı    | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                                                                                                                                                                           |
| RP#                               | I    | RESET/DEEP POWER-DOWN: Provides three-state control. Puts the device in deep power-down mode. Locks the boot block from program/erase.                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                   |      | When RP# is at logic high level and equals 6.5V maximum the boot block is locked and cannot be programmed or erased.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                   |      | When RP # = 11.4V minimum the boot block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                   |      | When RP# is at a logic low level the boot block is locked, the deep power-down mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions. When RP# transitions from logic low to logic high the flash memory enters the read array mode.                                                                                                                                                                                                                |
| OE#                               | 1    | OUTPUT ENABLE: Gates the device's outputs through the data buffers during a read cycle. OE # is active low.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| WE#                               | I    | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                                                                                                                                                         |
| BYTE#                             |      | <b>BYTE</b> # <b>ENABLE:</b> Controls whether the device operates in the byte-wide mode (x8) or the word-wide mode (x16). BYTE# pin must be controlled at CMOS levels to meet 100 $\mu$ A CMOS current in the standby mode. BYTE# = "0" enables the byte-wide mode, where data is read and programmed on DQ0-DQ7 and DQ15/A_1 becomes the lowest order address that decodes between the upper and lower byte. DQ8-DQ14 are tri-stated during the byte-wide mode. BYTE# = "1" enables the word-wide mode where data is read and programmed on DQ0-DQ15. |
| V <sub>PP</sub>                   |      | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.  Note: V <sub>PP</sub> < V <sub>PPLMAX</sub> memory contents cannot be altered.                                                                                                                                                                                                                                                                                                                                                                         |
| V <sub>CC</sub>                   |      | DEVICE POWER SUPPLY (5V ± 10%, 5V ± 5%)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| GND <sup>-</sup>                  |      | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| NC                                |      | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DU                                |      | DON'T USE PIN: Pin should not be connected to anything.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |





1.6 Pin Descriptions for x8 28F002BX

| Symbol                           | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>17</sub>  | I    | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                           |
| A <sub>9</sub>                   | I    | ADDRESS INPUT: When $A_9$ is at 12V the signature mode is accessed. During this mode $A_0$ decodes between the manufacturer and device ID's.                                                                                                                                                                                                                                                          |
| DQ <sub>0</sub> -DQ <sub>7</sub> | 1/0  | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the command user interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array, Intelligent Identifier and status register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled. |
| CE#                              | l    | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                          |
| #RP#                             | I    | RESET/DEEP POWERDOWN: Provides Three-State control. Puts the device in deep powerdown mode. Locks the Boot Block from program/erase.                                                                                                                                                                                                                                                                  |
|                                  |      | When RP# is at logic high level and equals 6.5V maximum the Boot Block is locked and cannot be programmed or erased.                                                                                                                                                                                                                                                                                  |
|                                  |      | When RP# = 11.4V minimum the Boot Block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                  |
|                                  |      | When RP# is at a logic low level the Boot Block is locked, the deep powerdown mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions. When RP# transitions from logic low to logic high, the flash memory enters the read-array mode.                                                               |
| OE#                              |      | OUTPUT ENABLE: Gates the device's outputs through the data buffers during a read cycle. OE # is active low.                                                                                                                                                                                                                                                                                           |
| WE#                              | 1    | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                        |
| V <sub>PP</sub>                  |      | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.  Note: V <sub>PP</sub> < V <sub>PPLMAX</sub> memory contents cannot be altered.                                                                                                                                                                                                                        |
| V <sub>CC</sub>                  |      | DEVICE POWER SUPPLY (5V $\pm$ 10%, 5V $\pm$ 5%)                                                                                                                                                                                                                                                                                                                                                       |
| GND                              |      | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                                                                                   |
| NC                               |      | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                       |
| DU                               |      | DON'T USE PIN: Pin should not be connected to anything.                                                                                                                                                                                                                                                                                                                                               |



# 2.0 28F200BX WORD/BYTE-WIDE PRODUCTS DESCRIPTION



Figure 6. 28F200BX Word/Byte-Wide Block Diagram



## 2.1 28F200BX Memory Organization

## 2.1.1 BLOCKING

The 28F200BX uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirm commands are written to the CUI. The 28F200BX is a random read/write memory, only erasure is performed by block.

# 2.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being written or erased when RP# is not at 12V. The boot block can be erased and written when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F200BX-T and 28F200BX-B.

## 2.1.1.2 Parameter Block Operation

The 28F200BX has 2 parameter blocks (8 Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. The parameter blocks provide for more efficient memory utilization when dealing with parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F200BX-T and 28F200BX-B.

## 2.1.1.3 Main Block Operation

Two main blocks of memory exist on the 28F200BX (1 x 128 Kbyte block and 1 x 96-Kbyte block). See the following section on Block Memory Map for the address location of these blocks for the 28F200BX-T and 28F200BX-B products.

## 2.1.2 BLOCK MEMORY MAP

Two versions of the 28F200BX product exist to support two different memory maps of the array blocks in order to accommodate different microprocessor protocols for boot code location. The 28F200BX-T memory map is inverted from the 28F200BX-B memory map.

## 2.1.2.1 28F200BX-B Memory Map

The 28F200BX-B device has the 16-Kbyte boot block located from 00000H to 01FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F200BX-B the first 8-Kbyte parameter block resides in memory space from 02000H to 02FFFH. The second 8-Kbyte parameter block resides in memory space from 03000H to 03FFFH. The 96-Kbyte main block resides in memory space from 04000H to 0FFFFH. The 128-Kbyte main block resides in memory space from 10000H to 1FFFFH (word locations). See Figure 7.



Figure 7. 28F200BX-B Memory Map



## 2.1.2.2 28F200BX-T Memory Map

The 28F200BX-T device has the 16-Kbyte boot block located from 1E000H to 1FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F200BX-T the first 8-Kbyte parameter block resides in memory space from 1D000H to 1DFFFH. The second 8-Kbyte parameter block resides in memory space from 1C000H to 1CFFFH. The 96-Kbyte main block resides in memory space from 10000H to 1BFFFH. The 128-Kbyte main block resides in memory space from 00000H to 0FFFFH as shown in Figure 8.



Figure 8. 28F200BX-T Memory Map

# 3.0 28F002BX BYTE-WIDE PRODUCTS DESCRIPTION





# 3.1 28F002BX Memory Organization

#### 3.1.1 BLOCKING

The 28F002BX uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirm commands are written to the CUI. The 28F002BX is a random read/write memory, only erasure is performed by block.

# 3.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being programmed or erased when RP# is not at 12V. The boot block can be erased and programmed when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while still providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F002BX-T and 28F002BX-B.

# 3.1.1.2 Parameter Block Operation

The 28F002BX has 2 parameter blocks (8 Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. Parameter blocks provide for more efficient memory utilization when dealing with small parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F002BX-T and 28F002BX-B.

# 3.1.1.3 Main Block Operation

Two main blocks of memory exist on the 28F002BX (1 x 128-Kbyte block and 1 x 96-Kbyte block). See the following section on Block Memory Map for address location of these blocks for the 28F002BX-T and 28F002BX-B.

# 3.1.2 BLOCK MEMORY MAP

Two versions of the 28F002BX product exist to support two different memory maps of the array blocks in order to accommodate different microprocessor protocols for boot code location. The 28F002BX-T memory map is inverted from the 28F002BX-B memory map.

# 3.1.2.1 28F002BX-B Memory Map

The 28F002BX-B device has the 16-Kbyte boot block located from 00000H to 03FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F002BX-B the first 8-Kbyte parameter block resides in memory from 04000H to 05FFFH. The second 8-Kbyte parameter block resides in memory space from 06000H to 07FFFH. The 96-Kbyte main block resides in memory space from 08000H to 1FFFFH. The 128-Kbyte main block resides in memory space from 20000H to 3FFFFH. See Figure 10.



Figure 10. 28F002BX-B Memory Map



# 3.1.2.2 28F002BX-T Memory Map

The 28F002BX-T device has the 16-Kbyte boot block located from 3C000H to 3FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F002BX-T the first 8-Kbyte parmeter block resides in memory space from 3A000H to 3BFFFH. The second 8-Kbyte parameter block resides in memory space from 38000H to 39FFFH. The 96-Kbyte main block resides in memory space from 20000H to 37FFFH. The 128-Kbyte main block resides in memory space from 00000H to 1FFFFH.



Figure 11. 28F002BX-T Memory Map

# 4.0 PRODUCT FAMILY PRINCIPLES OF OPERATION

Flash memory augments EPROM functionality with in-circuit electrical write and erase. The 2-Mbit flash

family utilizes a Command User Interface (CUI) and internally generated and timed algorithms to simplify write and erase operations.

The CUI allows for 100% TTL-level control inputs, fixed power supplies during erasure and programming, and maximum EPROM compatibility.

In the absence of high voltage on the V<sub>PP</sub> pin, the 2-Mbit boot block flash family will only successfully execute the following commands: Read Array, Read Status Register, Clear Status Register and Intelligent Identifier mode. The device provides standard EPROM read, standby and output disable operations. Manufacturer Identification and Device Identification data can be accessed through the CUI or through the standard EPROM A9 high voltage access (V<sub>ID</sub>) for PROM programming equipment.

The same EPROM read, standby and output disable functions are available when high voltage is applied to the V<sub>PP</sub> pin. In addition, high voltage on V<sub>PP</sub> allows write and erase of the device. All functions associated with altering memory contents: write and erase, Intelligent Identifier read and Read Status are accessed via the CUI.

The purpose of the Write State Machine (WSM) is to completely automate the write and erasure of the device. The WSM will begin operation upon receipt of a signal from the CUI and will report status back through a Status Register. The CUI will handle the WE# interface to the data and address latches, as well as system software requests for status while the WSM is in operation.

# 4.1 28F200BX Bus Operations

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles.



Table 1. Bus Operations for WORD-WIDE Mode (BYTE  $\# = V_{IH}$ )

| Mode                            | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-15</sub> |
|---------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х               | D <sub>OUT</sub>   |
| Output Disable                  |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | High Z             |
| Standby                         |         | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х               | High Z             |
| Deep Power-Down                 | 9       | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х               | Х               | High Z             |
| Intelligent Identifier (Mfr)    | 4       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х               | 0089H              |
| Intelligent Identifier (Device) | 4, 5    | V <sub>IH</sub> | V <sub>IL</sub> | VIL             | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | 2274H<br>2275H     |
| Write                           | 6, 7, 8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х               | D <sub>IN</sub>    |

# Table 2. Bus Operations for BYTE-WIDE Mode (BYTE $\# = V_{IL}$ )

| Mode                               | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | A_1 | V <sub>PP</sub> | DQ <sub>0-7</sub> | DQ <sub>8-14</sub> |
|------------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|-----------------|-------------------|--------------------|
| Read                               | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х   | Х               | DOUT              | High Z             |
| Output Disable                     |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х   | Х               | High Z            | High Z             |
| Standby                            |         | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | Х               | Х   | Х               | High Z            | High Z             |
| Deep Power-Down                    | 9       | VIL             | Х               | Х               | Х               | Х               | Х               | Х   | Х               | High Z            | High Z             |
| Intelligent Identifier (Mfr)       | 4       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $V_{ID}$        | VIL             | Х   | Х               | 89H               | High Z             |
| Intelligent Identifier<br>(Device) | 4, 5    | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х   | Х               | 74H<br>75H        | High Z             |
| Write                              | 6, 7, 8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | VIL             | Х               | Х               | Х   | Х               | D <sub>IN</sub>   | High Z             |

- 1. Refer to DC Characteristics.
- 2. X can be V<sub>IL</sub> or V<sub>IH</sub> for control pins and addresses, V<sub>PPL</sub> or V<sub>PPH</sub> for V<sub>PP</sub>.
- 3. See DC characteristics for V<sub>PPL</sub>, V<sub>PPH</sub>, V<sub>HH</sub>, V<sub>ID</sub> voltages.
- 4. Manufacturer and Device codes may also be accessed via a CUI write sequence.  $A_1 A_{17} = X$ .
- 5. Device ID = 2274H for 28F200BX-T and 2275H for 28F200BX-B.
- 6. Refer to Table 4 for valid DIN during a write operation.
- 7. Command writes for Block Erase or Word/Byte Write are only executed when VPP = VPPH.
- 8. To write or erase the boot block, hold RP# at VHH.
- 9. RP# must be at GND  $\pm 0.2$ V to meet the 1.2  $\mu$ A maximum deep power-down current.



# 4.2 28F002BX Bus Operations

**Table 3. Bus Operations** 

| Mode                            | Notes   | RP#               | CE#             | OE#              | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | VPP | DQ <sub>0-7</sub> |
|---------------------------------|---------|-------------------|-----------------|------------------|-----------------|-----------------|-----------------|-----|-------------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IL</sub>  | V <sub>IH</sub> | Х               | X               | Х   | D <sub>OUT</sub>  |
| Output Disable                  |         | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IH</sub>  | VIH             | Х               | Х               | Х   | High Z            |
| Standby                         |         | V <sub>IH</sub>   | V <sub>IH</sub> | ×                | Х               | Х               | Х               | Х   | High Z            |
| Deep Power-Down                 | ' 9     | √ V <sub>IL</sub> | Х               | X                | Х               | Х               | Х               | X,  | High Z            |
| Intelligent Identifier (Mfr)    | 4       | V <sub>IH</sub>   | V <sub>IL</sub> | VIL              | VIH             | V <sub>ID</sub> | V <sub>IL</sub> | Х   | 89H               |
| Intelligent Identifier (Device) | 4, 5    | V <sub>IH</sub>   | V <sub>IL</sub> | V <sub>IL</sub>  | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | X   | 7CH<br>7DH        |
| Write                           | 6, 7, 8 | V <sub>IH</sub>   | V <sub>IL</sub> | ·V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х   | D <sub>IN</sub>   |

#### NOTES:

- 1. Refer to DC Characteristics.
- 2. X can be VIL or VIH for control pins and addresses, VPPL or VPPH for VPP.
- 3. See DC characteristics for V<sub>PPL</sub>, V<sub>PPH</sub>, V<sub>HH</sub>, V<sub>ID</sub> voltages.
- 4. Manufacturer and Device codes may also be accessed via a CUI write sequence.  $A_1-A_{16}=X$ .
- 5. Device ID = 7CH for 28F002BX-T and 7DH for 28F002BX-B.
- 6. Refer to Table 4 for valid D<sub>IN</sub> during a write operation.
- Command writes for Block Erase or byte program are only executed when V<sub>PP</sub> = V<sub>PPH</sub>.
- 8. Program or erase the Boot block by holding RP# at VHH.
- 9. RP# must be at GND ±0.2V to meet the 1.2 μA maximum deep power-down current.

# 4.3 Read Operations

The 2-Mbit boot block flash family has three user read modes; Array, Intelligent Identifier, and Status Register. Status Register read mode will be discussed in detail in the "Write Operations" section.

During power-up conditions ( $V_{CC}$  supply ramping), it takes a maximum of 600 ns from when  $V_{CC}$  is at 4.5V minimum to valid data on the outputs.

## 4.3.1 READ ARRAY

If the memory is not in the Read Array mode, it is necessary to write the appropriate read mode command to the CUI. The 2-Mbit boot block flash family has three control functions, all of which must be logically active, to obtain data at the outputs. Chip-Enable CE# is the device selection control. Power-Down RP# is the device power control. Output-Enable OE# is the DATA INPUT/OUTPUT (DQ[0:15] or DQ[0:7]) direction control and when active is used to drive data from the selected memory on to the I/O bus.

# 4.3.1.1 Output Control

With OE# at logic-high level ( $V_{IH}$ ), the output from the device is disabled and data input/output pins

(DQ[0:15] or DQ[0:7]) are tri-stated. Data input is then controlled by WE#.

# 4.3.1.2 Input Control

With WE# at logic-high level (V<sub>IH</sub>), input to the device is disabled. Data Input/Output pins (DQ-[0:15] or DQ[0:7]) are controlled by OE#.

# 4.3.2 INTELLIGENT IDENTIFIERS

#### 28F200BX Products

The manufacturer and device codes are read via the CUI or by taking the  $A_9$  pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 0089H, and location 00001H outputs the device code; 2274H for 28F200BX-B. When BYTE# is at a logic low only the lower byte of the above signatures is read and  $DQ_{15}/A_{-1}$  is a "don't care" during Intelligent Identifier mode. A read array command must be written to the CUI to return to the read array mode.



#### 28F002BX Products

The manufacturer and device codes are also read via the CUI or by taking the A9 pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 89H, and location 00001H outputs the device code; 7CH for 28F002BX-T, 7DH for 28F002BX-B.

# 4.4 Write Operations

Commands are written to the CUI using standard microprocessor write timings. The CUI serves as the interface between the microprocessor and the internal chip operation. The CUI can decipher Read Array, Read Intelligent Identifier, Read Status Register, Clear Status Register, Erase and Program commands. In the event of a read command, the CUI simply points the read path at either the array, the intelligent identifier, or the status register depending on the specific read command given. For a program or erase cycle, the CUI informs the write state machine that a write or erase has been requested. During a program cycle, the Write State Machine will control the program sequences and the CUI will only respond to status reads. During an erase cycle, the CUI will respond to status reads and erase suspend. After the Write State Machine has completed its task, it will allow the CUI to respond to its full command set. The CUI will stay in the current command state until the microprocessor issues another command.

The CUI will successfully initiate an erase or write operation only when V<sub>PP</sub> is within its voltage range. Depending upon the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable, available only when memory updates are desired. The system designer can also choose to "hard-wire" V<sub>PP</sub> to 12V. The 2 Mbit boot block flash family is designed to accommodate either design practice. It is recommended that RP# be tied to logical Reset for data protection during unstable CPU reset function as described in the "Product Family Overview" section.

# 4.4.1 BOOT BLOCK WRITE OPERATIONS

In the case of Boot Block modifications (write and erase), RP# is set to  $V_{HH}=12V$  typically, in addition to  $V_{PP}$  at high voltage. However, if RP# is not at  $V_{HH}$  when a program or erase operation of the boot block is attempted, the corresponding status register bit (Bit 4 for Program and Bit 5 for Erase, refer to Table 5 for Status Register Definitions) is set to indicate the failure to complete the operation.

# 4.4.2 COMMAND USER INTERFACE (CUI)

The Command User Interface (CUI) serves as the interface to the microprocessor. The CUI points the read/write path to the appropriate circuit block as described in the previous section. After the WSM has completed its task, it will set the WSM Status bit to a "1", which will also allow the CUI to respond to its full command set. Note that after the WSM has returned control to the CUI, the CUI will remain in its current state.

#### 4.4.2.1 Command Set

| Command<br>Codes | Device Mode                |
|------------------|----------------------------|
| 00               | Invalid/Reserved           |
| 10               | Alternate Program Setup    |
| 20               | Erase Setup                |
| 40               | Program Setup              |
| 50               | Clear Status Register      |
| 70               | Read Status Register       |
| 90               | Intelligent Identifier     |
| В0               | Erase Suspend              |
| D0               | Erase Resume/Erase Confirm |
| FF               | Read Array                 |

## 4.4.2.2 Command Function Descriptions

Device operations are selected by writing specific commands into the CUI. Table 4 defines the 2-Mbit boot block flash family commands.



**Table 4. Command Definitions** 

| Command                               | Bus<br>Cycles | Notes | First     | Bus Cycle | ,    | Second Bus Cycle |         |      |  |
|---------------------------------------|---------------|-------|-----------|-----------|------|------------------|---------|------|--|
|                                       | Req'd         | - 8   | Operation | Address   | Data | Operation        | Address | Data |  |
| Read Array/Reset                      | 1             | 1     | Write     | Х         | FFH  |                  |         |      |  |
| Intelligent Identifier                | 3             | 2, 4  | Write     | Х         | 90H  | Read             | IA      | IID  |  |
| Read Status Register                  | 2             | 3     | Write     | Х         | 70H  | Read             | Х       | SRD  |  |
| Clear Status Register                 | 1             |       | Write     | X.        | 50H  |                  |         |      |  |
| Erase Setup/Erase Confirm             | 2             | 5     | Write     | ВА        | 20H  | Write            | BA      | DOH  |  |
| Word/Byte Write Setup/Write           | 2             | 6, 7  | Write     | WA        | 40H  | Write            | WA      | WD   |  |
| Erase Suspend/Erase Resume            | . 2           |       | Write     | Х         | вон  | Write            | Х       | DOH  |  |
| Alternate Word/Byte Write Setup/Write | 2             | 6, 7  | Write     | WA        | 10H  | Write            | WA      | WD   |  |

#### NOTES:

- 1. Bus operations are defined in Tables 1, 2, 3.
- 2. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
- 3. SRD = Data read from Status Register.
- 4. IID = Intelligent Identifier Data.

Following the Intelligent Identifier Command, two read operations access manufacturer and device codes.

- 5. BA = Address within the block being erased.
- 6. PA = Address to be programmed.
- PD = Data to be programmed at location PA.
- 7. Either 40H or 10H command is valid.
- 8. When writing commands to the device, the upper data bus [DQ8-DQ15] = X (28F200BX-only) which is either  $V_{CC}$  or  $V_{SS}$  to avoid burning additional current.

#### Invalid/Reserved

These are unassigned commands. It is not recommended that the customer use any command other than the valid commands specified above. Intel reserves the right to redefine these codes for future functions.

# Read Array (FFH)

This single write command points the read path at the array. If the host CPU performs a CE#/OE# controlled read immediately following a two-write sequence that started the WSM, then the device will output status register contents. If the Read Array command is given after Erase Setup the device is reset to read the array. A two Read Array command sequence (FFH) is required to reset to Read Array after Program Setup.

# Inteligent Identifier (90H)

After this command is executed, the CUI points the output path to the Intelligent Identifier circuits. Only Intelligent Identifier values at addresses 0 and 1 can be read (only address A0 is used in this mode, all other address inputs are ignored).

#### Read Status Register (70H)

This is one of the two commands that is executable while the state machine is operating. After this command is written, a read of the device will output the contents of the status register, regardless of the address presented to the device.

The device automatically enters this mode after program or erase has completed.

## Clear Status Register (50H)

The WSM can only set the Program Status and Erase Status bits in the status register, it can not clear them. Two reasons exist for operating the status register in this fashion. The first is a synchronization. The WSM does not know when the host CPU has read the status register, therefore it would not know when to clear the status bits. Secondly, if the CPU is programming a string of bytes, it may be more efficient to query the status register after programming the string. Thus, if any errors exist while programming the string, the status register will return the accumulated error status.



# Program Setup (40H or 10H)

This command simply sets the CUI into a state such that the next write will load the address and data registers. Either 40H or 10H can be used for Program Setup. Both commands are included to accommodate efforts to achieve an industry standard command code set.

# **Program**

The second write after the program setup command, will latch addresses and data. Also, the CUI initiates the WSM to begin execution of the program algorithm. While the WSM finishes the algorithm, the device will output Status Register contents. Note that the WSM cannot be suspended during programming.

# Erase Setup (20H)

Prepares the CUI for the Erase Confirm command. No other action is taken. If the next command is not an Erase Confirm command then the CUI will set both the Program Status and Erase Status bits of the Status Register to a "1", place the device into the Read Status Register state, and wait for another command.

# Erase Confirm (D0H)

If the previous command was an Erase Setup command, then the CUI will enable the WSM to erase, at the same time closing the address and data latches, and respond only to the Read Status Register and Erase Suspend commands. While the WSM is executing, the device will output Status Register data when OE# is toggled low. Status Register data can only be updated by toggling either OE# or CE# low.

# Erase Suspend (B0H)

This command only has meaning while the WSM is executing an Erase operation, and therefore will only be responded to during an erase operation. After this command has been executed, the CUI will set an output that directs the WSM to suspend Erase operations, and then return to responding to only Read Status Register or to the Erase Resume commands. Once the WSM has reached the Suspend state, it will set an output into the CUI which allows the CUI to respond to the Read Array, Read Status Register, and Erase Resume commands. In this mode, the CUI will not respond to any other commands. The WSM will also set the WSM Status bit to a "1". The WSM will continue to run, idling in the SUSPEND state, regardless of the state of all input

control pins, with the exclusion of RP#. RP# will immediately shut down the WSM and the remainder of the chip. During a suspend operation, the data and address latches will remain closed, but the address pads are able to drive the address into the read path.

# Erase Resume (D0H)

This command will cause the CUI to clear the Suspend state and set the WSM Status bit to a "0", but only if an Erase Suspend command was previously issued. Erase Resume will not have any effect in all other conditions.

## 4.4.3 STATUS REGISTER

The 2-Mbit boot block flash family contains a status register which may be read to determine when a program or erase operation is complete, and whether that operation completed successfully. The status register may be read at any time by writing the Read Status command to the CUI. After writing this command, all subsequent Read operations output data from the status register until another command is written to the CUI. A Read Array command must be written to the CUI to return to the Read Array mode.

The status register bits are output on DQ[0:7] whether the device is in the byte-wide (x8) or word-wide (x16) mode for the 28F200BX. In the word-wide mode the upper byte, DQ[8:15] is set to 00H during a Read Status command. In the byte-wide mode, DQ[8:14] are tri-stated and DQ15/A-1 retains the low order address function.

It should be noted that the contents of the status register are latched on the falling edge of OE# or CE# whichever occurs last in the read cycle. This prevents possible bus errors which might occur if the contents of the status register change while reading the status register. CE# or OE# must be toggled with each subsequent status read, or the completion of a program or erase operation will not be evident.

The Status Register is the interface between the microprocessor and the Write State Machine (WSM). When the WSM is active, this register will indicate the status of the WSM, and will also hold the bits indicating whether or not the WSM was successful in performing the desired operation. The WSM sets status bits "Three" through "Seven" and clears bits "Six" and "Seven", but cannot clear status bits "Three" through "Five". These bits can only be cleared by the controlling CPU through the use of the Clear Status Register command.



# 4.4.3.1 Status Register Bit Definition

# **Table 5. Status Register Definitions**



#### NOTES:

SR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

SR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

SR.4 = PROGRAM STATUS

1 = Error in Byte/Word Program0 = Successful Byte/Word Program

SR.3 = V<sub>PP</sub> STATUS

1 = V<sub>PP</sub> Low Detect; Operation Abort

 $0 = V_{PP} OK$ 

SR.2-SR.0 = RESERVED FOR FUTURE ENHANCE-MENTS

Write State Machine Status bit must first be checked to determine byte/word program or block erase completion, before the Program or Erase Status bits are checked for success.

When Erase Suspend is issued, WSM halts execution and sets both WSMS and ESS bits to "1" ESS bit remains set to "1" until an Erase Resume command is issued

When this bit is set to "1". WSM has applied the maximum number of erase pulses to the block and is still unable to successfully perform an erase verify.

When this bit is set to "1", WSM has attempted but failed to Program a byte or word.

The V<sub>PP</sub> Status bit, unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM interrogates the V<sub>PP</sub> level only after the byte write or block erase command sequences have been entered and informs the system if V<sub>PP</sub> has not been switched on. The V<sub>PP</sub> Status bit is not guaranteed to report accurate feedback between V<sub>PPL</sub> and V<sub>PPH</sub>.

These bits are reserved for future use and should be masked out when polling the Status Register.

## 4.4.3.2 Clearing the Status Register

Certain bits in the status register are set by the write state machine, and can only be reset by the system software. These bits can indicate various failure conditions. By allowing the system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several bytes or erasing multiple blocks in sequence). The status register may then be read to determine if an error occurred during that programming or erasure series. This adds flexibility to the way the device may be programmed or erased. To clear the status register, the Clear Status Register command is written to the CUI. Then, any other command may be issued to the CUI. Note again that before a read cycle can be initiated, a Read Array command must be written to the CUI to specify whether the read data is to come from the array, status register, or Intelligent Identifier.

# 4.4.4 PROGRAM MODE

Program is executed by a two-write sequence. The Program Setup command is written to the CUI followed by a second write which specifies the address and data to be programmed. The write state machine will execute a sequence of internally timed events to:

- Program the desired bits of the addressed memory word (byte), and
- Verify that the desired bits are sufficiently programmed

Programming of the memory results in specific bits within a byte or word being changed to a "0".

If the user attempts to program "1"s, there will be no change of the memory cell content and no error occurs.

Similar to erasure, the status register indicates whether programming is complete. While the program sequence is executing, bit 7 of the status register is a "0". The status register can be polled by



toggling either CE# or OE# to determine when the program sequence is complete. Only the Read Status Register command is valid while programming is active.

When programming is complete, the status bits, which indicate whether the program operation was successful, should be checked. If the programming operation was unsuccessful, Bit 4 of the status register is set to a "1" to indicate a Program Failure. If Bit 3 is set then V<sub>PP</sub> was not within acceptable limits, and the WSM will not execute the programming sequence.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after programming is completed; however, it must be recognized that reads from the memory, status register, or Intelligent Identifier cannot be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 12 shows a system software flowchart for device byte programming operation. Figure 13 shows a similar flowchart for device word programming operation (28F200BX-only).

#### 4.4.5 ERASE MODE

Erasure of a single block is initiated by writing the Erase Setup and Erase Confirm commands to the CUI, along with the addresses, A[12:16] for the 28F200BX or A[12:17] for the 28F002BX, identifying the block to be erased. These addresses are latched internally when the Erase Confirm command is issued. Block erasure results in all bits within the block being set to "1".

The WSM will execute a sequence of internally timed events to:

- 1. Program all bits within the block
- Verify that all bits within the block are sufficiently programmed
- 3. Erase all bits within the block and
- 4. Verify that all bits within the block are sufficiently erased

While the erase sequence is executing, Bit 7 of the status register is a "0".

When the status register indicates that erasure is complete, the status bits, which indicate whether the erase operation was successful, should be checked. If the erasure operation was unsuccessful, Bit 5 of the status register is set to a "1" to indicate an Erase Failure. If V<sub>PP</sub> was not within acceptable limits after the Erase Confirm command is issued, the WSM will not execute an erase sequence; instead, Bit 5 of the status register is set to a "1" to indicate

an Erase Failure, and Bit 3 is set to a "1" to identify that  $V_{PP}$  supply voltage was not within acceptable limits.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after erasure is completed; however, it must be recognized that reads from the memory array, status register, or Intelligent Identifier can not be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 14 shows a system software flowchart for Block Erase operation.

# 4.4.5.1 Suspending and Resuming Erase

Since an erase operation typically requires 1 to 3 seconds to complete, an Erase Suspend command is provided. This allows erase-sequence interruption in order to read data from another block of the memory. Once the erase sequence is started, writing the Erase Suspend command to the CUI requests that the Write State Machine (WSM) pause the erase sequence at a predetermined point in the erase algorithm. The status register must be read to determine when the erase operation has been suspended.

At this point, a Read Array command can be written to the CUI in order to read data from blocks other than that which is being suspended. The only other valid command at this time is the Erase Resume command or Read Status Register operation.

Figure 15 shows a system software flowchart detailing the operation.

During Erase Suspend mode, the chip can go into a pseudo-standby mode by taking CE# to  $V_{IH}$  and the active current is now a maximum of 10 mA. If the chip is enabled while in this mode by taking CE# to  $V_{IL}$ , the Erase Resume command can be issued to resume the erase operation.

Upon completion of reads from any block other than the block being erased, the Erase Resume command must be issued. When the Erase Resume command is given, the WSM will continue with the erase sequence and complete erasing the block. As with the end of erase, the status register must be read, cleared, and the next instruction issued in order to continue.

# 4.4.6 EXTENDED CYCLING

Intel has designed extended cycling capability into its ETOX III flash memory technology. The 2-Mbit boot block flash family is designed for 100,000 program/erase cycles on each of the five blocks. The combination of low electric fields, clean oxide processing and minimized oxide area per memory cell subjected to the tunneling electric field, results in very high cycling capability.







Figure 12. Automated Byte Programming Flowchart





Figure 13. Automated Word Programming Flowchart





| Bus<br>Operation | Command        | Comments                                                          |
|------------------|----------------|-------------------------------------------------------------------|
| Write            | Setup<br>Erase | Data = 20H<br>Address = Within block to be<br>erased              |
| Write            | Erase          | Data = D0H<br>Address = Within block to be<br>erased              |
| Read             |                | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent blocks.

Full status check can be done after each block or after a sequence of blocks.

Write FFH after the last block erase operation to reset the device to Read Array Mode.

# **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4,5 Both 1 = Command Sequence Error |
| Standby          |         | Check SR.5<br>1 = Block Erase Error          |

SR.3 MUST be cleared, if set during an erase attempt, before further attempts are allowed by the Write State Machine.

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 14. Automated Block Erase Flowchart





Figure 15. Erase Suspend/Resume Flowchart

# 4.5 Power Consumption

## 4.5.1 ACTIVE POWER

With CE# at a logic-low level and RP# at a logic-high level, the device is placed in the active mode. The device  $I_{CC}$  current is a maximum of 60 mA at 10 MHz with TTL input signals.

# 4.5.2 AUTOMATIC POWER SAVINGS

Automatic Power Savings (APS) is a low power feature during active mode of operation. The 2-Mbit family of products incorporate Power Reduction Control (PRC) circuitry which basically allows the device to put itself into a low current state when it is not being accessed. After data is read from the memory array, PRC logic controls the device's power consumption by entering the APS mode where

maximum I<sub>CC</sub> current is 3 mA and typical I<sub>CC</sub> current is 1 mA. The device stays in this static state with outputs valid until a new location is read.

# 4.5.3 STANDBY POWER

With CE# at a logic-high level ( $V_{IH}$ ), and the CUI in read mode, the memory is placed in standby mode where the maximum  $I_{CC}$  standby current is 100  $\mu$ A with CMOS input signals. The standby operation disables much of the device's circuitry and substantially reduces device power consumption. The outputs (DQ[0:15] or DQ[0:7]) are placed in a high-impedance state independent of the status of the OE# signal. When the 2-Mbit boot block flash family is deselected during erase or program functions, the devices will continue to perform the erase or program function and consume program or erase active power until program or erase is completed.



#### 4.5.4 RESET/DEEP POWER-DOWN

The 2-Mbit boot block flash family supports a typical  $I_{CC}$  of 0.2  $\mu$ A in deep power-down mode. One of the target markets for these devices is in portable equipment where the power consumption of the machine is of prime importance. The 2-Mbit boot block flash family has a RP# pin which places the device in the deep power-down mode. When RP# is at a logic-low (GND  $\pm$ 0.2V), all circuits are turned off and the device typically draws 0.2  $\mu$ A of  $V_{CC}$  current.

During read modes, the RP# pin going low deselects the memory and places the output drivers in a high impedance state. Recovery from the deep power-down state, requires a maximum of 300 ns to access valid data (tpHOV).

During erase or program modes, RP# low will abort either erase or program operation. The contents of the memory are no longer valid as the data has been corrupted by the RP# function. As in the read mode above, all internal circuitry is turned off to achieve the 0.2 µA current level.

RP# transitions to  $V_{IL}$  or turning power off to the device will clear the status register.

This use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset it expects to read from the flash memory. Automated flash memories provide status information when accessed during write/erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input. In this application RP# is controlled by the same RESET# signal that resets the system CPU.

# 4.6 Power-Up Operation

The 2-Mbit boot block flash family is designed to offer protection against accidental block erasure or programming during power transitions. Upon power-up the 2-Mbit boot block flash family is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers-up first. Power suppy sequencing is not required.

The 2-Mbit boot block flash family ensures the CUI is reset to the read mode on power-up.

In addition, on power-up the user must either drop CE# low or present a new address to ensure valid data at the outputs.

A system designer must guard against spurious writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is

active. Since both WE# and CE# must be low for a command write, driving either signal to  $V_{IH}$  will inhibit writes to the device. The CUI architecture provides an added level of protection since alteration of memory contents can only occur after successful completion of the two-step command sequences. Finally, the device is disabled until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. This feature provides yet another level of memory protection.

# 4.7 Power Supply Decoupling

Flash memory's power switching characteristics require careful device decoupling methods. System designers are interested in 3 supply current issues:

- Standby current levels (I<sub>CCS</sub>)
- Active current levels (I<sub>CCR</sub>)
- Transient peaks produced by falling and rising edges of CE#.

Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress these transient voltage peaks. Each flash device should have a 0.1  $\mu F$  ceramic capacitor connected between each  $V_{CC}$  and GND, and between its  $V_{PP}$  and GND. These high frequency, low-inherent inductance capacitors should be placed as close as possible to the package leads.

# 4.7.1 V<sub>PP</sub> TRACE ON PRINTED CIRCUIT BOARDS

Writing to flash memories while they reside in the target system, requires special consideration of the  $V_{PP}$  power supply trace by the printed circuit board designer. The  $V_{PP}$  pin supplies the flash memory cell's current for programming and erasing. One should use similar trace widths and layout considerations given to the  $V_{CC}$  power supply trace. Adequate  $V_{PP}$  supply traces and decoupling will decrease spikes and overshoots.

# 4.7.2 V<sub>CC</sub>, V<sub>PP</sub> AND RP# TRANSITIONS

The CUI latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its state upon power-up, after exit from deep power-down mode or after  $V_{CC}$  transitions below  $V_{LKO}$  (Lockout voltage), is Read Array mode.

After any word/byte write or block erase operation is complete and even after  $V_{PP}$  transitions down to  $V_{PPL}$ , the CUI must be reset to Read Array mode via the Read Array command when accesses to the flash memory are desired.



# **ABSOLUTE MAXIMUM RATINGS\***

| Commercial Operating Temperature  During Read0°C to 70°C(1)  During Block Erase  and Word/Byte Write0°C to 70°C  Temperature Under Bias |
|-----------------------------------------------------------------------------------------------------------------------------------------|
| Extended Operating Temperature  During Read                                                                                             |
| Storage Temperature65°C to +125°C                                                                                                       |
| Voltage on Any Pin (except $V_{CC}$ , $V_{PP}$ , $A_9$ and $RP\#$ ) with Respect to GND $-2.0V$ to $+7.0V$ <sup>(2)</sup>               |
| Voltage on Pin RP# or Pin A <sub>9</sub> with Respect to GND $\dots$ -2.0V to +13.5V(2, 3)                                              |
| V <sub>PP</sub> Program Voltage with Respect<br>to GND during Block Erase<br>and Word/Byte Write – 2.0V to +14.0V <sup>(2, 3)</sup>     |
| V <sub>CC</sub> Supply Voltage with Respect to GND2.0V to +7.0V(2)                                                                      |
| Output Short Circuit Current                                                                                                            |

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

1. Operating temperature is for commercial product defined by this specification.

2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC}+0.5$ V which, during transitions, may overshoot to  $V_{CC}+2.0$ V for periods <20 ns.

3. Maximum DC voltage on  $V_{PP}$  may overshoot to  $\pm 14.0 V$  for periods <20 ns. Maximum DC voltage on RP# or A9 may overshoot to 13.5V for periods < 20 ns.

4. Output shorted for no more than one second. No more than one output shorted at a time.

5.  $10\% V_{CC}$  specifications reference the 28F200BX-60/28F002BX-60 in their standard test configuration, and the 28F200BX-80/28F002BX-80.

6. 5% V<sub>CC</sub> specifications reference the 28F200BX-60/28F002BX-60 in their high speed test configuration.

# **OPERATING CONDITIONS**

| Symbol          | pol Parameter                        |   | Min  | Max  | Units |
|-----------------|--------------------------------------|---|------|------|-------|
| TA              | Operating Temperature                |   | 0    | 70   | °C    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (10%) | 5 | 4.50 | 5.50 | V     |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (5%)  | 6 | 4.75 | 5.25 | V     |

# DC CHARACTERISTICS

| Symbol | Parameter              | Notes | Min | Тур | Max   | Unit | Test Condition                                     |
|--------|------------------------|-------|-----|-----|-------|------|----------------------------------------------------|
| ILI    | Input Load Current     | 1     |     |     | ± 1.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$  |
| lLO    | Output Leakage Current | 1     |     |     | ±10   | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$ |



# DC CHARACTERISTICS (Continued)

| Symbol           | Parameter                                                                        | Notes          | Min  | Тур      | Max                   | Unit | Test Condition                                                                                                    |
|------------------|----------------------------------------------------------------------------------|----------------|------|----------|-----------------------|------|-------------------------------------------------------------------------------------------------------------------|
| lccs             | V <sub>CC</sub> Standby Current                                                  | 1, 3           |      |          | 1.5                   | mΑ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = RP# = V <sub>IH</sub>                                              |
|                  |                                                                                  |                |      |          | 100                   | μА   | $V_{CC} = V_{CC}$ Max<br>$CE\# = RP\# = V_{CC} \pm 0.2V$<br>28F200BX:<br>$BYTE\# = V_{CC} \pm 0.2V$ or GND        |
| ICCD             | V <sub>CC</sub> Deep Power-Down Current                                          | 1              |      | 0.20     | 1.2                   | μΑ   | $RP# = GND \pm 0.2V$                                                                                              |
| ICCR             | V <sub>CC</sub> Read Current for<br>28F200BX Word-Wide and<br>Byte-Wide Mode and | 1, 5,<br>6, 10 |      | 20       | 55                    | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>$f_{(max)} = 10$ MHz, $f_{(typ)} = 5$ MHz<br>$I_{OUT} = 0$ mA, CMOS Inputs |
|                  | 28F002BX Byte-Wide Mode                                                          |                |      | 20       | 60                    | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>$f_{(max)} = 10$ MHz, $f_{(typ)} = 5$ MHz<br>$I_{OUT} = 0$ mA, TTL Inputs  |
| Iccw             | V <sub>CC</sub> Word Byte Write Current                                          | 1, 4           |      |          | 65                    | mΑ   | Word Write in Progress                                                                                            |
| ICCE             | V <sub>CC</sub> Block Erase Current                                              | 1, 4           |      |          | 30                    | mΑ   | Block Erase in Progress                                                                                           |
| ICCES            | V <sub>CC</sub> Erase Suspend Current                                            | 1, 2           |      | 5        | 10                    | mA   | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                                                   |
| IPPS             | V <sub>PP</sub> Standby Current                                                  | 1              |      |          | ± 1.5                 | μΑ   | $V_{PP} \leq V_{CC}$                                                                                              |
| I <sub>PPD</sub> | V <sub>PP</sub> Deep Power-Down Current                                          | 1              |      |          | 5.0                   | μΑ   | RP# = GND ±0.2V RP#                                                                                               |
| IPPR             | V <sub>PP</sub> Read Current                                                     | 1              |      |          | 200                   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                                                                 |
| I <sub>PPW</sub> | V <sub>PP</sub> Word Write Current                                               | 1, 4           |      |          | 40                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress                                                      |
| I <sub>PPW</sub> | V <sub>PP</sub> Byte Write Current                                               | 1, 4           | ,    |          | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                                                      |
| IPPE             | V <sub>PP</sub> Block Erase Current                                              | 1, 4           |      |          | 30                    | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                                                     |
| IPPES            | V <sub>PP</sub> Erase Suspend Current                                            | 1              |      |          | 200                   | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                                                       |
| I <sub>RP#</sub> | RP# Boot Block Unlock Current                                                    | 1, 4           |      |          | 500                   | μΑ   | RP# = V <sub>HH</sub>                                                                                             |
| l <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current                                    | 1, 4           |      |          | 500                   | μΑ   | $A_9 = V_{ID}$                                                                                                    |
| $V_{ID}$         | A <sub>9</sub> Intelligent Identifier Voltage                                    |                | 11.5 |          | 13.0                  | ٧    |                                                                                                                   |
| V <sub>IL</sub>  | Input Low Voltage                                                                |                | -0.5 | <u> </u> | 0.8                   | ٧    |                                                                                                                   |
| V <sub>IH</sub>  | Input High Voltage                                                               |                | 2.0  |          | V <sub>CC</sub> + 0.5 | ٧    |                                                                                                                   |
| V <sub>OL</sub>  | Output Low Voltage                                                               |                |      |          | 0.45                  | ٧    | V <sub>CC</sub> = V <sub>CC</sub> Min<br>I <sub>OL</sub> = 5.8 mA                                                 |



# DC CHARACTERISTICS (Continued)

| Symbol           | Parameter                                     | Notes | Min                   | Тур  | Max  | Unit | Test Condition                              |
|------------------|-----------------------------------------------|-------|-----------------------|------|------|------|---------------------------------------------|
| V <sub>OH1</sub> | Output High Voltage (TTL)                     |       | 2.4                   |      |      | >    | $V_{CC} = V_{CC} Min$<br>$I_{OH} = -2.5 mA$ |
| V <sub>OH2</sub> | Output High Voltage (CMOS)                    |       | 0.85 V <sub>CC</sub>  |      |      | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$    |
|                  |                                               |       | V <sub>CC</sub> - 0.4 |      |      |      | $V_{CC} = V_{CC} Min$ $I_{OH} = -100 \mu A$ |
| V <sub>PPL</sub> | V <sub>PP</sub> during Normal Operations      | 3     | 0.0                   |      | 6.5  | ٧    |                                             |
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write Operations | 7     | 11.4                  | 12.0 | 12.6 | >    |                                             |
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write Operations | 8     | 10.8                  | 12.0 | 13.2 | ٧    |                                             |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.0                   |      |      | ٧    |                                             |
| $V_{HH}$         | RP# Unlock Voltage                            |       | 11.5                  |      | 13.0 | ٧    | Boot Block Write/Erase                      |

# **EXTENDED TEMPERATURE OPERATING CONDITIONS**

| Symbol          | Parameter                            | Notes | Min  | Max  | Units |
|-----------------|--------------------------------------|-------|------|------|-------|
| TA              | Operating Temperature                |       | -40  | +85  | °C    |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (10%) | 5     | 4.50 | 5.50 | ٧     |

# DC CHARACTERISTICS: EXTENDED TEMPERATURE OPERATION

| Symbol           | Parameter                                                                        | Notes      | Min | Тур  | Max  | Unit | Test Condition                                                                                             |
|------------------|----------------------------------------------------------------------------------|------------|-----|------|------|------|------------------------------------------------------------------------------------------------------------|
| ILI              | Input Load Current                                                               | 1          |     |      | ±1.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                                          |
| I <sub>LO</sub>  | Output Leakage Current                                                           | 1          |     |      | ±10  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                                         |
| Iccs             | V <sub>CC</sub> Standby Current                                                  | 1, 3       |     |      | 1.5  | mA   | $V_{CC} = V_{CC} Max$ $CE\# = RP\# = V_{IH}$                                                               |
|                  |                                                                                  |            |     |      | 100  | μА   | $V_{CC} = V_{CC}$ Max<br>$CE\# = RP\# = V_{CC} \pm 0.2V$<br>28F200BX:<br>$BYTE\# = V_{CC} \pm 0.2V$ or GND |
| I <sub>CCD</sub> | V <sub>CC</sub> Deep Power-Down Current                                          | 1          |     | 0.20 | 20   | μΑ   | $RP# = GND \pm 0.2V$                                                                                       |
| ICCR             | V <sub>CC</sub> Read Current for<br>28F200BX Word-Wide and<br>Byte-Wide Mode and | 1, 5,<br>6 |     |      | 60   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>f = 10 MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs                         |
|                  | 28F002BX Byte-Wide Mode                                                          |            |     |      | 65   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$ f = 10 MHz, $I_{OUT} = 0$ mA TTL Inputs                             |



# DC CHARACTERISTICS: EXTENDED TEMPERATURE OPERATION (Continued)

| Symbol            | Parameter                                     | Notes | Min                   | Тур  | Max                   | Unit | Test Condition                                                |
|-------------------|-----------------------------------------------|-------|-----------------------|------|-----------------------|------|---------------------------------------------------------------|
| Iccw              | V <sub>CC</sub> Word Byte Write Current       | 1     |                       |      | 70                    | mA   | Word Write in Progress                                        |
| ICCE              | V <sub>CC</sub> Block Erase Current           | 1     |                       |      | 40                    | mA   | Block Erase in Progress                                       |
| CCES              | V <sub>CC</sub> Erase Suspend Current         | 1, 2  |                       | 5    | 10                    | mΑ   | Block Erase Suspended<br>CE# = V <sub>IH</sub>                |
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby Current               | 1     |                       |      | ±15                   | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                             |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-Down Current       | 1     |                       |      | 5.0                   | μΑ   | RP# = GND ±0.2V                                               |
| I <sub>PPR</sub>  | V <sub>PP</sub> Read Current                  | 1     |                       |      | 200                   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                             |
| I <sub>PPW</sub>  | V <sub>PP</sub> Word Write Current            | 1, 4  | ·                     |      | 40                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress  |
| I <sub>PPW</sub>  | V <sub>PP</sub> Byte Write Current            | 1, 4  |                       |      | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress  |
| I <sub>PPE</sub>  | V <sub>PP</sub> Block Erase Current           | 1, 4  |                       |      | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend Current         | 1     |                       |      | 200                   | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended   |
| I <sub>RP#</sub>  | RP# Boot Block Unlock Current                 | 1, 4  |                       |      | 500                   | μΑ   | RP# = V <sub>HH</sub>                                         |
| I <sub>ID</sub>   | A <sub>9</sub> Intelligent Identifier Current | 1     |                       |      | 500                   | μΑ   | $A_9 = V_{ID}$                                                |
| $V_{ID}$          | A <sub>9</sub> Intelligent Identifier Voltage |       | 11.5                  |      | 13.0                  | ٧    | ,                                                             |
| V <sub>IL</sub>   | Input Low Voltage                             |       | -0.5                  |      | 0.8                   | ٧    |                                                               |
| $V_{IH}$          | Input High Voltage                            |       | 2.0                   |      | V <sub>CC</sub> + 0.5 | ٧    |                                                               |
| V <sub>OL</sub>   | Output Low Voltage                            |       |                       |      | 0.45                  | ٧    | $V_{CC} = V_{CC} Min$<br>$I_{OL} = 5.8 mA$                    |
| V <sub>OH1</sub>  | Output High Voltage (TTL)                     |       | 2.4                   |      |                       | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                      |
| V <sub>OH2</sub>  | Output High Voltage (CMOS)                    |       | 0.85 V <sub>CC</sub>  |      |                       | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                      |
|                   |                                               |       | V <sub>CC</sub> - 0.4 |      |                       |      | $V_{CC} = V_{CC} Min$ $I_{OH} = -100 \mu A$                   |
| V <sub>PPL</sub>  | V <sub>PP</sub> during Normal Operations      | 3     | 0.0                   |      | 6.5                   | ٧    |                                                               |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Erase/Write Operations | 7     | 11.4                  | 12.0 | 12.6                  | ٧    |                                                               |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Erase/Write Operations | 8     | 10.8                  | 12.0 | 13.2                  | ٧    |                                                               |
| $V_{LKO}$         | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.0                   |      |                       | ٧    |                                                               |
| V <sub>HH</sub>   | RP# Unlock Voltage                            |       | 11.5                  |      | 13.0                  | ٧    | Boot Block Write/Erase                                        |



# CAPACITANCE(4, 9) T<sub>A</sub> = 25°C, f = 1 MHz

| Symbol           | Parameter          | Тур | Max | Unit | Condition             |
|------------------|--------------------|-----|-----|------|-----------------------|
| C <sub>IN</sub>  | Input Capacitance  | 6   | 8   | pF   | $V_{IN} = 0V$         |
| C <sub>OUT</sub> | Output Capacitance | 10  | 12  | pF   | V <sub>OUT</sub> = 0V |

#### NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).
- 2. I<sub>CCES</sub> is specified with the device deselected. If the device is read while in Erase Suspend Mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCR</sub>.
- 3. Block Erases and Word/Byte Writes are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between  $V_{PPH}$  and  $V_{PPL}$ .
- Sampled, not 100% tested.
- 5. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA typical in static operation.
- 6. CMOS Inputs are either V<sub>CC</sub> ±0.2V or GND ±0.2V. TTL Inputs are either V<sub>II</sub> or V<sub>IH</sub>.
- 7.  $V_{PP} = 12.0V \pm 5\%$  for applications requiring 100,000 block erase cycles.
- 8. Vpp = 12.0V ±10% for applications requiring wider Vpp tolerances at 100 block erase cycles.
- 9. For the 28F002BX, address pin A<sub>10</sub> follows the C<sub>OUT</sub> capacitance numbers.
- 10. ICCB typical is 25 mA for X16 active read current.

# STANDARD TEST CONFIGURATION(1)

# STANDARD AC INPUT/OUTPUT REFERENCE WAVEFORM



AC test inputs are driven at V<sub>OH</sub> (2.4 V<sub>TTL</sub>) for a Logic "1" and V<sub>OL</sub> (0.45 V<sub>TTL</sub>) for a logic "0". Input timing begins at V<sub>IH</sub> (2.0 V<sub>TTL</sub>) and V<sub>IL</sub> (0.8 V<sub>TTL</sub>). Output timing ends at V<sub>IH</sub> and V<sub>IL</sub>. Input rise and fall times (10% to 90%) < 10 ns.

# STANDARD AC TESTING LOAD CIRCUIT



# HIGH SPEED TEST CONFIGURATION(2)

# HIGH SPEED AC INPUT/OUTPUT REFERENCE WAVEFORM



AC test inputs are driven at 3.0V for a Logic "1" and 0.0V for a logic "0". Input timing begins, and output timing ends, at 1.5V. Input rise and fall times  $(10\%\ to\ 90\%) < 10\ ns.$ 

#### NOTES:

- Testing characteristics for 28F200BX-60/28F002BX-60 in standard test configuration and 28F200BX-80/28F002BX-80.
- 2. Testing characteristics for 28F200BX-60/28F002BX-60 in high speed test configuration.

# HIGH SPEED AC TESTING LOAD CIRCUIT





# AC CHARACTERISTICS—Read Only Operations(1)

|                                        |                  |                                                                            |       | V <sub>CC</sub>                                          | ±5% |                                                          |     | . V <sub>CC</sub>                                        | ± 10% |                                                            |     |    |
|----------------------------------------|------------------|----------------------------------------------------------------------------|-------|----------------------------------------------------------|-----|----------------------------------------------------------|-----|----------------------------------------------------------|-------|------------------------------------------------------------|-----|----|
|                                        |                  | Versions                                                                   |       | 28F200BX-60 <sup>(4)</sup><br>28F002BX-60 <sup>(4)</sup> |     | 28F200BX-60 <sup>(5)</sup><br>28F002BX-60 <sup>(5)</sup> |     | 28F200BX-80 <sup>(5)</sup><br>28F002BX-80 <sup>(5)</sup> |       | 28F200BX-120 <sup>(5)</sup><br>28F002BX-120 <sup>(5)</sup> |     |    |
| Sym                                    | bol              | Parameter                                                                  | Notes | Min                                                      | Max | Min                                                      | Max | Min Max                                                  |       | Min                                                        | Max |    |
| tavav                                  | t <sub>RC</sub>  | Read Cycle Time                                                            |       | 60                                                       |     | 70                                                       |     | 80                                                       |       | 120                                                        |     | ns |
| tavqv                                  | t <sub>ACC</sub> | Address to<br>Output Delay                                                 |       |                                                          | 60  |                                                          | 70  |                                                          | 80    |                                                            | 120 | ns |
| tELQV                                  | t <sub>CE</sub>  | CE# to Output Delay                                                        | 2     |                                                          | 60  |                                                          | 70  |                                                          | 80    |                                                            | 120 | ns |
| <sup>t</sup> PHQV                      | t <sub>PWH</sub> | RP# High to<br>Output Delay                                                |       |                                                          | 300 |                                                          | 300 |                                                          | 300   |                                                            | 300 | ns |
| t <sub>GLQV</sub>                      | toE              | OE# to Output Delay                                                        | 2     |                                                          | 30  |                                                          | 35  |                                                          | 40    |                                                            | 40  | ns |
| tELQX                                  | $t_{LZ}$         | CE# to Output Low Z                                                        | 3     | 0                                                        |     | 0                                                        |     | 0                                                        |       | 0                                                          |     | ns |
| <sup>t</sup> EHQZ                      | t <sub>HZ</sub>  | CE# High to Output<br>High Z                                               | 3     |                                                          | 20  |                                                          | 25  |                                                          | 30    |                                                            | 30  | ns |
| tGLQX                                  | toLZ             | OE# to Output Low Z                                                        | 3     | 0                                                        |     | 0                                                        |     | 0                                                        |       | 0                                                          |     | ns |
| tGHQZ                                  | t <sub>DF</sub>  | OE# High to Output<br>High Z                                               | 3     |                                                          | 20  |                                                          | 25  |                                                          | 30    |                                                            | 30  | ns |
|                                        | t <sub>OH</sub>  | Output Hold from<br>Addresses,<br>CE# or OE# Change,<br>Whichever is First | 3     | 0                                                        |     | 0                                                        |     | 0                                                        |       | 0                                                          |     | ns |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> |                  | CE# to BYTE#<br>Switching<br>Low or High                                   | 3     |                                                          | 5   |                                                          | 5   |                                                          | 5     |                                                            | 5   | ns |
| t <sub>FHQV</sub>                      |                  | BYTE# Switching<br>High to<br>Valid Output Delay                           | 3, 6  |                                                          | 60  |                                                          | 70  |                                                          | 80    |                                                            | 120 | ns |
| t <sub>FLQZ</sub>                      |                  | BYTE# Switching<br>Low to<br>Output High Z                                 | 3     |                                                          | 20  |                                                          | 25  |                                                          | 30    |                                                            | 30  | ns |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.
- 4. See High Speed Test Configuration.
- 5. See Standard Test Configuration.
- 6. t<sub>FLQV</sub>, BYTE# switching low to valid output delay, will be equal to t<sub>AVQV</sub>, measured from the time DQ<sub>15</sub>/A-<sub>1</sub> becomes valid.



# **EXTENDED TEMPERATURE OPERATIONS AC CHARACTERISTICS—Read Only Operations**(1):

|                                        |                  | Versions                                                          |       |     | 0BX-80 <sup>(4)</sup><br>2BX-80 <sup>(4)</sup> | Unit |  |
|----------------------------------------|------------------|-------------------------------------------------------------------|-------|-----|------------------------------------------------|------|--|
| Sym                                    | nbol             | Parameter                                                         | Notes | Min | Max                                            | ]    |  |
| t <sub>AVAV</sub>                      | t <sub>RC</sub>  | Read Cycle Time                                                   |       | 80  |                                                | ns   |  |
| t <sub>AVQV</sub>                      | tACC             | Address to<br>Output Delay                                        |       |     | 80                                             | ns   |  |
| tELQV                                  | t <sub>CE</sub>  | CE# to Output Delay                                               | 2     |     | 80                                             | ns   |  |
| t <sub>PHQV</sub>                      | t <sub>PWH</sub> | RP# High to<br>Output Delay                                       | ,     |     | 300                                            | ns   |  |
| tGLQV                                  | tOE              | OE# to Output Delay                                               | 2     |     | 40                                             | ns   |  |
| tELQX                                  | t <sub>LZ</sub>  | CE# to Output Low Z                                               | 3     | 0   |                                                | ns   |  |
| t <sub>EHQZ</sub>                      | t <sub>HZ</sub>  | CE# High to Output<br>High Z                                      | 3     |     | 30                                             | ns   |  |
| tGLQX                                  | toLZ             | OE# to Output Low Z                                               | 3     | 0   |                                                | ns   |  |
| tGHQZ                                  | t <sub>DF</sub>  | OE# High to Output<br>High Z                                      | 3     |     | 30                                             | ns   |  |
|                                        | tон              | Output Hold from Addresses, CE# or OE# Change, Whichever is First | 3     | 0   |                                                | ns   |  |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> |                  | CE# to BYTE#<br>Switching<br>Low or High                          | 3     |     | 5                                              | ns   |  |
| t <sub>FHQV</sub>                      |                  | BYTE# Switching<br>High to<br>Valid Output Delay                  | 3, 5  |     | 80                                             | ns   |  |
| t <sub>FLQZ</sub>                      |                  | BYTE# Switching<br>Low to<br>Output High Z                        | 3     |     | 30                                             | ns   |  |

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.
- 4. See Standard Test Configuration.
- 5.  $t_{FLQV}$ , BYTE# switching low to valid output delay, will be equal to  $t_{AVQV}$ , measured from the time DQ<sub>5</sub>/A-1 becomes valid.









Figure 17.  $I_{CC}$  (RMS) vs Frequency ( $V_{CC} = 5.5V$ ) for x16 Operation



Figure 18.  $I_{CC}$  (RMS) vs Frequency ( $V_{CC} = 5.5V$ ) for x8 Operation



Figure 19.  $T_{ACC}$  vs Output Load Capacitance ( $V_{CC} = 4.5V, T = 70^{\circ}C$ )







# AC CHARACTERISTICS For WE#-Controlled Write Operations(1)

|                    |                  |                                                   |         | Vcc | ±5%                                          | :   |     | Vcc | ± 10%                                          |     |                                                  |      |
|--------------------|------------------|---------------------------------------------------|---------|-----|----------------------------------------------|-----|-----|-----|------------------------------------------------|-----|--------------------------------------------------|------|
|                    |                  | Versions                                          |         |     | BX-60 <sup>(9)</sup><br>BX-60 <sup>(9)</sup> |     |     |     | 3X-80 <sup>(10)</sup><br>3X-80 <sup>(10)</sup> |     | 3X-120 <sup>(10)</sup><br>3X-120 <sup>(10)</sup> | Unit |
| Syml               | bol              | Parameter                                         | Notes   | Min | Max                                          | Min | Max | Min | Max                                            | Min | Max                                              |      |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                                  |         | 60  |                                              | 70  |     | 80  |                                                | 120 |                                                  | ns   |
| t <sub>PHWL</sub>  | t <sub>PS</sub>  | RP# High<br>Recovery to<br>WE# Going Low          |         | 215 |                                              | 215 |     | 215 |                                                | 215 |                                                  | ns   |
| tELWL              | tcs              | CE# Setup to<br>WE# Going Low                     |         | 0   |                                              | 0   |     | 0   |                                                | 0   |                                                  | ns   |
| tphhwh             | t <sub>PHS</sub> | RP# V <sub>HH</sub><br>Setup to<br>WE# Going High | 6, 8    | 100 |                                              | 100 |     | 100 |                                                | 100 |                                                  | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to<br>WE# Going High        | 5, 8    | 100 |                                              | 100 |     | 100 |                                                | 100 |                                                  | ns   |
| t <sub>AVWH</sub>  | t <sub>AS</sub>  | Address Setup to WE# Going High                   | 3       | 50  |                                              | 50  |     | 50  |                                                | 50  |                                                  | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to<br>WE# Going High                   | 4       | 60  |                                              | 60  |     | 60  |                                                | 60  |                                                  | ns   |
| twLwH              | t <sub>WP</sub>  | WE# Pulse Width                                   |         | 50  |                                              | 50  |     | 60  |                                                | 60  |                                                  | ns   |
| t <sub>WHDX</sub>  | t <sub>DH</sub>  | Data Hold from<br>WE# High                        | 4       | 0   |                                              | 0   |     | 0   |                                                | 0   |                                                  | ns   |
| t <sub>WHAX</sub>  | t <sub>AH</sub>  | Address Hold<br>from WE# High                     | 3       | 10  |                                              | 10  |     | 10  |                                                | 10  |                                                  | ns   |
| twheh              | tсн              | CE# Hold from<br>WE# High                         |         | 10  |                                              | 10  |     | 10  |                                                | 10  |                                                  | ns   |
| twhwL              | twph             | WE# Pulse<br>Width High                           |         | 10  |                                              | 20  |     | 20  |                                                | 20  |                                                  | ns   |
| twHQV1             |                  | Duration of<br>Word/Byte Write<br>Operation       | 2, 5    | 6   |                                              | 6   |     | 6   |                                                | 6   |                                                  | μs   |
| t <sub>WHQV2</sub> |                  | Duration of Erase<br>Operation (Boot)             | 2, 5, 6 | 0.3 |                                              | 0.3 |     | 0.3 |                                                | 0.3 |                                                  | s    |
| twHQV3             |                  | Duration of Erase<br>Operation<br>(Parameter)     | 2, 5    | 0.3 |                                              | 0.3 |     | 0.3 |                                                | 0.3 |                                                  | S    |
| t <sub>WHQV4</sub> |                  | Duration of Erase<br>Operation (Main)             | 2, 5, 6 | 0.6 |                                              | 0.6 |     | 0.6 |                                                | 0.6 |                                                  | s    |
| tawl               | t <sub>VPH</sub> | V <sub>PP</sub> Hold from<br>Valid SRD            | 5, 8    | 0   |                                              | 0   |     | 0   |                                                | 0   |                                                  | ns   |



# AC CHARACTERISTICS For WE#-Controlled Write Operations(1) (Continued)

|                   |          |                                            |       | V <sub>CC</sub>                                          | ±5% | V <sub>CC</sub> ± 10% |     |     |                                                |     |     |      |
|-------------------|----------|--------------------------------------------|-------|----------------------------------------------------------|-----|-----------------------|-----|-----|------------------------------------------------|-----|-----|------|
|                   | Versions |                                            |       | 28F200BX-60 <sup>(9)</sup><br>28F002BX-60 <sup>(9)</sup> |     |                       |     |     | 3X-80 <sup>(10)</sup><br>3X-80 <sup>(10)</sup> |     |     | Unit |
| Sym               | bol      | Parameter                                  | Notes | Min                                                      | Max | Min                   | Max | Min | Max                                            | Min | Max |      |
| <sup>t</sup> QVPH |          | RP# V <sub>HH</sub> Hold<br>from Valid SRD |       | 0                                                        |     | 0                     |     | 0   |                                                | 0   |     | ns   |
| t <sub>PHBR</sub> |          | Boot-Block<br>Relock Delay                 | 7, 8  |                                                          | 100 |                       | 100 |     | 100                                            |     | 100 | ns   |

#### **NOTES:**

- 1. Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during Read Mode.

  2. The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled inter-
- Ine on-cnip wSM completely automates program/erase operations; program/erase algorithms are nally which includes verify and margining operations.
   Refer to command definition table for valid A<sub>IN</sub>.
   Refer to command definition table for valid D<sub>IN</sub>.
   Program/Erase durations are measured to valid SRD data (successful operation, SR.7=1).
   For Boot Block Program/Erase, RP# should be held at V<sub>HH</sub> until operation completes successfully.
   Time t<sub>PHBR</sub> is required for successful relocking of the Boot Block.
   Sampled but not 100% tested.
   See High Speed Test Configuration.

- 9. See High Speed Test Configuration.
- 10. See Standard Test Configuration.

# BLOCK ERASE AND WORD/BYTE WRITE PERFORMANCE: Vpp = 12.0V ±5%

| Parameter                          | Notes | 28F200BX-60<br>28F002BX-60 |        |     | 28F200BX-80<br>28F002BX-80 |        |     | 28F200BX-120<br>28F002BX-120 |        |     | Unit |
|------------------------------------|-------|----------------------------|--------|-----|----------------------------|--------|-----|------------------------------|--------|-----|------|
|                                    |       | Min                        | Typ(1) | Max | Min                        | Typ(1) | Max | Min                          | Typ(1) | Max |      |
| Boot/Parameter<br>Block Erase Time | 2     |                            | 1.0    | 7   |                            | 1.0    | 7   |                              | 1.0    | 7   | Ö    |
| Main Block<br>Erase Time           | 2     |                            | 2.4    | 14  |                            | 2.4    | 14  |                              | 2.4    | 14  | S    |
| Main Block Byte<br>Program Time    | 2     |                            | 1.2    | 4.2 |                            | 1.2    | 4.2 |                              | 1.2    | 4.2 | s    |
| Main Block Word<br>Program Time    | 2     |                            | 0.6    | 2.1 |                            | 0.6    | 2.1 |                              | 0.6    | 2.1 | S    |

## NOTES:

- 1. 25°C
- 2. Excludes System-Level Overhead.

# BLOCK ERASE AND WORD/BYTE WRITE PERFORMANCE: $V_{PP} = 12.0V \pm 10\%$

| Parameter                          | Notes | 28F200BX-60<br>28F002BX-60 |        |     | 28F200BX-80<br>28F002BX-80 |        |     | 28F200BX-120<br>28F002BX-120 |                    |     | Unit |
|------------------------------------|-------|----------------------------|--------|-----|----------------------------|--------|-----|------------------------------|--------------------|-----|------|
|                                    |       | Min                        | Typ(1) | Max | Min                        | Typ(1) | Max | Min                          | Typ <sup>(1)</sup> | Max |      |
| Boot/Parameter<br>Block Erase Time | 2     |                            | 5.8    | 40  | - 77.011                   | 5.8    | 40  |                              | 5.8                | 40  | s    |
| Main Block<br>Erase Time           | 2     |                            | 14     | 60  |                            | 14     | 60  |                              | 14                 | 60  | s    |
| Main Block Byte<br>Program Time    | 2     |                            | 6.0    | 20  |                            | 6.0    | 20  |                              | 6.0                | 20  | s    |
| Main Block Word<br>Program Time    | 2     |                            | 3.0    | 10  |                            | 3.0    | 10  |                              | 3.0                | 10  | s    |

- 1. 25°C
- 2. Excludes System-Level Overhead.



# **EXTENDED TEMPERATURE OPERATION AC CHARACTERISTICS** For WE#-Controlled Write Operations(1):

|                    |                  | Versions <sup>(4)</sup>                     |         |     | BX-80 <sup>(9)</sup> | Unit |
|--------------------|------------------|---------------------------------------------|---------|-----|----------------------|------|
| Syml               | bol              | Parameter                                   | Notes   | Min | Max                  | ]    |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                            |         | 80  |                      | ns   |
| t <sub>PHWL</sub>  | t <sub>PS</sub>  | RP# High Recovery to WE# Going Low          |         | 220 |                      | ns   |
| · tELWL            | tcs              | CE# Setup to WE# Going Low                  |         | 0   |                      | ns   |
| t <sub>PHHWH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to WE# Going High | 6, 8    | 100 |                      | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE# Going High     | 5, 8    | 100 |                      | ns   |
| tavwh              | tas              | Address Setup to WE# Going High             | 3       | 60  |                      | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to WE# Going High                | 4       | 60  |                      | ns   |
| t <sub>WLWH</sub>  | t <sub>WP</sub>  | WE# Pulse Width                             |         | 60  |                      | ns   |
| twHDX              | t <sub>DH</sub>  | Data Hold from WE# High                     | 4       | 0   |                      | ns   |
| twhax              | t <sub>AH</sub>  | Address Hold from WE# High                  | 3       | 10  |                      | ns   |
| twheh              | tcH              | CE# Hold from WE# High                      |         | 10  |                      | ns   |
| twHWL              | t <sub>WPH</sub> | WE# Pulse Width High                        |         | 20  |                      | ns   |
| twHQV1             |                  | Duration of Word/Byte<br>Write Operation    | 2, 5    | 7   |                      | μs   |
| t <sub>WHQV2</sub> |                  | Duration of Erase Operation (Boot)          | 2, 5, 6 | 0.4 |                      | s    |
| t <sub>WHQV3</sub> |                  | Duration of Erase<br>Operation (Parameter)  | 2, 5    | 0.4 |                      | s    |
| twHQV4             |                  | Duration of Erase Operation (Main)          | 2, 5, 6 | 0.7 |                      | s    |
| t <sub>QWL</sub>   | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD         | 5, 8    | 0   |                      | ns   |
| tQVPH              | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD     | 6, 8    | 0   |                      | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                     | 7, 8    |     | 100                  | ns   |

- Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during Read Mode.
- 2. The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid  $A_{\text{IN}}$ .
- 4. Refer to command definition table for valid DIN.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7=1).
- 6. For Boot Block Program/Erase, RP# should be held at VHH until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the Boot Block.
- 8. Sampled but not 100% tested.
- 9. See Standard Test Configuration.



# **EXTENDED TEMPERATURE OPERATION** BLOCK ERASE AND WORD/BYTE WRITE PERFORMANCE: $V_{pp} = 12.0V \pm 5\%$

| Parameter                          | Notes | T28F200BX-80<br>Notes T28F002BX-80 |                    |      |     |  |  |
|------------------------------------|-------|------------------------------------|--------------------|------|-----|--|--|
|                                    |       | Min                                | Typ <sup>(1)</sup> | Max  |     |  |  |
| Boot/Parameter<br>Block Erase Time | 2     | ÷                                  | 1.5                | 10.5 | S   |  |  |
| Main Block<br>Erase Time           | 2     |                                    | 3.0                | 18   | s · |  |  |
| Main Block Byte<br>Program Time    | 2     |                                    | 1.4                | 5.0  | s   |  |  |
| Main Block Word<br>Program Time    | 2     |                                    | <b>Ģ.</b> 7        | 2.5  | s   |  |  |

 <sup>25°</sup>C, 12.0V V<sub>PP</sub>.
 Excludes System-Level Overhead.





# AC CHARACTERISTICS FOR CE#-CONTROLLED WRITE OPERATIONS(1,9)

|                    |                  |                                                      | V <sub>CC</sub> ±5% V <sub>CC</sub> ± 10% |                                                            |     |                                    |     |                                    |     |                                                              |     |      |
|--------------------|------------------|------------------------------------------------------|-------------------------------------------|------------------------------------------------------------|-----|------------------------------------|-----|------------------------------------|-----|--------------------------------------------------------------|-----|------|
| Versions           |                  |                                                      |                                           | 28F200BX-60 <sup>(10)</sup><br>28F002BX-60 <sup>(10)</sup> |     | 28F200BX-60(11)<br>28F002BX-60(11) |     | 28F200BX-80(11)<br>28F002BX-80(11) |     | 28F200BX-120 <sup>(11)</sup><br>28F002BX-120 <sup>(11)</sup> |     | Unit |
| Symi               | bol              | Parameter                                            | Notes                                     |                                                            | Max | Min                                | Max | Min                                | Max | Min                                                          | Max |      |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                                     |                                           | 60                                                         |     | 70                                 |     | 80                                 |     | 120                                                          |     | ns   |
| <sup>t</sup> PHEL  | t <sub>PS</sub>  | RP# High Recovery to CE# Going Low                   |                                           | 215                                                        |     | 215                                |     | 215                                |     | 215                                                          |     | ns   |
| twlel              | tws              | WE# Setup to CE#<br>Going Low                        |                                           | 0                                                          |     | 0                                  |     | 0                                  |     | 0                                                            |     | ns   |
| <sup>t</sup> PHHEH | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to CE# Going High          | 6, 8                                      | 100                                                        |     | 100                                |     | 100                                |     | 100                                                          |     | ns   |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE#<br>Going High           | 5, 8                                      | 100                                                        |     | 100                                |     | 100                                |     | 100                                                          |     | ns   |
| t <sub>AVEH</sub>  | t <sub>AS</sub>  | Address Setup to CE# Going High                      | 3                                         | 50                                                         |     | 50                                 |     | 50                                 |     | 50                                                           |     | ns   |
| <sup>t</sup> DVEH  | t <sub>DS</sub>  | Data Setup to CE#<br>Going High                      | 4                                         | 60                                                         |     | 60                                 |     | 60                                 |     | 60                                                           |     | ns   |
| <sup>t</sup> ELEH  | t <sub>CP</sub>  | CE# Pulse Width                                      |                                           | 50                                                         |     | 50                                 |     | 60                                 |     | 60                                                           |     | ns   |
| <sup>t</sup> EHDX  | t <sub>DH</sub>  | Data Hold from<br>CE# High                           | 4                                         | 0                                                          |     | 0                                  |     | 0                                  |     | 0                                                            |     | ns   |
| <sup>t</sup> EHAX  | t <sub>AH</sub>  | Address Hold<br>from CE# High                        | 3                                         | 10                                                         |     | 10                                 |     | 10                                 |     | 10                                                           |     | ns   |
| <sup>t</sup> EHWH  | twH              | WE# Hold from<br>CE# High                            |                                           | 10                                                         | ,   | 10                                 |     | 10                                 |     | 10                                                           | ٠   | ns   |
| <sup>t</sup> EHEL  | tCPH             | CE# Pulse<br>Width High                              |                                           | 10                                                         |     | 20                                 | :   | 20                                 |     | 20                                                           |     | ns   |
| <sup>t</sup> EHQV1 |                  | Duration of<br>Word/Byte<br>Programming<br>Operation | 2,5                                       | 6                                                          |     | 6                                  |     | 6                                  |     | 6                                                            |     | μs   |
| <sup>t</sup> EHQV2 | ·                | Duration of Erase<br>Operation (Boot)                | 2, 5, 6                                   | 0.3                                                        |     | 0.3                                |     | 0.3                                |     | 0.3                                                          |     | s    |
| <sup>t</sup> EHQV3 |                  | Duration of Erase<br>Operation<br>(Parameter)        | 2, 5                                      | 0.3                                                        |     | 0.3                                |     | 0.3                                |     | 0.3                                                          | v.  | s    |
| t <sub>EHQV4</sub> |                  | Duration of Erase<br>Operation (Main)                | 2, 5                                      | 0.6                                                        |     | 0.6                                |     | 0.6                                |     | 0.6                                                          |     | S    |
| <sup>t</sup> QWL   | t <sub>VPH</sub> | V <sub>PP</sub> Hold from<br>Valid SRD               | 5, 8                                      | 0                                                          |     | 0                                  |     | 0                                  |     | 0                                                            |     | ns   |
| <sup>t</sup> QVPH  | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold<br>from Valid SRD           | 6, 8                                      | 0                                                          |     | 0                                  |     | 0                                  |     | 0                                                            |     | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock<br>Delay                           | 7                                         |                                                            | 100 |                                    | 100 |                                    | 100 |                                                              | 100 | ns   |

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# time should be measured relative to the CE# waveform.

<sup>2, 3, 4, 5, 6, 7, 8:</sup> Refer to AC Characteristics notes for WE#-Controlled Write Operations.

<sup>9.</sup> Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during Read Mode.

<sup>10.</sup> See High Speed Test Configuration.

<sup>11.</sup> See Standard Test Configuration.



# EXTENDED TEMPERATURE OPERATION AC CHARACTERISTICS FOR CE#-CONTROLLED WRITE OPERATIONS(1, 9)

|                    |                  | Versions                                          | T28F200<br>T28F002 | Unit |     |    |  |
|--------------------|------------------|---------------------------------------------------|--------------------|------|-----|----|--|
| Symbol             |                  | Parameter                                         | Notes              | Min  | Max |    |  |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                                  |                    | 80   |     | ns |  |
| t <sub>PHEL</sub>  | t <sub>PS</sub>  | RP# High Recovery<br>to CE# Going Low             |                    | 220  |     | ns |  |
| tWLEL              | tws              | WE# Setup to CE#<br>Going Low                     |                    | 0    |     | ns |  |
| <sup>t</sup> PHHEH | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to<br>CE# Going High    | 6, 8               | 100  |     | ns |  |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE#<br>Going High        | 5, 8               | 100  |     | ns |  |
| <sup>t</sup> AVEH  | t <sub>AS</sub>  | Address Setup to<br>CE# Going High                | 3                  | 60   |     | ns |  |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to CE#<br>Going High                   | 4                  | 60   |     | ns |  |
| tELEH              | t <sub>CP</sub>  | CE# Pulse Width                                   |                    | 60   |     | ns |  |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from<br>CE# High                        | 4                  | 0    |     | ns |  |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold<br>from CE# High                     | 3                  | 10   |     | ns |  |
| t <sub>EHWH</sub>  | t <sub>WH</sub>  | WE# Hold from CE# High                            |                    | 10   |     | ns |  |
| tEHEL              | t <sub>CPH</sub> | CE# Pulse<br>Width High                           |                    | 20   |     | ns |  |
| t <sub>EHQV1</sub> |                  | Duration of Word/Byte<br>Programming<br>Operation | 2, 5               | 7    |     | μs |  |
| t <sub>EHQV2</sub> |                  | Duration of Erase<br>Operation (Boot)             | 2, 5, 6            | 0.4  |     | s  |  |
| t <sub>EHQV3</sub> |                  | Duration of Erase<br>Operation (Parameter)        | 2, 5               | 0.4  |     | S  |  |
| t <sub>EHQV4</sub> |                  | Duration of Erase<br>Operation (Main)             | 2, 5               | 0.7  |     | S  |  |
| tQWL               | t <sub>VPH</sub> | V <sub>PP</sub> Hold from<br>Valid SRD            | 5, 8               | 0    |     | ns |  |
| tQVPH              | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold<br>from Valid SRD        | 6, 8               | 0    |     | ns |  |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                           | 7                  |      | 100 | ns |  |

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# time should be measured relative to the CE# waveform.

<sup>2, 3, 4, 5, 6, 7, 8:</sup> Refer to AC Characteristics for WE#-Controlled Write Operations.

<sup>9.</sup> Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC Characteristics during Read Mode.

<sup>10.</sup> See Standard Test Configuration.







# **ORDERING INFORMATION**





# **ADDITIONAL INFORMATION**

| Order<br>Number | Document                                                                          |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------|--|--|--|--|--|
| 292130          | AB-57 "Boot Block Architecture for Safe Firmware Updates"                         |  |  |  |  |  |
| 292154          | AB-60 "2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family"                    |  |  |  |  |  |
| 292098          | AP-363 "Extended Flash BIOS Concepts for Portable Computers"                      |  |  |  |  |  |
| 292148          | AP-604 "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM" |  |  |  |  |  |
| 290449          | 28F002/200BL-T/B 2-Mbit Low Power Boot Block Flash Memory Datasheet               |  |  |  |  |  |
| 290450          | 28F004/400BL-T/B 4-Mbit Low Power Boot Block Flash Memory Datasheet               |  |  |  |  |  |
| 290451          | 28F004/400BX-T/B 4-Mbit Boot Block Flash Memory Datasheet                         |  |  |  |  |  |
| 290531          | 2-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |  |  |  |  |  |
| 290530          | 4-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |  |  |  |  |  |
| 290539          | 8-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |  |  |  |  |  |



# **REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -002   | Removed $-70$ speed bin Integrated $-70$ characteristics into $-60$ speed bin Added Extended Temperature characteristics Modified BYTE# Timing Diagram Improved t <sub>PHQV</sub> , RP# High to Output Delay and t <sub>PHEL</sub> , RP# High Recovery to CE# going low specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| -003   | PWD changed to RP# for JEDEC standardization compatibility. Combined $V_{CC}$ Read current for 28F200BX Word-wide mode and Byte-wide mode, and 28F002BX Byte-wide mode in DC Characteristics tables. Change $I_{PPS}$ current spec from $\pm$ 10 $\mu$ A to $\pm$ 15 $\mu$ A in DC Characteristics tables. Improved $I_{CCR}$ and $I_{CCW}$ in DC Characteristics: Extended Temperature Operation table. Improved $I_{AVAV}$ , $I_{AVQV}$ , $I_{ELQV}$ , $I_{ELQV}$ , $I_{EHQZ}$ , $I_{EHQZ}$ , $I_{EHQV}$ and $I_{ELQZ}$ specifications for Extended Temperature Operations AC Characteristics—Read and Write Operations.                                                                                                              |
| -004   | Added specifications for 120 ns access time product version; 28F200BX-120 and 28F002BX-120.  Included permanent change on write timing parameters for -80 ns product versions. Write pulse width (t <sub>WP</sub> and t <sub>CP</sub> ) increases from 50 ns to 60 ns. Write pulse width high (t <sub>WPH</sub> and t <sub>CPH</sub> ) decreases from 30 ns to 20 ns. Total write cycle time (t <sub>WC</sub> ) remains unchanged.  Added I <sub>CCR</sub> test condition note for typical frequency value in DC characteristics table.  Added I <sub>OH</sub> CMOS specification.  Added 28F400BX interface to Intel386™EX Embedded Processor block diagram.  Added description of how to upgrade to SmartVoltage Boot Block products. |

# int<sub>el</sub>®

# 28F200BL-T/B, 28F002BL-T/B 2-MBIT (128K x 16, 256K x 8) LOW POWER BOOT BLOCK FLASH MEMORY FAMILY

- Low Voltage Operation for Very Low Power Portable Applications

   V<sub>CC</sub> = 3.0V-3.6V
- Expanded Temperature Range — -20°C to +70°C
- x8/x16 Input/Output Architecture — 28F200BL-T, 28F200BL-B
  - For High Performance and High Integration 16-bit and 32-bit CPUs
- x8-only input/Output Architecture
  - 28F002BL-T, 28F002BL-B
  - For Space Constrained 8-bit Applications
- Upgradeable to Intel's SmartVoltage Products
- Optimized High Density Blocked Architecture
  - One 16-KB Protected Boot Block
  - Two 8-KB Parameter Blocks
  - One 96-KB Main Block
  - One 128-KB Main Block
  - Top or Bottom Boot Locations
- Extended Cycling Capability
   10,000 Block Erase Cycles
- Automated Word/Byte Write and Block Erase
  - Command User Interface
  - Status Registers
  - Erase Suspend Capability

- **SRAM-Compatible Write Interface**
- Automatic Power Savings Feature
   0.8 mA Typical I<sub>CC</sub> Active Current in Static Operation
- **Very High-Performance Read** 
  - 150 ns Maximum Access Time
  - 65 ns Maximum Output Enable Time
- Low Power Consumption
   15 mA Typical Active Read Current
- Reset/Deep Power-Down Input
  - 0.2 μA I<sub>CC</sub> Typical
  - Acts as Reset for Boot Operations
- Write Protection for Boot Block
- Hardware Data Protection Feature
  - Erase/Write Lockout during Power Transitions
- Industry Standard Surface Mount Packaging
  - 28F200BL: JEDEC ROM Compatible

44-Lead PSOP

56-Lead TSOP

- 28F002BL: 40-Lead TSOP

- 12V Word/Byte Write and Block Erase — V<sub>PP</sub> = 12V ±5% Standard
- ETOX III Flash Technology
  - 3.3V Read
- Independent Software Vendor Support

#### 28F200BL-T/B, 28F002BL-T/B



Intel's 2-Mbit Low Power Flash Memory Family is an extension of the Boot Block Architecture which includes block-selective erasure, automated write and erase operations and standard microprocessor interface. The 2-Mbit Flash Memory Family enhances the Boot Block Architecture by adding more density and blocks, x8/x16 input/output control, very low power, very high speed, an industry standard ROM compatible pinout and surface mount packaging. The 2-Mbit Low Power Flash Family opens a new capability for 3V battery-operated portable systems and allows for an easy upgrade to Intel's 4-Mbit Low Power Boot Block Flash Memory Family.

The Intel 28F200BL-T/B are 16-bit wide flash memory offerings. These high density flash memories provide user selectable bus operation for either 8-bit or 16-bit applications. The 28F200BL-T and 28F200BL-B are 2,097,152-bit non-volatile memories organized as either 262,144 bytes or 131,072 words of information. They are offered in 44-Lead plastic SOP and 56-Lead TSOP packages. The x8/x16 pinout conforms to the industry standard ROM/EPROM pinout.

The Intel 28F002BL-T/B are 8-bit wide flash memories with 2,097,152 bits organized as 262,144 bytes of information. They are offered in a 40-Lead TSOP package, which is ideal for space-constrained portable systems.

These devices use an integrated Command User Interface (CUI) and Write State Machine (WSM) for simplified word/byte write and block erasure. The 28F200BL-T/28F002BL-T provide block locations compatible with Intel's low voltage MCS-186 family, i386™, i486™ microprocessors. The 28F200BL-B/28F002BL-B provide compatibility with Intel's 80960KX and 80960SX families as well as other low voltage embedded microprocessors.

The boot block includes a data protection feature to protect the boot code in critical applications. With a maximum access time of 150 ns, these 2-Mbit flash devices are very high performance low power memories which interface to a wide range of low power microprocessors and microcontrollers. A deep power-down mode lowers the total V<sub>CC</sub> power consumption to 0.66  $\mu$ W. This is critical in handheld battery powered systems such as Handy Phones. For very high speed applications using a 5V supply, refer to the Intel 28F200BX-T/B, 28F002BX-T/B 2-Mbit Boot Block Flash Memory Family datasheet.

Manufactured on Intel's 0.8 micron ETOX III process, the 2-Mbit low power flash memory family provides world class quality, reliability and cost-effectiveness at the 2-Mbit density level.



#### 1.0 PRODUCT FAMILY OVERVIEW

Throughout this datasheet 28F200BL refers to both the 28F200BL-T and 28F200BL-B devices and 28F002BL refers to both the 28F002BL-T and 28F002BL-B devices. The 2-Mbit flash family refers to both the 28F200BL and 28F002BL products. This datasheet comprises the specifications for four separate products in the 2-Mbit flash memory family. Section 1 provides an overview of the 2-Mbit flash memory family including applications, pinouts and pin descriptions. Sections 2 and 3 describe in detail the specific memory organizations for the 28F200BL and 28F002BL products respectively. Section 4 combines a description of the family's principles of operations. Finally, section 5 describes the family's operating specifications.

#### PRODUCT FAMILY

| x8/x16 Products | x8-Only Products |
|-----------------|------------------|
| 28F200BL-T      | 28F002BL-T       |
| 28F200BL-B      | 28F002BL-B       |

#### 1.1 Designing for Upgrade to SmartVoltage Products

Today's high volume boot block products are upgradable to Intel's SmartVoltage boot block products that provide program and erase operation at 5V or 12V Vpp and read operation at 3V or 5V VCC. Intel's SmartVoltage boot block products provide the following enhancements to the boot block products described in this data sheet:

- DU pin is replaced by WP# to provide a means to lock and unlock the boot block with logic signals.
- 2. 5V Program/Erase operation uses proven program and erase techniques with 5V  $\pm 10\%$  applied to Vpp.
- Enhanced circuits optimize performance at 3.3V Vcc.

Refer to the 2, 4 or 8 Mbit SmartVoltage Boot Block Flash Memory Data Sheets for complete specifications.

When you design with 12V V<sub>PP</sub> boot block products you should provide the capability in your board design to upgrade to SmartVoltage products.

Follow these guidelines to ensure compatibility:

- Connect DU (WP# on SmartVoltage products) to a control signal or to V<sub>CC</sub> or GND.
- If adding a switch on V<sub>PP</sub> for write protection, switch to GND for complete write protection.
- Allow for connecting 5V to V<sub>PP</sub> and disconnect 12V from line V<sub>PP</sub> line, if desired.

#### 1.2 Main Features

The 28F200BL/28F002BL low power boot block flash memory family is a very low power and very high performance 2-Mbit (2,097,152 bit) memory family organized as either 128 Kwords (131,072 words) of 16 bits each or 256 Kbytes (262,144 bytes) of 8 bits each.

Five Separately Erasable Blocks including a Hardware-Lockable boot block (16,384 Bytes), two parameter blocks (8,192 Bytes each) and two main blocks (1 block of 98,304 Bytes and 1 block of 131,072 Bytes) are included on the 2-Mbit family. An erase operation erases one of the 5 blocks in typically 3.4 seconds and the boot or parameter blocks in typically 2.0 seconds, independent of the remaining blocks. Each block can be independently erased and programmed 10,000 times.

The Boot Block is located at either the top (28F200BL-T, 28F002BL-T) or the bottom (28F200BL-B, 28F002BL-B) of the address map in order to accommodate different microprocessor protocols for boot code location. The hardware lockable boot block provides the most secure code storage. The boot block is intended to store the kernel code required for booting-up a system. When the RP# pin is between 11.4V and 12.6V the boot block is unlocked and program and erase operations can be performed. When the RP# pin is at or below 4.1V the boot block is locked and program and erase operations to the boot block are ignored.

The 28F200BL products are available in the ROM/EPROM compatible pinout and housed in the 44-Lead PSOP (Plastic Small Outline) package and the 56-Lead TSOP (Thin Small Outline, 1.2 mm thick) package as shown in Figures 3 and 4. The 28F002BL products are available in the 40-Lead TSOP (1.2 mm thick) package as shown in Figure 5.

The **Command User Interface (CUI)** serves as the interface between the microprocessor or microcontroller and the internal operation of the 28F200BL and 28F002BL flash memory products.



Program and Erase Automation allow program and erase operations to be executed using a two-write command sequence to the CUI. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verifications, thereby unburdening the microprocessor or microcontroller. Writing of memory data is performed in word or byte increments for the 28F200BL family and in byte increments for the 28F002BL family typically within 11  $\mu$ s.

The **Status Register (SR)** indicates the status of the WSM and whether the WSM successfully completed the desired program or erase operation.

Maximum Access Time of 150 ns ( $T_{ACC}$ ) is achieved over the commercial temperature range (0°C to +70°C), over  $V_{CC}$  supply voltage range (3.0V to 3.6V, 4.5V to 5.5V) and 50 pF output load.

lpp Program current is 40 mA for x16 operation and 30 mA for x8 operation. lpp Erase current is 30 mA maximum. Vpp erase and programming voltage is 11.4V to 12.6V (Vpp = 12V  $\pm 5\%$ ) under all operating conditions.

Typical I<sub>CC</sub> Active Current of 15 mA is achieved for the x16 products and the x8 products.

The 2-Mbit flash family is also designed with an Automatic Power Savings (APS) feature to minimize system battery current drain and allow for extremely low power designs. Once the device is accessed to read the array data, APS mode will immediately put the memory in static mode of operation where I<sub>CC</sub> active current is typically 0.8 mA until the next read is initiated.

When the CE# and RP# pins are at  $V_{CC}$  and the BYTE# pin (28F200BL-only) is at either  $V_{CC}$  or GND the **CMOS Standby** mode is enabled where  $I_{CC}$  is typically **40**  $\mu$ **A.** 

A **Deep Power-down Mode** is enabled when the RP# pin is at ground minimizing power consumption and providing write protection during power-up conditions. **I<sub>CC</sub> current** during deep power-down mode is **0.20** μ**A typical**. An initial maximum access time or Reset Time of 600 ns is required from RP# switching until outputs are valid. Equivalently, the device has a maximum wake-up time of 1 μs until writes to the Command User Interface are recognized. When RP# is at ground the WSM is reset, the Status Register is cleared and the entire device is protected from being written to. This feature prevents data corruption and protects the code stored in the device during system reset. The system Reset pin can be tied to RP# to reset the memory to nor-

mal read mode upon activation of the Reset pin. When the CPU enters reset mode, it expects to read the contents of a memory location. Furthermore, with on-chip program/erase automation in the 2-Mbit family and the RP# functionality for data protection, after the CPU is reset and even if a program or erase command is issued, the device will not recognize any operation until RP# returns to its normal state.

For the 28F200BL, Byte-wide or Word-wide Input/Output Control is possible by controlling the BYTE# pin. When the BYTE# pin is at a logic low the device is in the byte-wide mode (x8) and data is read and written through DQ[0:7]. During the byte-wide mode, DQ[8:14] are tri-stated and DQ<sub>15</sub>/A<sub>-1</sub> becomes the lowest order address pin. When the BYTE# pin is at a logic high the device is in the word-wide mode (x16) and data is read and written through DQ[0:15].

#### 1.3 Applications

The 2-Mbit low power boot block flash memory family combines high density, 3V operation, high performance, cost-effective flash memories with blocking and hardware protection capabilities. Its flexibility and versatility will reduce costs throughout the product life cycle. Flash memory is ideal for Just-In-Time production flow, reducing system inventory and costs, and eliminating component handling during the production phase. During the product life cycle, when code updates or feature enhancements become necessary, flash memory will reduce the update costs by allowing either a user-performed code change via floppy disk or a remote code change via a serial link. The 2-Mbit boot block flash memory family provides full function, blocked flash memories suitable for a wide range of applications. These applications include Extended PC BIOS, Handy Digital Cellular Phone program and data storage and various other portable embedded applications where both program and data storage are required.

Reprogrammable systems such as Notebook and Palmtop computers, are ideal applications for the 2-Mbit low power flash products. Portable and handheld personal computer applications are becoming more complex with the addition of power management software to take advantage of the latest microprocessor technology, the availability of ROM-based application software, pen tablet code for electronic handwriting, and diagnostic code. Figure 1 shows an example of a 28F200BL-T application.

This increase in software sophistication augments the probability that a code update will be required after the PC is shipped. The 2-Mbit low power flash memory products provide an inexpensive update so-



lution for the notebook and handheld personal computers while extending their product lifetime. Furthermore, the 2-Mbit flash memory products' deep power-down mode provides added flexibility for these battery-operated portable designs which require operation at extremely low power levels.

The 2-Mbit low power flash products also provide excellent design solutions for Handy Digital Cellular Phone applications requiring high density storage, high performance capabilities coupled with low voltage operation, and a small form factor package (x8-only bus). The 2-Mbit's blocking scheme allows for an easy segmentation of the embedded code with: 16 Kbytes of Hardware-Protected Boot code, 2 Main

Blocks of program code and 2 Parameter Blocks of 8 Kbytes each for frequently updatable data storage and diagnostic messages (e.g., phone numbers, authorization codes). Figure 2 is an example of such an application with the 28F002BL-T.

These are a few actual examples of the wide range of applications for the 2-Mbit Low Power Boot Block flash memory family which enables system designers to achieve the best possible product design. Only your imagination limits the applicability of such a versatile low power product family.



Figure 1. 28F200BL-T Interface to Intel386™ EX Embedded Processor



Figure 2. 28F002BL-T Interface to iNTEL 80L188EB, Low Voltage 8-Bit Embedded Microprocessor



#### 1.4 Pinouts

The 28F200BL 44-Lead PSOP pinout follows the industry standard ROM/EPROM pinout as shown in Figure 3 with an upgrade to the 28F400BL (4-Mbit low power flash family). Furthermore, the 28F200BL 56-Lead TSOP pinout shown in

Figure 4 provides density upgrades to the 28F400BL and to future higher density boot block memories.

The 28F002BL 40-Lead TSOP pinout shown in Figure 5 is 100% compatible and has a density upgrade to the 28F004BL 4-Mbit Low Power Boot Block flash memory.



Figure 3. PSOP Lead Configuration for x8/x16 28F200BL





Figure 4. TSOP Lead Configuration for x8/x16 28F200BL



Figure 5. TSOP Lead Configuration for x8 28F002BL



# 1.5 Pin Descriptions for x8/x16 28F200BL

| Symbol                            | Туре       | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>16</sub>   | . I        | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                                                                                         |
| A <sub>9</sub>                    |            | <b>ADDRESS INPUT:</b> When $A_9$ is at 12V the signature mode is accessed. During this mode $A_0$ decodes between the manufacturer and device ID's. When BYTE# is at a logic low only the lower byte of the signatures are read. $DQ_{15}/A_{-1}$ is a don't care in the signature mode when BYTE# is low.                                                                                                                                                          |
| DQ <sub>0</sub> -DQ <sub>7</sub>  | 1/0        | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the command user interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array, Intelligent Identifier and Status Register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled.                                                               |
| DQ <sub>8</sub> -DQ <sub>15</sub> | 1/0        | DATA INPUT/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a program command. Data is internally latched during the write and program cycles. Outputs array data. The data pins float to tri-state when the chip is deselected or the outputs are disabled as in the byte-wide mode (BYTE# = "0"). In the byte-wide mode DQ <sub>15</sub> /A <sub>-1</sub> becomes the lowest order address for data output on DQ <sub>0</sub> -DQ <sub>7</sub> . |
| CE#                               | <b>I</b> , | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels. If CE# and RP# are high, but not at a CMOS high level, the standby current will increase due to current flow through the CE# and RP# input stages.                                                                                                        |
| RP#                               | I          | RESET/DEEP POWER-DOWN: Provides Three-State control. Puts the device in deep power-down mode. Locks the boot block from program/erase.                                                                                                                                                                                                                                                                                                                              |
|                                   |            | When RP# is at logic high level and equals 4.1V maximum the boot block is locked and cannot be programmed or erased.                                                                                                                                                                                                                                                                                                                                                |
|                                   |            | When RP# = 11.4V minimum the boot block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                                                                                |
|                                   |            | When RP# is at a logic low level the boot block is locked, the deep power-down mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions. When RP# transitions from logic low to logic high, the flash memory enters the read-array mode.                                                                                                                            |
| OE#                               | ı          | <b>OUTPUT ENABLE:</b> Gates the device's outputs through the data buffers during a read cycle. OE# is active low.                                                                                                                                                                                                                                                                                                                                                   |
| WE#                               | 1          | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                                                                                      |



# 1.5 Pin Descriptions for x8/x16 28F200BL (Continued)

| Symbol          | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BYTE#           | ı    | <b>BYTE</b> # <b>ENABLE</b> : Controls whether the device operates in the byte-wide mode (x8) or the word-wide mode (x16). BYTE# = "0" enables the byte-wide mode, where data is read and programmed on $DQ_0-DQ_7$ and $DQ_{15}/A_{-1}$ becomes the lowest order address that decodes between the upper and lower byte. $DQ_8-DQ_{14}$ are tri-stated during the byte-wide mode. BYTE# = "1" enables the word-wide mode where data is read and programmed on $DQ_0-DQ_{15}$ . |
| V <sub>PP</sub> |      | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.                                                                                                                                                                                                                                                                                                                                                                                 |
|                 |      | Note: V <sub>PP</sub> < V <sub>PPLMAX</sub> memory contents cannot be altered.                                                                                                                                                                                                                                                                                                                                                                                                 |
| V <sub>CC</sub> |      | DEVICE POWER SUPPLY (3.3V $\pm$ 0.3V, 5V $\pm$ 10%)                                                                                                                                                                                                                                                                                                                                                                                                                            |
| GND             |      | GROUND: For all internal circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| NC              |      | NO CONNECT: Pin may be driven or left floating.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DU              |      | DON'T USE PIN: Pin should not be connected to anything.                                                                                                                                                                                                                                                                                                                                                                                                                        |



# 1.6 Pin Descriptions for x8 28F002BL

| Symbol                           | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>17</sub>  | 1    | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                          |
| A <sub>9</sub>                   | 1    | <b>ADDRESS INPUT:</b> When $A_9$ is at 12V the signature mode is accessed. During this mode $A_0$ decodes between the manufacturer and device ID's.                                                                                                                                                                                                                                                  |
| DQ <sub>0</sub> –DQ <sub>7</sub> | 1/0  | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a program command. Inputs commands to the command user interface when CE# and WE# are active. Data is internally latched during the write and program cycles. Outputs array Intelligent Identifier and status register data. The data pins float to tri-state when the chip is deselected or the outputs are disabled. |
| CE#                              | ı    | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels.                                                                                                                                                                                            |
| RP#                              | 1    | RESET/DEEP POWER-DOWN: Provides Three-State control. Puts the device in deep power-down mode. Locks the Boot Block from program/erase.                                                                                                                                                                                                                                                               |
|                                  |      | When RP# is at logic high level and equals 4.1V maximum the Boot Block is locked and cannot be programmed or erased.                                                                                                                                                                                                                                                                                 |
|                                  |      | When RP# = 11.4V minimum the Boot Block is unlocked and can be programmed or erased.                                                                                                                                                                                                                                                                                                                 |
|                                  |      | When RP# is at a logic low level the Boot Block is locked, the deep power-down mode is enabled and the WSM is reset preventing any blocks from being programmed or erased, therefore providing data protection during power transitions. When RP# transitions from logic low to logic high, the flash memory enters the read-array mode.                                                             |
| OE#                              | I    | <b>OUTPUT ENABLE:</b> Gates the device's outputs through the data buffers during a read cycle. OE# is active low.                                                                                                                                                                                                                                                                                    |
| WE#                              | 1    | WRITE ENABLE: Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                                       |
| V <sub>PP</sub>                  | ,    | PROGRAM/ERASE POWER SUPPLY: For erasing memory array blocks or programming data in each block.                                                                                                                                                                                                                                                                                                       |
|                                  |      | Note: V <sub>PP</sub> < V <sub>PPLMAX</sub> memory contents cannot be altered.                                                                                                                                                                                                                                                                                                                       |
| V <sub>CC</sub>                  |      | DEVICE POWER SUPPLY (3.3V $\pm$ 0.3V, 5V $\pm$ 10%)                                                                                                                                                                                                                                                                                                                                                  |
| GND                              |      | GROUND: For all internal circuitry                                                                                                                                                                                                                                                                                                                                                                   |
| NC                               |      | NO CONNECT: Pin may be driven or left floating                                                                                                                                                                                                                                                                                                                                                       |
| DU :                             |      | DON'T USE PIN: Pin should not be connected to anything                                                                                                                                                                                                                                                                                                                                               |



# 2.0 28F200BL PRODUCTS DESCRIPTION



Figure 6. 28F200BL Word/Byte-Wide Block Diagram



#### 2.1 28F200BL Memory Organization

#### 2.1.1 BLOCKING

The 28F200BL uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirm commands are written to the CUI. The 28F200BL is a random read/write memory, only erasure is performed by block.

# 2.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being written or erased when RP# is not at 12V. The boot block can be erased and written when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F200BL-T and 28F200BL-B.

#### 2.1.1.2 Parameter Block Operation

The 28F200BL has 2 parameter blocks (8 Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. The parameter blocks provide for more efficient memory utilization when dealing with parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F200BL-T and 28F200BL-B.

#### 2.1.1.3 Main Block Operation

Two main blocks of memory exist on the 28F200BL (1  $\times$  128-Kbyte block and 1  $\times$  96-Kbyte blocks). See the following section on Block Memory Map for the address location of these blocks for the 28F200BL-T and 28F200BL-B products.

#### 2.1.2 BLOCK MEMORY MAP

Two versions of the 28F200BL product exist to support two different memory maps of the array blocks in order to accommodate different micropro-cessor protocols for boot code location. The 28F200BL-T memory map is inverted from the 28F200BL-B memory map.

#### 2.1.2.1 28F200BL-B Memory Map

The 28F200BL-B device has the 16-Kbyte boot block located from 00000H to 01FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F200BL-B the first 8-Kbyte parameter block resides in memory space from 02000H to 02FFFH. The second 8-Kbyte parameter block resides in memory space from 03000H to 03FFFH. The 96-Kbyte main block resides in memory space from 04000H to 0FFFFH. The 128-Kbyte main block resides in memory space from 10000H to 1FFFFH (word locations). See Figure 7.



Figure 7. 28F200BL-B Memory Map

#### 2.1.2.2 28F200BL-T Memory Map

The 28F200BL-T device has the 16-Kbyte boot block located from 1E000H to 1FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F200BL-T the first 8-Kbyte parameter block resides in memory space from 1D000H to 1DFFFH. The second 8-Kbyte parameter block resides in memory space from 1C000H to 1CFFFH. The 96-Kbyte main block resides in memory space from 10000H to 1BFFFH. The 128-Kbyte main block resides in memory space from 00000H to 0FFFFH as shown below in Figure 8



Figure 8. 28F200BL-T Memory Map



# 3.0 **28F002BL PRODUCTS** DESCRIPTION



Figure 9. 28F002BL Byte-Wide Block Diagram



#### 3.1 28F002BL Memory Organization

#### 3.1.1 BLOCKING

The 28F002BL uses a blocked array architecture to provide independent erasure of memory blocks. A block is erased independently of other blocks in the array when an address is given within the block address range and the Erase Setup and Erase Confirm commands are written to the CUI. The 28F002BL is a random read/write memory, only erasure is performed by block.

# 3.1.1.1 Boot Block Operation and Data Protection

The 16-Kbyte boot block provides a lock feature for secure code storage. The intent of the boot block is to provide a secure storage area for the kernel code that is required to boot a system in the event of power failure or other disruption during code update. This lock feature ensures absolute data integrity by preventing the boot block from being programmed or erased when RP# is not at 12V. The boot block can be erased and programmed when RP# is held at 12V for the duration of the erase or program operation. This allows customers to change the boot code when necessary while still providing security when needed. See the Block Memory Map section for address locations of the boot block for the 28F002BL-T and 28F002BL-B.

#### 3.1.1.2 Parameter Block Operation

The 28F002BL has 2 parameter blocks (8 Kbytes each). The parameter blocks are intended to provide storage for frequently updated system parameters and configuration or diagnostic information. The parameter blocks can also be used to store additional boot or main code. The parameter blocks however, do not have the hardware write protection feature that the boot block has. Parameter blocks provide for more efficient memory utilization when dealing with small parameter changes versus regularly blocked devices. See the Block Memory Map section for address locations of the parameter blocks for the 28F002BL-T and 28F002BL-B.

#### 3.1.1.3 Main Block Operation

Two main blocks of memory exist on the 28F002BL (1 x 128-Kbyte block and 1 x 96-Kbyte block).

See the following section on Block Memory Map for the address location of these blocks for the 28F002BL-T and 28F002BL-B.

#### 3.1.2 BLOCK MEMORY MAP

Two versions of the 28F002BL product exist to support two different memory maps of the array blocks in order to accommodate different microprocessor protocols for boot code location. The 28F002BL-T memory map is inverted from the 28F002BL-B memory map.

#### 3.1.2.1 28F002BL-B Memory Map

The 28F002BL-B device has the 16-Kbyte boot block located from 00000H to 03FFFH to accommodate those microprocessors that boot from the bottom of the address map at 00000H. In the 28F002BL-B the first 8-Kbyte parameter block resides in memory from 04000H to 05FFFH. The second 8-Kbyte parameter block resides in memory space from 06000H to 07FFFH. The 96-Kbyte main block resides in memory space from 08000H to 1FFFFH. The 128-Kbyte main block resides in memory space from 20000H to 3FFFFH. See Figure 10.



Figure 10. 28F002BL-B Memory Map





#### 3.1.2.2 28F002BL-T Memory Map

The 28F002BL-T device has the 16-Kbyte boot block located trom 3C000H to 3FFFFH to accommodate those microprocessors that boot from the top of the address map. In the 28F002BL-T the first 8-Kbyte parameter block resides in memory space from 3A000H to 3BFFFH. The second 8-Kbyte parameter block resides in memory space from 38000H to 39FFFH. The 96-Kbyte main block resides in memory space from 20000H to 37FFFH. The 128-Kbyte main block resides in memory space from 00000H to 1FFFFH.



Figure 11. 28F002BL-T Memory Map

# 4.0 PRODUCT FAMILY PRINCIPLES OF OPERATION

Flash memory augments EPROM functionality with in-circuit electrical write and erase. The 2-Mbit flash family utilizes a Command User Interface (CUI) and internally generated and timed algorithms to simplify write and erase operations.

The CUI allows for fixed power supplies during erasure and programming, and maximum EPROM compatibility.

In the absence of high voltage on the V<sub>PP</sub> pin, the 2-Mbit flash family will only successfully execute the following commands: Read Array, Read Status Register, Clear Status Register and Intelligent Identifier mode. The device provides standard EPROM read, standby and output disable operations. Manufacturel Identification and Device Identification data can be accessed through the CUI or through the standard EPROM A9 high voltage access (V<sub>ID</sub>) (for PROM programmer equipment).

The same EPROM read, standby and output disable functions are available when high voltage is applied to the  $V_{PP}$  pin. In addition, high voltage on  $V_{PP}$  allows write and erase of the device. All functions associated with altering memory contents: write and erase, Intelligent Identifier read and Read Status are accessed via the CUI.

The purpose of the Write State Machine (WSM) is to completely automate the write and erasure of the device. The WSM will begin operation upon receipt of a signal from the CUI and will report status back through a Status Register. The CUI will handle the WE# interface to the data and address latches, as well as system software requests for status while the WSM is in operation.

### 4.1 28F200BL Bus Operations

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles.



Table 1. Bus Operations for WORD-WIDE Mode (BYTE  $\# = V_{IH}$ )

| Mode                            | Notes       | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-15</sub> |
|---------------------------------|-------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------------|
| Read                            | 1, 2, 3     | V <sub>IH</sub> | $V_{IL}$        | V <sub>IL</sub> | V <sub>IH</sub> | X               | Х               | Х               | D <sub>OUT</sub>   |
| Output Disable                  |             | V <sub>IH</sub> | $V_{IL}$        | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | High Z             |
| Standby                         |             | V <sub>IH</sub> | V <sub>IH</sub> | ×               | X               | Х               | Х               | ` X             | High Z             |
| Deep Power-Down                 | 9           | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х               | Х               | High Z             |
| Intelligent Identifier (Mfr)    | 4           | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $V_{ID}$        | $V_{IL}$        | Х               | 0089H              |
| Intelligent Identifier (Device) | 4, 5,<br>10 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | 2274H<br>2275H     |
| Write                           | 6, 7, 8     | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х               | D <sub>IN</sub>    |

#### Table 2. Bus Operations for BYTE-WIDE Mode (BYTE $\# = V_{IL}$ )

| Mode                            | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | A-1 | $V_{PP}$ | DQ <sub>0-7</sub> | DQ <sub>8-14</sub> |
|---------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|----------|-------------------|--------------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х   | Х        | D <sub>OUT</sub>  | High Z             |
| Output Disable                  |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $V_{IH}$        | Х               | Х               | Х   | Х        | High Z            | High Z             |
| Standby                         |         | V <sub>IH</sub> | V <sub>IH</sub> | X               | Х               | Х               | Х               | Х   | Х        | High Z            | High Z             |
| Deep Power-Down                 | 9       | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х               | Х   | Х        | High Z            | High Z             |
| Intelligent Identifier (Mfr)    | 4       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х   | X        | 89H               | High Z             |
| Intelligent Identifier (Device) | 4, 5    | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х   | Х        | 74H<br>75H        | High Z             |
| Write                           | 6, 7, 8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х   | Х        | D <sub>IN</sub>   | High Z             |

#### NOTES:

- Refer to DC Characteristics.
- 2. X can be V<sub>IL</sub> or V<sub>IH</sub> for control pins and addresses, V<sub>PPL</sub> or V<sub>PPH</sub> for V<sub>PP</sub>.
- 3. See DC characteristics for V<sub>PPL</sub>, V<sub>PPH</sub>, V<sub>HH</sub>, V<sub>ID</sub> voltages.
- 4. Manufacturer and Device codes may also be accessed via a CPU write sequence. A<sub>1</sub>-A<sub>16</sub> = V<sub>IL</sub>.
- 5. Device ID = 2274H for 28F200BL-T and 2275H for 28F200BL-B.
- 6. Refer to Table 4 for valid DIN during a write operation.
- 7. Command writes for Block Erase or Word/Byte Write are only executed when VPP = VPPH.
- 8. To write or erase the boot block, hold RP# at V<sub>HH</sub>.
- 9. RP# must be at GND  $\pm 0.2$ V to meet the 1.2  $\mu$ A maximum deep power-down current.
- 10. The device ID codes are identical to those of the 28F2100BX 5V versions and SmartVoltage equivalents.



#### 4.2 28F002BL Bus Operations

**Table 3. Bus Operations** 

| Mode                            | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>    | V <sub>PP</sub> | DQ <sub>0-7</sub> |
|---------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|-----------------|-------------------|
| Read                            | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х                 | Х               | D <sub>OUT</sub>  |
| Output Disable                  |         | V <sub>IH</sub> | V <sub>IL</sub> | ViH             | V <sub>IH</sub> | Х               | Х                 | X               | High Z            |
| Standby                         |         | V <sub>IH</sub> | V <sub>IH</sub> | X               | Х               | · X             | Χ.                | Х               | High Z            |
| Deep Power-Down                 | 9       | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х                 | X               | High Z            |
| Intelligent Identifier (Mfr)    | 4       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $V_{ID}$        | V <sub>IL</sub> . | Х               | 89H               |
| Intelligent Identifier (Device) | 4, 5    | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub>   | Х               | 7CH<br>7DH        |
| Write                           | 6, 7, 8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х                 | Х               | D <sub>IN</sub>   |

#### NOTES:

- 1. Refer to DC Characteristics.
- 2. X can be V<sub>II</sub> or V<sub>IH</sub> for control pins and addresses, V<sub>PPI</sub> or V<sub>PPH</sub> for V<sub>PP</sub>.
- 3. See DC characteristics for VPPL, VPPH, VHH, VID voltages.
- Manufacturer and Device codes may also be accessed via a CUI write sequence. A<sub>1</sub>-A<sub>17</sub> = V<sub>IL</sub>.
- 5. Device ID = 7CH for 28F002BL-T and 7DH for 28F002BL-B.
- 6. Refer to Table 4 for valid DIN during a write operation.
- 7. Command writes for Block erase or byte program are only executed when VPP = VPPH.
- 8. Program or erase the Boot block by holding RP# at VHH.
- 9. RP# must be at GND  $\pm 0.2$ V to meet the 1.2  $\mu$ A maximum deep power-down current.
- 10. The device ID codes are identical to those of the 28F002BX 5V versions and SmartVoltage equivalents.

#### 4.3 Read Operations

The 2-Mbit flash family has three user read modes; Array, Intelligent Identifier, and Status Register. Status Register read mode will be discussed in detail in the "Write Operations" section.

During power-up conditions ( $V_{CC}$  supply ramping), it takes a maximum of 600 ns from  $V_{CC}$  at 3.0V minimum to obtain valid data on the outputs.

#### 4.3.1 READ ARRAY

If the memory is not in the Read Array mode, it is necessary to write the appropriate read mode command to the CUI. The 2-Mbit flash family has three control functions, all of which must be logically active, to obtain data at the outputs. Chip-Enable CE# is the device selection control. Power-Down RP# is the device power control. Output-Enable OE# is the DATA INPUT/OUTPUT (DQ[0:15] or DQ[0:7]) direction control and when active is used to drive data from the selected memory on to the I/O bus.

#### 4.3.1.1 Output Control

With OE# at logic-high level (V<sub>IH</sub>), the output from the device is disabled and data input/output pins (DQ[0:15] or DQ[0:7]) are tri-stated. Data input is then controlled by WE#.

#### 4.3.1.2 Input Control

With WE# at logic-high level (V<sub>IH</sub>), input to the device is disabled. Data Input/Output pins (DQ[0:15] or DQ[0:7]) are controlled by **OE**#.

#### 4.3.2 INTELLIGENT IDENTIFIERS

#### 28F200BL Products

The manufacturer and device codes are read via the CUI or by taking the  $A_9$  pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 0089H, and location 00001H outputs the device code; 2274H for 28F200BL-T, 2275H for 28F200BL-B. When BYTE# is at a logic low only the lower byte of the above signatures is read and DQ15/A $_1$  is a "don't care" during Intelligent Identifier mode. A read array command must be written to the CUI to return to the read array mode.



#### 28F002BL Products

The manufacturer and device codes are also read via the CUI or by taking the  $A_9$  pin to 12V. Writing 90H to the CUI places the device into Intelligent Identifier read mode. A read of location 00000H outputs the manufacturer's identification code, 89H, and location 00001H outputs the device code; 7CH for 28F002BL-B.

#### 4.4 Write Operations

Commands are written to the CUI using standard microprocessor write timings. The CUI serves as the interface between the microprocessor and the internal chip operation. The CUI can decipher Read Array, Read Intelligent Identifier, Read Status Register, Clear Status Register, Erase and Program commands. In the event of a read command, the CUI simply points the read path at either the array, the Intelligent Identifier, or the status register depending on the specific read command given. For a program or erase cycle, the CUI informs the write state machine that a write or erase has been requested. During a program cycle, the Write State Machine will control the program sequences and the CUI will only respond to status reads. During an erase cycle, the CUI will respond to status reads and erase suspend. After the Write State Machine has completed its task, it will allow the CUI to respond to its full command set. The CUI will stay in the current command state until the microprocessor issues another command.

The CUI will successfully initiate an erase or write operation only when V<sub>PP</sub> is within its voltage range. Depending upon the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable, available only when memory updates are desired. The system designer can also choose to "hard-wire" V<sub>PP</sub> to 12V. The 2-Mbit flash family is designed to accommodate either design practice. It is recommended that RP# be tied to logical Reset for data protection during unstable CPU reset function as described in the "Product Family Overview" section.

#### 4.4.1 BOOT BLOCK WRITE OPERATIONS

In the case of Boot Block modifications (write and erase), RP# is set to  $V_{HH}=12V$  typically, in addition to  $V_{PP}$  at high voltage. However, if RP# is not at  $V_{HH}$  when a program or erase operation of the boot block is attempted, the corresponding status register bit (Bit 4 for Program and Bit 5 for Erase, refer to Table 5 for Status Register Definitions) is set to indicate the failure to complete the operation.

#### 4.4.2 COMMAND USER INTERFACE (CUI)

The Command User Interface (CUI) serves as the interface to the microprocessor. The CUI points the read/write path to the appropriate circuit block as described in the previous section. After the WSM has completed its task, it will set the WSM Status bit to a "1", which will also allow the CUI to respond to its full command set. Note that after the WSM has returned control to the CUI, the CUI will remain in its current state.

#### 4.4.2.1 Command Set

| Command<br>Codes | Device Mode                |
|------------------|----------------------------|
| 00               | Invalid/Reserved           |
| 10               | Alternate Program Setup    |
| 20               | Erase Setup                |
| 40               | Program Setup              |
| 50               | Clear Status Register      |
| 70               | Read Status Register       |
| 90               | Intelligent Identifier     |
| В0               | Erase Suspend              |
| D0               | Erase Resume/Erase Confirm |
| FF               | Read Array                 |

#### 4.4.2.2 Command Function Descriptions

Device operations are selected by writing specific commands into the CUI. Table 4 defines the 2-Mbit flash family commands.





**Table 4. Command Definitions** 

| Command                                  | Bus<br>Cycles | Notes   | First Bus Cycle |         |      | Second Bus Cycle |         |      |  |
|------------------------------------------|---------------|---------|-----------------|---------|------|------------------|---------|------|--|
|                                          | Req'd         | 8       | Operation       | Address | Data | Operation        | Address | Data |  |
| Read Array                               | 1             | 1       | Write           | Х       | FFH  |                  |         |      |  |
| Intelligent Identifier                   | 3             | 2, 4    | Write           | Х       | 90H  | Read             | IA.     | IID  |  |
| Read Status Register                     | 2             | 3       | Write           | Х       | 70H  | Read             | X       | SRD  |  |
| Clear Status Register                    | 1             |         | Write           | Х       | 50H  |                  |         |      |  |
| Erase Setup/Erase Confirm                | 2             | 5       | Write           | BA      | 20H  | Write            | ВА      | DOH  |  |
| Word/Byte Write<br>Setup/Write           | 2             | 6, 7    | Write           | WA      | 40H  | Write            | WA      | WD   |  |
| Erase Suspend/Erase Resume               | 2             |         | Write           | Х       | вон  | Write            | Х       | DOH  |  |
| Alternate Word/Byte Write<br>Setup/Write | 2             | 2, 3, 7 | Write           | - WA    | 10H  | Write            | WA      | WD   |  |

#### NOTES:

- 1. Bus operations are defined in Tables 1, 2, 3,
- 2. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
- 3. SRD = Data read from Status Register.
- 4. IID = Intelligent Identifier Data.
- Following the Intelligent Identifier Command, two read operations access manufacturer and device codes.
- 5. BA = Address within the block being erased.
- 6. WA = Address to be written.
- WD = Data to be written at location WA.
- 7. Either 40H or 10H commands is valid.
- 8. When writing commands to the device, the upper data bus [DQ<sub>8</sub>-DQ<sub>15</sub>] = X (28F200BL-only) which is either V<sub>CC</sub> or V<sub>SS</sub> to avoid burning additional current.

#### Invalid/Reserved

These are unassigned commands. It is not recommended that the customer use any command other than the valid commands specified above. Intel reserves the right to redefine these codes for future functions.

#### Read Array (FFH)

This single write command points the read path at the array. If the host CPU performs a CE#/OE# controlled read immediately following a two-write sequence that started the WSM, then the device will output status register contents. If the Read Array command is given after Erase Setup the device is reset to read the array. A two Read Array command sequence (FFH) is required to reset to Read Array after Program Setup.

#### Intelligent Identifier (90H)

After this command is executed, the CUI points the output path to the Intelligent Identifier circuits. Only Intelligent Identifier values at addresses 0 and 1 can be read (only address A0 is used in this mode, all other address inputs are ignored).

#### Read Status Register (70H)

This is one of the two commands that is executable while the state machine is operating. After this command is written, a read of the device will output the contents of the status register, regardless of the address presented to the device.

The device automatically enters this mode after program or erase has completed.

#### Clear Status Register (50H)

The WSM can only set the Program Status and Erase Status bits in the status register, it can not clear them. Two reasons exist for operating the status register in this fashion. The first is a synchronization. The WSM does not know when the host CPU has read the status register, therefore it would not know when to clear the status bits. Secondly, if the CPU is programming a string of bytes, it may be more efficient to query the status register after programming the string. Thus, if any errors exist while programming the string, the status register will return the accumulated error status.



#### Program Setup (40H or 10H)

This command simply sets the CUI into a state such that the next write will load the address and data registers. Either 40H or 10H can be used for Program Setup. Both commands are included to accommodate efforts to achieve an industry standard command code set.

#### **Program**

The second write after the program setup command, will latch addresses and data. Also, the CUI initiates the WSM to begin execution of the program algorithm. While the WSM finishes the algorithm, the device will output Status Register contents. Note that the WSM cannot be suspended during programming.

#### Erase Setup (20H)

Prepares the CUI for the Erase Confirm command. No other action is taken. If the next command is not an Erase Confirm command then the CUI will set both the Program Status and Erase Status bits of the Status Register to a "1", place the device into the Read Status Register state, and wait for another command.

#### **Erase Confirm (D0H)**

If the previous command was an Erase Setup command, then the CUI will enable the WSM to erase, at the same time closing the address and data latches, and respond only to the Read Status Register and Erase Suspend commands. While the WSM is executing, the device will output Status Register data when OE# is toggled low. Status Register data can only be updated by toggling either OE# or CE# low.

#### Erase Suspend (B0H)

This command only has meaning while the WSM is executing an Erase operation, and therefore will only be responded to during an erase operation. After this command has been executed, the CUI will initiate the WSM to suspend Erase operations, and then return to responding to only Read Status Register or to the Erase Resume commands. Once the WSM has reached the Suspend state, it will set an output into the CUI which allows the CUI to respond to the Read Array, Read Status Register, and Erase Resume commands. In this mode, the CUI will not respond to any other commands. The WSM will also

set the WSM Status bit to a "1". The WSM will continue to run, idling in the SUSPEND state, regardless of the state of all input control pins, with the exclusion of RP#. RP# low will immediately shut down the WSM and the remainder of the chip.

#### Erase Resume (D0H)

This command will cause the CUI to clear the Suspend state and set the WSM Status bit to a "0", but only if an Erase Suspend command was previously issued. Erase Resume will not have any effect in all other conditions.

#### 4.4.3 STATUS REGISTER

The 2-Mbit flash family contains a status register which may be read to determine when a program or erase operation is complete, and whether that operation completed successfully. The status register may be read at any time by writing the Read Status command to the CUI. After writing this command, all subsequent Read operations output data from the status register until another command is written to the CUI. A Read Array command must be written to the CUI to return to the Read Array mode.

The status register bits are output on DQ[0:7] whether the device is in the byte-wide (x8) or word-wide (x16) mode for the 28F200BL. In the word-wide mode the upper byte, DQ[8:15] is set to 00H during a Read Status command. In the byte-wide mode, DQ[8:14] are tri-stated and DQ<sub>15</sub>/A<sub>-1</sub> retains the low order address function.

It should be noted that the contents of the status register are latched on the falling edge of OE# or CE# whichever occurs last in the read cycle. This prevents possible bus errors which might occur if the contents of the status register change while reading the status register. CE# or OE# must be toggled with each subsequent status read, or the completion of a program or erase operation will not be evident.

The Status Register is the interface between the microprocessor and the Write State Machine (WSM). When the WSM is active, this register will indicate the status of the WSM, and will also hold the bits indicating whether or not the WSM was successful in performing the desired operation. The WSM sets status bits "Three" through "Seven" and clears bits "Six" and "Seven", but cannot clear status bits "Three" through "Five". These bits can only be cleared by the controlling CPU through the use of the Clear Status Register command.



#### 4.4.3.1 Status Register Bit Definition

#### **Table 5. Status Register Definitions**



SR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase in Progress/Completed

SR.5 = FRASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

SR.4 = PROGRAM STATUS

1 = Error in Byte/Word Program

0 = Successful Byte/Word Program

 $SR.3 = V_{PP} STATUS$ 

1 = V<sub>PP</sub> Low Detect; Operation Abort

 $0 = V_{PP} OK$ 

Write State Machine Status bit must first be checked to determine byte/word program or block erase completion, before the Program or Erase Status bits are checked for success.

When Erase Suspend is issued, WSM halts execution and sets both WSMS and ESS bits to "1". ESS bit remains set to "1" until an Erase Resume command is issued

When this bit is set to "1". WSM has applied the maximum number of erase pulses to the block and is still unable to successfully perform an erase verify.

When this bit is set to "1", WSM has attempted but failed to Program a byte or word.

The V<sub>PP</sub> Status bit unlike an A/D converter, does not provide continuous indication of V<sub>PP</sub> level. The WSM interrogates the V<sub>PP</sub> level only after the byte write or block erase command sequences have been entered and informs the system if V<sub>PP</sub> has not been switched on. The V<sub>PP</sub> Status bit is not guaranteed to report accurate feedback between V<sub>PP</sub> and V<sub>PPH</sub>.

SR.2-SR.0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use and should be masked out when polling the Status Register.

#### 4.4.3.2 Clearing the Status Register

Certain bits in the status register are set by the write state machine, and can only be reset by the system software. These bits can indicate various failure conditions. By allowing the system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several bytes or erasing multiple blocks in sequence). The status register may then be read to determine if an error occurred during that programming or erasure series. This adds flexibility to the way the device may be programmed or erased. To clear the status register, the Clear Status Register command is written to the CUI. Then, any other command may be issued to the CUI. Note again that before a read cycle can be initiated, a Read Array command must be written to the CUI to specify whether the read data is to come from the array, status register, or Intelligent Identifier.

#### 4.4.4 PROGRAM MODE

Program is executed by a two-write sequence. The Program Setup command is written to the CUI followed by a second write which specifies the address and data to be programmed. The write state machine will execute a sequence of internally timed events to:

- program the desired bits of the addressed memory word (byte), and
- verify that the desired bits are sufficiently programmed.

Programming of the memory results in specific bits within a byte or word being changed to a "0".

If the user attempts to program "1"s, there will be no change of the memory cell content and no error occurs.



Similar to erasure, the status register indicates whether programming is complete. While the program sequence is executing, bit 7 of the status register is a "0". The status register can be polled by toggling either CE# or OE# to determine when the program sequence is complete. Only the Read Status Register command is valid while programming is active.

When programming is complete, the status bits, which indicate whether the program operation was successful, should be checked. If the programming operation was unsuccessful, Bit 4 of the status register is set to a "1" to indicate a Program Failure. If Bit 3 is set then V<sub>PP</sub> was not within acceptable limits, and the WSM will not execute the programming sequence.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after programming is completed; however, it must be recognized that reads from the memory, status register, or Intelligent Identifier cannot be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 12 shows a system software flowchart for device byte programming operation. Figure 13 shows a similar flowchart for device word programming operation (28F200BL-only).

#### 4.4.5 ERASE MODE

Erasure of a single block is initiated by writing the Erase Setup and Erase Confirm commands to the CUI, along with the addresses, A[12:16] for the 28F200BL or A[12:17] for the 28F002BL, identifying the block to be erased. These addresses are latched internally when the Erase Confirm command is issued. Block erasure results in all bits within the block being set to "1".

The WSM will execute a sequence of internally timed events to:

- 1. program all bits within the block
- verify that all bits within the block are sufficiently programmed
- 3. erase all bits within the block and
- verify that all bits within the block are sufficiently erased

While the erase sequence is executing, Bit 7 of the status register is a "0".

When the status register indicates that erasure is complete, the status bits, which indicate whether the erase operation was successful, should be checked.

If the erasure operation was unsuccessful, Bit 5 of the status register is set to a "1" to indicate an Erase Failure. If  $V_{PP}$  was not within acceptable limits after the Erase Confirm command is issued, the WSM will not execute an erase sequence; instead, Bit 5 of the status register is set to a "1" to indicate an Erase Failure, and Bit 3 is set to a "1" to identify that  $V_{PP}$  supply voltage was not within acceptable limits

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after erasure is completed; however, it must be recognized that reads from the memory array, status register, or Intelligent Identifier can not be accomplished until the CUI is given the appropriate command. A Read Array command must first be given before memory contents can be read.

Figure 14 shows a system software flowchart for Block Erase operation.

#### 4.4.5.1 Suspending and Resuming Erase

Since an erase operation typically requires 2 to 5 seconds to complete, an Erase Suspend command is provided. This allows erase-sequence interruption in order to read data from another block of the memory. Once the erase sequence is started, writing the Erase Suspend command to the CUI requests that the Write State Machine (WSM) pause the erase sequence at a predetermined point in the erase algorithm. The status register must be read to determine when the erase operation has been suspended.

At this point, a Read Array command can be written to the CUI in order to read data from blocks other than that which is being suspended. The only other valid command at this time is the Erase Resume command or Read Status Register operation.

Figure 15 shows a system software flowchart detailing the operation.

During Erase Suspend mode, the chip can go into a pseudo-standby mode by taking CE# to  $V_{IH}$  and the active current is now a maximum of 6 mA. If the chip is enabled while in this mode by taking CE# to  $V_{IL}$ , the Erase Resume command can be issued to resume the erase operation.

Upon completion of reads from any block other than the block being erased, the Erase Resume command must be issued. When the Erase Resume command is given, the WSM will continue with the erase sequence and complete erasing the block. As with the end of erase, the status register must be read, cleared, and the next instruction issued in order to continue.



#### 4.4.6 EXTENDED CYCLING

Intel has designed extended cycling capability into its ETOX III flash memory technology. The 2-Mbit low voltage flash family is designed for 10,000 pro-

gram/erase cycles on each of the five blocks. The combination of low electric fields, clean oxide processing and minimized oxide area per memory cell subjected to the tunneling electric field, results in very high cycling capability.



Figure 12. Automated Byte Programming Flowchart





| Bus<br>Operation | Command          | Comments                                                          |
|------------------|------------------|-------------------------------------------------------------------|
| Write            | Setup<br>Program | Data = 40H<br>Address = Word to be<br>programmed                  |
| Write            | Program          | Data to be programmed<br>Address = Word to be<br>programmed       |
| Read             |                  | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                  | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent words.

Full status check can be done after each word or after a sequence of words.

Write FFH after the last word programming operation to reset the device to Read Array Mode.

| Status Register Data<br>Read (See Above) |                                |
|------------------------------------------|--------------------------------|
| SR.3 = 0 NO                              | V <sub>PP</sub> Range<br>Error |
| SR.4 = 0 NO                              | Word Program<br>Error          |
| Word Program<br>Successful               | 290449-11                      |

| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4<br>1 = Word Program Error         |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple words are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 13. Automated Word Programming Flowchart





| Bus<br>Operation | Command        | Comments                                                          |
|------------------|----------------|-------------------------------------------------------------------|
| Write            | Setup<br>Erase | Data = 20H<br>Address = Within block to be<br>erased              |
| Write            | Erase          | Data = D0H<br>Address = Within block to be<br>erased              |
| Read             |                | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent blocks.

Full status check can be done after each block or after a sequence of blocks.

Write FFH after the last block erase operation to reset the device to Read Array Mode.

#### **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4,5 Both 1 = Command Sequence Error |
| Standby          |         | Check SR.5<br>1 = Block Erase Error          |

SR.3 MUST be cleared, if set during an erase attempt, before further attempts are allowed by the Write State Machine.

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 14. Automated Block Erase Flowchart





Figure 15. Erase Suspend/Resume Flowchart

#### 4.5 Power Consumption

#### 4.5.1 ACTIVE POWER

With CE# at a logic-low level and RP# at a logic-high level, the device is placed in the active mode. The device  $I_{CC}$  current is a maximum of 22 mA at 5 MHz.

#### 4.5.2 AUTOMATIC POWER SAVINGS

Automatic Power Savings (APS) is a low power feature during active mode of operation. The 2-Mbit flash family of products incorporate Power Reduction Control (PRC) circuitry which basically allows the device to put itself into a low current state when it is not being accessed. After data is read from the

memory array, PRC logic controls the device's power consumption by entering the APS mode where typical  $I_{\rm CC}$  current is 0.8 mA and maximum  $I_{\rm CC}$  current is 2 mA. The device stays in this static state with outputs valid until a new memory location is read.

#### 4.5.3 STANDBY POWER

With CE# at a logic-high level (V<sub>IH</sub>), and the CUI in read mode, the memory is placed in standby mode where the maximum  $I_{CC}$  standby current is 120  $\mu A$  with CMOS input signals. The standby operation disables much of the device's circuitry and substantially reduces device power consumption. The outputs (DQ[0:15] or DQ[0:7]) are placed in a high-impedance state independent of the status of the OE# signal. When the 2-Mbit flash family is deselected during erase or program functions, the devices will



continue to perform the erase or program function and consume program or erase active power until program or erase is completed.

#### 4.5.4 RESET/DEEP POWER-DOWN

The 2-Mbit flash family supports a typical  $I_{CC}$  of 0.2  $\mu$ A in deep power-down mode. One of the target markets for these devices is in portable equipment where the power consumption of the machine is of prime importance. The 2-Mbit flash family has a RP# pin which places the device in the deep power-down mode. When RP# is at a logic-low (GND  $\pm$ 0.2V), all circuits are turned off and the device typically draws 0.2  $\mu$ A of V<sub>CC</sub> current.

During read modes, the RP# pin going low deselects the memory and places the output drivers in a high impedance state. Recovery from the deep power-down state, requires a maximum of 600 ns to access valid data (tpHOV).

During erase or program modes, RP# low will abort either erase or program operation. The contents of the memory are no longer valid as the data has been corrupted by the RP# function. As in the read mode above, all internal circuitry is turned off to achieve the 0.2  $\mu$ A current level.

RP# transitions to  $V_{IL}$  or turning power off to the device will clear the status register.

The use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset, it expects to read from the flash memory. Automated flash memories provide status information when accessed during write/erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of RP# input. In this application, RP# is controlled by the same RESET# signal that resets the system CPU.

# 4.6 Power-Up Operation

The 2-Mbit flash family is designed to offer protection against accidental block erasure or programming during power transitions. Upon power-up the 2-Mbit flash family is indifferent as to which power supply, V<sub>PP</sub> or V<sub>CC</sub>, powers-up first. Power supply sequencing is not required.

The 2-Mbit flash family ensures the CUI is reset to the read mode on power-up.

In addition, on power-up the user must either drop CE# low or present a new address to ensure valid data at the outputs.

A system designer must guard against spurious writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either signal to  $V_{IH}$  will inhibit writes to the device. The CUI architecture provides an added level of protection since alteration of memory contents can only occur after successful completion of the two-step command sequences. Finally the device is disabled until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. This feature provides yet another level of memory protection

#### 4.7 Power Supply Decoupling

Flash memory's power switching characteristics require careful device decoupling methods. System designers are interested in 3 supply current issues:

- Standby current levels (I<sub>CCS</sub>)
- Active current levels (I<sub>CCR</sub>)
- Transient peaks produced by falling and rising edges of CE#.

Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress these transient voltage peaks. Each flash device should have a 0.1  $\mu\text{F}$  ceramic capacitor connected between each  $V_{CC}$  and GND, and between its  $V_{PP}$  and GND. These high frequency, low-inherent inductance capacitors should be placed as close as possible to the package leads.

# 4.7.1 V<sub>PP</sub> TRACE ON PRINTED CIRCUIT BOARDS

Writing to flash memories while they reside in the target system, requires special consideration of the V<sub>PP</sub> power supply trace by the printed circuit board designer. The V<sub>PP</sub> pin supplies the flash memory cell's current for programming and erasing. One should use similar trace widths and layout considerations given to the V<sub>CC</sub> power supply trace. Adequate V<sub>PP</sub> supply traces and decoupling will decrease spikes and overshoots.

#### 4.7.2 V<sub>CC</sub>, V<sub>PP</sub> AND RP# TRANSITIONS

The CUI latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its state upon power-up, after exit from deep power-down mode or after  $V_{CC}$  transitions below  $V_{LKO}$  (Lockout voltage), is Read Array mode.

After any word/byte write or block erase operation is complete and even after  $V_{PP}$  transitions down to  $V_{PPL}$ , the CUI must be reset to Read Array mode via the Read Array command when accesses to the flash memory are desired.



#### 5.0 OPERATING SPECIFICATIONS

#### **Absolute Maximum Ratings**

Operating Temperature During Read .....  $-20^{\circ}$ C to  $+70^{\circ}$ C<sup>(1)</sup> During Block Erase and Word/Byte Write......0°C to 70°C Temperature Under Bias . . . . . . .  $-200^{\circ}$ C to  $+80^{\circ}$ C Storage Temperature .....-65°C to +125°C Voltage on Any Pin (except V<sub>CC</sub>, V<sub>PP</sub>, A<sub>9</sub> and RP#) with Respect to GND ...... -2.0V to +7.0V<sup>(2)</sup> Voltage on Pin RP# or Pin Aq with Respect to GND ..... -2.0V to  $13.5V^{(2,3)}$ VPP Program Voltage with Respect to GND during Block Erase and Word/Byte Write  $\dots$  -2.0V to +14.0V(2, 3) V<sub>CC</sub> Supply Voltage with Respect to GND  $\dots$  -2.0V to +7.0V(2)

Output Short Circuit Current......100 mA(4)

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

1. Operating temperature is for commercial product defined by this specification.

2. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is  $V_{CC} + 0.5$ V which, during transitions, may overshoot to  $V_{CC} + 2.0$ V for periods <20 ns.

3. Maximum DC voltage on  $V_{PP}$  may overshoot to +14.0V for periods <20 ns. Maximum DC voltage on RP# or  $A_9$  may overshoot to 13.5V for periods <20 ns.

4. Output shorted for no more than one second. No more than one output shorted at a time.

5. AC Specifications are valid at both voltage ranges. See DC Characteristics table for voltage range-specific specifications.

#### OPERATING CONDITIONS

| Symbol Parameter |                                | Notes | Min  | Max  | Unit     |
|------------------|--------------------------------|-------|------|------|----------|
| TA               | Operating Temperature          |       | -20  | +70  | ç        |
| V <sub>CC</sub>  | V <sub>CC</sub> Supply Voltage |       | 3.00 | 3.60 | ٧        |
| V <sub>CC</sub>  | V <sub>CC</sub> Supply Voltage | 5     | 4.50 | 5.50 | <b>V</b> |

#### DC CHARACTERISTICS V<sub>CC</sub> = 3.3V ±0.3V Read, 3.15V-3.6V Program/Erase

| Symbol          | Parameter                               | Notes | Min | Тур  | Max  | Unit | Test Condition                                          |
|-----------------|-----------------------------------------|-------|-----|------|------|------|---------------------------------------------------------|
| I <sub>LI</sub> | Input Load Current                      | 1     |     |      | ±1.0 | μА   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$       |
| ILO             | Output Leakage Current                  | 1     |     |      | ±10  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$      |
| Iccs            | V <sub>CC</sub> Standby Current         | 1, 3  |     | 45   | 120  | μΑ   | $V_{CC} = V_{CC} Max$ $CE \# = RP \# = V_{CC} \pm 0.2V$ |
|                 |                                         |       |     | 45   | 120  | μΑ   | $V_{CC} = V_{CC} Max$ $CE \# = RP \# = V_{IH}$          |
| ICCD            | V <sub>CC</sub> Deep Power-down Current | 1     | ,   | 0.20 | 1.2  | μΑ   | RP# = GND ±0.2V                                         |



# **DC CHARACTERISTICS** $V_{CC} = 3.3V \pm 0.3V$ Read, 3.15V-3.6V Program/Erase (Continued)

| Symbol            | Parameter                                                                                                       | Notes      | Min                  | Тур  | Max                  | Unit     | Test Condition                                                                    |
|-------------------|-----------------------------------------------------------------------------------------------------------------|------------|----------------------|------|----------------------|----------|-----------------------------------------------------------------------------------|
| ICCR              | V <sub>CC</sub> Read Current for<br>28F200BX-L Word-Wide and<br>Byte-Wide Mode and<br>28F002BX-L Byte-Wide Mode | 1, 5,<br>6 |                      | 15   | 25                   | mA       | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>f = 5 MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs |
|                   | 201 002BX-E Byte-Wide Mode                                                                                      |            |                      | 15   | 25                   | mA       | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$ f = 5 MHz, $I_{OUT} = 0$ mA TTL Inputs     |
| Iccw              | V <sub>CC</sub> Word/Byte Write Current                                                                         | 1, 4       |                      |      | 30                   | mΑ       | Word/Byte Write in Progress                                                       |
| ICCE              | V <sub>CC</sub> Block Erase Current                                                                             | 1, 4       |                      |      | 20                   | mΑ       | Block Erase in Progress                                                           |
| ICCES             | V <sub>CC</sub> Erase Suspend Current                                                                           | 1, 2       |                      | 3    | 6                    | mΑ       | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                   |
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby Current                                                                                 | 1          | -                    |      | ±15                  | μΑ       | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                 |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep<br>Power-down Current                                                                      | 1          |                      |      | 5.0                  | μΑ       | RP# = GND ±0.2V                                                                   |
| I <sub>PPR</sub>  | V <sub>PP</sub> Read Current                                                                                    | 1          |                      |      | 200                  | μΑ       | V <sub>PP</sub> > V <sub>CC</sub>                                                 |
| I <sub>PPW</sub>  | V <sub>PP</sub> Word Write Current                                                                              | 1, 4       |                      |      | 40                   | mA       | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress                      |
| I <sub>PPW</sub>  | V <sub>PP</sub> Byte Write Current                                                                              | 1, 4       |                      |      | 30                   | mΑ       | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress                      |
| I <sub>PPE</sub>  | V <sub>PP</sub> Block Erase Current                                                                             | 1, 4       |                      |      | 30                   | mΑ       | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress                     |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend Current                                                                           | 1          | ٨                    |      | 200                  | μΑ       | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended                       |
| I <sub>RP#</sub>  | RP# Boot Block<br>Unlock Current                                                                                | 1, 4       |                      |      | 500                  | μΑ       | RP# = V <sub>HH</sub>                                                             |
| l <sub>ID</sub>   | A <sub>9</sub> Intelligent Identifier Current                                                                   | 1, 4       |                      |      | 500                  | μΑ       | $A_9 = V_{ID}$                                                                    |
| V <sub>ID</sub>   | A <sub>9</sub> Intelligent Identifier Voltage                                                                   |            | 11.4                 | 12.0 | 13.0                 | ٧        |                                                                                   |
| V <sub>IL</sub>   | Input Low Voltage                                                                                               |            | -0.5                 |      | 0.6                  | ٧        |                                                                                   |
| V <sub>IH</sub>   | Input High Voltage                                                                                              |            | 2.0                  |      | V <sub>CC</sub> +0.5 | >        |                                                                                   |
| V <sub>OL</sub>   | Output Low Voltage                                                                                              |            |                      | s 2  | 0.4                  | ٧        | $V_{CC} = V_{CC} Min$ $I_{OL} = 2 mA$                                             |
| V <sub>OH1</sub>  | Output High Voltage (TTL)                                                                                       |            | 2.4                  |      |                      | >        | $V_{CC} = V_{CC} Min$ $I_{OH} = -2 mA$                                            |
| V <sub>OH2</sub>  | Output High Voltage<br>(CMOS)                                                                                   |            | 0.85 V <sub>CC</sub> |      |                      | <b>V</b> | $I_{OH} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$                       |
|                   |                                                                                                                 |            | V <sub>CC</sub> -0.4 |      |                      | :        | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                          |
| $V_{PPL}$         | V <sub>PP</sub> during Normal Operations                                                                        | 3          | 0.0                  |      | 4.1                  | V        |                                                                                   |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Erase/Write<br>Operations                                                                |            | 11.4                 | 12.0 | 12.6                 | ٧        |                                                                                   |
| $V_{LKO}$         | V <sub>CC</sub> Erase/Write Lock Voltage                                                                        |            | 2.0                  |      |                      | ٧        |                                                                                   |
| $V_{HH}$          | RP# Unlock Voltage                                                                                              |            | 11.4                 | 12.0 | 13.0                 | ٧        | Boot Block Write/Erase                                                            |



# CAPACITANCE(4) T<sub>A</sub> = 25°C, f = 1 MHz

| Symbol           | Parameter          | Тур | Max | Unit | Condition             |
|------------------|--------------------|-----|-----|------|-----------------------|
| C <sub>IN</sub>  | Input Capacitance  | 6   | 8   | рF   | $V_{IN} = 0V$         |
| C <sub>OUT</sub> | Output Capacitance | 10  | 12  | pF   | V <sub>OUT</sub> = 0V |

#### NOTES:

- 1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC}=3.3V$ ,  $V_{PP}=12.0V$ ,  $T=25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).
- 2. I<sub>CCES</sub> is specified with the device deselected. If the device is read while in Erase Suspend Mode, current draw is the sum of I<sub>CCES</sub> and I<sub>CCR</sub>.
- 3. Block Erases and Word/Byte Writes are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between  $V_{PPH}$  and  $V_{PPL}$ .
- 4. Sampled, not 100% tested.
- 5. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to less than 1 mA in static operation.
- 6. CMOS Inputs are either  $V_{CC} \pm 0.2V$  or GND  $\pm 0.2V$ . TTL Inputs are either  $V_{II}$  or  $V_{IH}$ .

#### DC CHARACTERISTICS $V_{CC} = 5.0V \pm 10\%$ (4)

| Symbol            | Parameter                                                                        | Notes | Win           | Тур | Max  | Unit | Test Condition                                                                      |
|-------------------|----------------------------------------------------------------------------------|-------|---------------|-----|------|------|-------------------------------------------------------------------------------------|
| ILI               | Input Load Current                                                               | 1     |               |     | ±1.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                   |
| I <sub>LO</sub>   | Output Leakage Current                                                           | 1     |               |     | ±10  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$                                  |
| Iccs              | V <sub>CC</sub> Standby Current                                                  |       |               |     | 1.5  | mA   | $V_{CC} = V_{CC} Max$ $CE \# = RP \# = V_{IH}$                                      |
| 1                 | ·                                                                                |       |               |     | 100  | μΑ   | $V_{CC} = V_{CC} Max$ $CE \# = RP \# = V_{CC} \pm 0.2V$                             |
| ICCD              | V <sub>CC</sub> Deep Power-down<br>Current                                       | 1     |               |     | 1.2  | μΑ   | RP# = GND ±0.2V                                                                     |
|                   | V <sub>CC</sub> Read Current for<br>28F200BL Word-Wide and<br>Byte-Wide Mode and | 1     |               |     | 40   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = GND$<br>$f = 5$ MHz, $I_{OUT} = 0$ mA<br>CMOS Inputs |
|                   | 28F002BL                                                                         |       | -<br> -<br> - |     | 40   | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$<br>f = 5 MHz, $I_{OUT} = 0$ mA<br>TTL Inputs |
| Iccw              | V <sub>CC</sub> Word-Byte Write Current                                          | 1, 4  |               |     | 70   | mA   | Word or Byte Write in Progress                                                      |
| ICCE              | V <sub>CC</sub> Block Erase Current                                              | 1, 4  |               |     | 30   | mA   | Block Erase in Progress                                                             |
| I <sub>CCES</sub> | V <sub>CC</sub> Erase Suspend Current                                            | 1, 2  |               |     | 10   | mA   | Block Erase Suspended,<br>CE# = V <sub>IH</sub>                                     |
| IPPS              | V <sub>PP</sub> Standby Current                                                  | 1     |               |     | ±15  | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                   |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep Power-down<br>Current                                       | 1     |               |     | 5.0  | μΑ   | RP# = GND ±0.2V                                                                     |



# **DC CHARACTERISTICS** $V_{CC} = 5.0V \pm 10\%$ (Continued)

| Symbol           | Parameter                                        | Notes | Min                  | Тур  | Max                  | Unit | Test Condition                                                |
|------------------|--------------------------------------------------|-------|----------------------|------|----------------------|------|---------------------------------------------------------------|
| I <sub>PPR</sub> | V <sub>PP</sub> Read Current                     | 1     |                      |      | 200                  | μΑ   | $V_{PP} > V_{CC}$                                             |
| I <sub>PPW</sub> | V <sub>PP</sub> Word Write Current               | 1, 4  |                      |      | 40                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Word Write in Progress  |
| IPPW             | V <sub>PP</sub> Byte Write Current               | 1, 4  | -                    |      | 30                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Byte Write in Progress  |
| IPPE             | V <sub>PP</sub> Block Erase Current              | 1, 4  |                      |      | 30                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase in Progress |
| IPPES            | V <sub>PP</sub> Erase Suspend Current            | 1     |                      |      | 200                  | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Block Erase Suspended   |
| I <sub>RP#</sub> | RP# Boot Block Unlock Current                    | 1, 4  |                      |      | 500                  | μΑ   | RP# = V <sub>HH</sub>                                         |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current    | 1, 4  |                      |      | 500                  | μΑ   | $A_9 = V_{ID}$                                                |
| $V_{ID}$         | A <sub>9</sub> Intelligent Identifier Voltage    |       | 11.4                 | 12.0 | 13.0                 | ٧    |                                                               |
| V <sub>IL</sub>  | Input Low Voltage                                |       | -0.5                 |      | 0.8                  | ٧.   |                                                               |
| V <sub>IH</sub>  | Input High Voltage                               |       | 2.0                  |      | V <sub>CC</sub> +0.5 | ٧    |                                                               |
| V <sub>OL</sub>  | Output Low Voltage                               |       |                      |      | 0.45                 | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                       |
| V <sub>OH1</sub> | Output High Voltage (TTL)                        |       | 2.4                  |      |                      | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = -2.5 mA$                      |
| V <sub>OH2</sub> | Output High Voltage<br>(CMOS)                    |       | 0.85 V <sub>CC</sub> |      |                      | ٧    | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$      |
|                  | ~                                                |       | V <sub>CC</sub> -0.4 |      |                      |      | $I_{OH} = -100 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$      |
| V <sub>PPL</sub> | V <sub>PP</sub> during Normal Operations         | 3     | 0.0                  |      | 6.5                  | ٧    |                                                               |
| V <sub>PPH</sub> | V <sub>PP</sub> during Erase/Write<br>Operations |       | 11.4                 | 12.0 | 12.6                 | ٧    |                                                               |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage         |       | 2.2                  |      |                      | ٧    |                                                               |
| V <sub>HH</sub>  | RP# Unlock Voltage                               |       | 11.4                 | 12.0 | 13.0                 | V    | Boot Block Write/Erase                                        |

<sup>1.</sup> All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).

<sup>2.</sup> ICCES is specified with the device deselected. If the device is read while in Erase Suspend Mode, current draw is the sum of  $I_{CCES}$  and  $I_{CCP}$ .

3. Block Erase/Byte Writes are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between  $V_{PPH}$  and  $V_{PPL}$ .

<sup>4.</sup> All parameters are sampled, not 100% tested.



#### AC INPUT/OUTPUT REFERENCE WAVEFORM



#### **AC TESTING LOAD CIRCUIT**



# AC CHARACTERISTICS—Read-Only Operations(1) $V_{CC} = 3.3V \pm 0.3V$ , 5.0V $\pm 10\%$ (3)

|                                        | Versions         |                                                                         |       |     | OBL-150<br>2BL-150 | Unit |
|----------------------------------------|------------------|-------------------------------------------------------------------------|-------|-----|--------------------|------|
| Sym                                    | bol              | Parameter                                                               | Notes | Min | Max                | }    |
| t <sub>AVAV</sub>                      | t <sub>RC</sub>  | Read Cycle Time                                                         |       | 150 |                    | ns   |
| t <sub>AVQV</sub>                      | t <sub>ACC</sub> | Address to Output Delay                                                 |       |     | 150                | ns   |
| t <sub>ELQV</sub>                      | t <sub>CE</sub>  | CE# to Output Delay                                                     | 2     |     | 150                | ns   |
| t <sub>PHQV</sub>                      | t <sub>PWH</sub> | RP# High to Output Delay                                                |       |     | 600                | ns   |
| tGLQV                                  | tOE              | OE# to Output Delay                                                     | 2     |     | 65                 | ns   |
| t <sub>ELQX</sub>                      | t <sub>LZ</sub>  | CE# to Output Low Z                                                     | 3     | 0   |                    | ns   |
| t <sub>EHQZ</sub>                      | t <sub>HZ</sub>  | CE# High to Output High Z                                               | 3     |     | 55                 | ns   |
| tGLQX                                  | toLZ             | OE# to Output Low Z                                                     | 3     | 0   |                    | ns   |
| tGHQZ                                  | t <sub>DF</sub>  | OE# High to Output High Z                                               | 3     |     | 45                 | ns   |
|                                        | toH              | Output Hold from Addresses,<br>CE# or OE# Change,<br>Whichever is First | 3     | 0   |                    | ns   |
| t <sub>ELFL</sub><br>t <sub>ELFH</sub> |                  | CE# to BYTE# Switching<br>Low to High                                   | 3     |     | 5                  | ns   |
| t <sub>FHQV</sub>                      |                  | BYTE# Switching High to Valid Output Delay                              | 3, 4  |     | 150                | ns   |
| <sup>t</sup> FLQZ                      |                  | BYTE# Switching Low to Output High Z                                    | 3     |     | 45                 | ns   |

#### NOTES

- 1. See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.
- 3. Sampled, not 100% tested.
- 4.  $t_{FLQV}$ , BYTE# switching low to valid output delay will be equal to  $t_{AVQV}$ , measured from the time  $DQ_{15}/A_{-1}$  becomes valid.









Figure 17. BYTE# Timing Diagram for Both Read and Write Operations for 28F200BL



#### AC CHARACTERISTICS For WE # Controlled Write Operations(1) V<sub>CC</sub> = 3.15V-3.6V, 5.0V ± 10%

|                    |                        | Versions <sup>(4)</sup>                        |         |     | BL-150<br>BL-150 | Unit |
|--------------------|------------------------|------------------------------------------------|---------|-----|------------------|------|
| Symi               | Symbol Parameter Notes |                                                |         |     | Max              | 1    |
| t <sub>AVAV</sub>  | twc                    | Write Cycle Time                               |         | 150 |                  | ns   |
| t <sub>PHWL</sub>  | tps                    | RP# High Recovery to WE# Going Low             |         | 1 ′ |                  | μs   |
| t <sub>ELWL</sub>  | tcs                    | CE# Setup to WE# Going Low                     |         | 0   |                  | ns   |
| t <sub>PHHWH</sub> | t <sub>PHS</sub>       | RP# V <sub>HH</sub> Setup to WE# Going High    | 6, 8    | 200 |                  | ns   |
| t <sub>VPWH</sub>  | t <sub>VPS</sub>       | V <sub>PP</sub> Setup to WE# Going High        | 5, 8    | 200 |                  | ns   |
| t <sub>AVWH</sub>  | t <sub>AS</sub>        | Address Setup to WE# Going High                | 3       | 95  |                  | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>        | Data Setup to WE# Going High                   | 4       | 100 |                  | ns   |
| twLWH              | t <sub>WP</sub>        | WE# Pulse Width                                |         | 100 |                  | ns   |
| t <sub>WHDX</sub>  | t <sub>DH</sub>        | Data Hold from WE# High                        | 4       | 0   |                  | ns   |
| twhax              | t <sub>AH</sub>        | Address Hold from WE# High                     | 3       | 10  |                  | ns   |
| twhEH              | t <sub>CH</sub>        | CE# Hold from WE# High                         |         | 10  |                  | ns   |
| twHWL              | t <sub>WPH</sub>       | WE# Pulse Width High                           |         | 50  |                  | ns   |
| twHQV1             |                        | Duration of Programming Operation (Boot)       | 2, 5, 6 | 6   |                  | μs   |
| t <sub>WHQV2</sub> |                        | Duration of Word/Byte<br>Programming Operation | 2, 5, 6 | 0.3 |                  | s    |
| twHQV3             |                        | Duration of Erase Operation<br>(Parameter)     | 2, 5, 6 | 0.3 | _                | S    |
| t <sub>WHQV4</sub> |                        | Duration of Erase Operation (Main)             | 2, 5, 6 | 0.6 |                  | s    |
| t <sub>QWL</sub>   | t <sub>VPH</sub>       | V <sub>PP</sub> Hold from Valid SRD            | 5, 8    | 0   |                  | ns   |
| <sup>t</sup> QVPH  | t <sub>PHH</sub>       | RP# V <sub>HH</sub> Hold from Valid SRD        | 6, 8    | 0   |                  | ns   |
| t <sub>PHBR</sub>  |                        | Boot-Block Relock Delay                        | 7, 8    |     | 200              | ns   |

#### **NOTES:**

- 1. Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during Read Mode.
- 2. The on-chip WSM completely automates program/erase operations; program/erase algorithms are now controlled internally which includes verify and margining operations.
- 3. Refer to command definition table for valid AIN.
- 4. Refer to command definition table for valid D<sub>IN</sub>.
- 5. Program/Erase durations are measured to valid SRD data (successful operation, SR.7=1).
- 6. For Boot Block Program/Erase, RP# should be held at VHH until operation completes successfully.
- 7. Time t<sub>PHBR</sub> is required for successful relocking of the Boot Block.
- 8. Sampled but not 100% tested.





# BLOCK ERASE AND BYTE/WORD WRITE PERFORMANCE $V_{CC}=3.15V-3.6V,\,5.0V\,\pm10\%$

| Parameter                       | Notes |     | Unit   |      |   |
|---------------------------------|-------|-----|--------|------|---|
|                                 |       | Min | Typ(1) | Max  |   |
| Boot/Parameter Block Erase Time | 2     |     | 2.0    | 8.6  | s |
| Main Block Erase Time           | 2     |     | 3.4    | 17.0 | s |
| Main Block Byte Program Time    | 2     |     | 1.4    | 5.3  | s |
| Main Block Word Program Time    | 2     |     | 0.7    | 2.7  | s |

#### NOTES:

- 1. 25°C, 12.0V Vpp. 2. Excludes System-Level Overhead.







# AC CHARACTERISTICS FOR CE#-CONTROLLED WRITE OPERATIONS

 $V_{CC} = 3.15V - 3.6V, 5.0V \pm 10\%$ 

|                    |                  | Versions                                              |         |     | BL-150<br>BL-150 | Unit |
|--------------------|------------------|-------------------------------------------------------|---------|-----|------------------|------|
| Syml               | ool              | Parameter                                             | Notes   | Min | Max              |      |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                                      |         | 150 |                  | ns   |
| t <sub>PHEL</sub>  | tips             | RP# High Recovery to CE# Going Low                    |         | 1   |                  | μs   |
| t <sub>WLEL</sub>  | tws              | WE# Setup to CE# Going Low                            |         | 0   |                  | ns   |
| t <sub>PHHEH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to CE# Going High           | 6, 8    | 200 |                  | ns   |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE# Going High               | 5, 8    | 200 |                  | ns   |
| t <sub>AVEH</sub>  | t <sub>AS</sub>  | Address Setup to CE# Going High                       | 3       | 95  |                  | ns   |
| tDVEH              | t <sub>DS</sub>  | Data Setup to CE# Going High                          | 4       | 100 |                  | ns   |
| tELEH              | t <sub>CP</sub>  | CE# Pulse Width                                       |         | 100 |                  | ns   |
| tEHDX              | t <sub>DH</sub>  | Data Hold from CE# High                               | 4       | 0   |                  | ns   |
| tEHAX              | t <sub>AH</sub>  | Address Hold from CE# High                            | 3       | 10  |                  | ns   |
| tEHWH              | twH              | WE# Hold from CE# High                                |         | 10  |                  | ns   |
| tEHEL              | t <sub>CPH</sub> | CE# Pulse Width High                                  |         | 50  |                  | ns   |
| t <sub>EHQV1</sub> |                  | Duration of Word/Byte Programming<br>Operation (Boot) | 2, 5, 6 | 6   | ·                | μs   |
| t <sub>EHQV2</sub> |                  | Duration of Erase Operation (Boot)                    | 2, 5, 6 | 0.3 |                  | s    |
| t <sub>EHQV3</sub> |                  | Duration of Erase Operation (Parameter)               | 2, 5, 6 | 0.3 |                  | s    |
| t <sub>EHQV4</sub> |                  | Duration of Erase Operation (Main)                    | 2, 5, 6 | 0.6 |                  | s    |
| tawl               | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD                   | 5, 8    | 0   |                  | ns   |
| tQVPH              | t <sub>PPH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD               | 6, 8    | 0   |                  | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                               | 7       |     | 200              | ns   |

#### NOTES

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE# in systems where CE# defines the write pulse-width (within a longer WE# timing waveform), all set-up, hold and inactive WE# time should be measured relative to the CE# waveforms.

<sup>2, 3, 4, 5, 6, 7, 8:</sup> Refer to AC characteristics for WE#-controlled write operations.

Read timing characteristics during write and erase operations are the same as during read-only operations. Refer to AC characteristics during read mode.





# **ORDERING INFORMATION**





| Order<br>Number | Document                                                                          |
|-----------------|-----------------------------------------------------------------------------------|
| 292130          | AB-57 "Boot Block Architecture for Safe Firmware Updates"                         |
| 292154          | AB-60 "2/4/8- Mbit SmartVoltage Boot Block Flash Memory Family"                   |
| 292098          | AP-363 "Extended Flash BIOS Concepts for Portable Computers"                      |
| 292148          | AP-604 "Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM" |
| 290448          | 28F002/200BX-T/B 2-Mbit Boot Block Flash Memory Datasheet                         |
| 290450          | 28F004/400BL-T/B 4-Mbit Low Power Boot Block Flash Memory Datasheet               |
| 290451          | 28F004/400BX-T/B 4-Mbit Boot Block Flash Memory Datasheet                         |
| 290531          | 2-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290530          | 4-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |
| 290539          | 8-Mbit SmartVoltage Boot Block Flash Memory Family Datasheet                      |



# **REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -001   | Original Version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -002   | Modified BYTE# AC Timings  Modified t <sub>DVWH</sub> parameter for AC Characteristics for Write Operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -003   | PWD renamed to RP# for JEDEC standardization compatibility.  Combined V <sub>CC</sub> Read Current for 28F200BX-L Word-Wide and Byte-Wide Mode and 28F002BX-L Byte-Wide Mode in DC Characteristics tables.  Changed I <sub>PPS</sub> current spec from ±10 µA to ±15 µA in DC Characteristics table.  Added Boot Block Unlock current spec in DC Characteristics tables.  Improved t <sub>PWH</sub> spec to 600 ns (was 700 ns)  Changed I <sub>CCR</sub> current spec from 20 mA maximum to 25 mA maximum and added typical spec to DC Characteristics table.                                                        |
| -004   | Added I <sub>OH</sub> CMOS Specification.  Expanded temperature operating range, from 0°C-70°C to -20°-+70°C.  Product naming changed:  28F200BX-TL/BL changed to 28F200BL-T/B  28F002BX-TL/BL changed to 28F002BL-T/B  Typographical errors corrected.  Added 28F400BX interface to Intel386™ EX Embedded Processor Block Diagram.  Added upgrade considerations for SmartVoltage Boot Block products.  Previously specified V <sub>CC</sub> tolerance of 3.0V to 3.6V for Read, Program and Erase has been changed to 3.15V to 3.6V for Program and Erase operation, while the Read operation remains 3.0V to 3.6V. |



# 28F001BX-T/28F001BX-B 1M (128K x 8) CMOS FLASH MEMORY

- High Integration Blocked Architecture
  - -One 8 KB Boot Block w/Lock Out
  - Two 4 KB Parameter Blocks
  - One 112 KB Main Block
- 100,000 Erase/Program Cycles Per Block
- Simplified Program and Erase
  - Automated Algorithms via On-Chip Write State Machine (WSM)
- **SRAM-Compatible Write Interface**
- Deep-Powerdown Mode
  - 0.05  $\mu$ A I<sub>CC</sub> Typical
  - 0.8 μA Ipp Typical
- 12.0V ±5% Vpp

- **■** High-Performance Read
  - —70/75 ns, 90 ns, 120 ns, 150 ns Maximum Access Time
  - -5.0V ± 10% V<sub>CC</sub>
- Hardware Data Protection Feature
  - Erase/Write Lockout during Power Transitions
- Advanced Packaging, JEDEC Pinouts
  - 32-Pin PDIP
  - 32-Lead PLCC, TSOP
- **ETOX II Nonvolatile Flash Technology** 
  - EPROM-Compatible Process Base
  - High-Volume Manufacturing Experience
- **■** Extended Temperature Options

Intel's 28F001BX-B and 28F001BX-T combine the cost-effectiveness of Intel standard flash memory with features that simplify write and allow block erase. These devices aid the system designer by combining the functions of several components into one, making boot block flash an innovative alternative to EPROM and EEPROM or battery-backed static RAM. Many new and existing designs can take advantage of the 28F001BX's integration of blocked architecture, automated electrical reprogramming, and standard processor interface.

The 28F001BX-B and 28F001BX-T are 1,048,576 bit nonvolatile memories organized as 131,072 bytes of 8 bits. They are offered in 32-pin plastic DIP, 32-lead PLCC and 32-lead TSOP packages. Pin assignment conform to JEDEC standards for byte-wide EPROMs. These devices use an integrated command port and state machine for simplified block erasure and byte reprogramming. The 28F001BX-T's block locations provide compatibility with microprocessors and microcontrollers that boot from high memory, such as Intel's MCS-186 family, 80286, i386™, i486™, i860™ and 80960CA. With exactly the same memory segmentation, the 28F001BX-B memory map is tailored for microprocessors and microcontrollers that boot from low memory, such as Intel's MCS-51, MCS-196, 80960KX and 80960SX families. All other features are identical, and unless otherwise noted, the term 28F001BX can refer to either device throughout the remainder of this document.

The boot block section includes a reprogramming write lock out feature to guarantee data integrity. It is designed to contain secure code which will bring up the system minimally and download code to the other locations of the 28F001BX. Intel's 28F001BX employs advanced CMOS circuitry for systems requiring high-performance access speeds, low power consumption, and immunity to noise. Its access time provides no-WAIT-state performance for a wide range of microprocessors and microcontrollers. A deep-powerdown mode lowers power consumption to 0.25  $\mu W$  typical through  $V_{CC}$ , crucial in laptop computer, handheld instrumentation and other low-power applications. The RP# power control input also provides absolute data protection during system powerup or power loss.

Manufactured on Intel's ETOX process base, the 28F001BX builds on years of EPROM experience to yield the highest levels of quality, reliability, and cost-effectiveness.





Figure 1. 28F001BX Block Diagram

**Table 1. Pin Description** 

| Symbol                           | Туре             | Name and Function                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>16</sub>  | INPUT            | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                                                                                                                 |
| DQ <sub>0</sub> -DQ <sub>7</sub> | INPUT/<br>OUTPUT | DATA INPUTS/OUTPUTS: Inputs data and commands during memory write cycles; outputs data during memory, Status Register and Identifier read cycles. The data pins are active high and float to tri-state off when the chip is deselected or the outputs are disabled. Data is internally latched during a write cycle.                                                                        |
| CE#                              | INPUT            | CHIP ENABLE: Activates the device's control logic, input buffers, decoders and sense amplifiers. CE# is active low; CE# high deselects the memory device and reduces power consumption to standby levels.                                                                                                                                                                                   |
| RP#                              | INPUT            | <b>POWERDOWN:</b> Puts the device in deep powerdown mode. RP# is active low; RP# high gates normal operation. RP# = V <sub>HH</sub> allows programming of the boot block. RP# also locks out erase or write operations when active low, providing data protection during power transitions. RP# active resets internal automation. Exit from deep powerdown sets device to Read Array mode. |
| OE#                              | INPUT            | <b>OUTPUT ENABLE:</b> Gates the device's outputs through the data buffers during a read cycle. OE# is active low. OE# = V <sub>HH</sub> (pulsed) allows programming of the boot block.                                                                                                                                                                                                      |
| WE#                              | INPUT            | <b>WRITE ENABLE:</b> Controls writes to the Command Register and array blocks. WE# is active low. Addresses and data are latched on the rising edge of the WE# pulse.                                                                                                                                                                                                                       |
| V <sub>PP</sub>                  | ,                | <b>ERASE/PROGRAM POWER SUPPLY</b> for erasing blocks of the array or programming bytes of each block. Note: With V <sub>PP</sub> < V <sub>PPL</sub> max, memory contents cannot be altered.                                                                                                                                                                                                 |
| V <sub>CC</sub>                  |                  | DEVICE POWER SUPPLY: (5V ±10%)                                                                                                                                                                                                                                                                                                                                                              |
| GND                              |                  | GROUND                                                                                                                                                                                                                                                                                                                                                                                      |





Figure 2. DIP Pin Configuration



Figure 3. TSOP Lead Configuration





Figure 4. PLCC Lead Configuration

#### **APPLICATIONS**

The 28F001BX flash 'boot block' memory augments the non-volatility, in-system electrical erasure and reprogrammability of Intel's standard flash memory by offering four separately erasable blocks and integrating a state machine to control erase and program functions. The specialized blocking architecture and automated programming of the 28F001BX provide a full-function, non-volatile flash memory ideal for a wide range of applications, including PC boot/BIOS memory, minimum-chip embedded program memory and parametric data storage. The 28F001BX combines the safety of a hardware-protected 8-KByte boot block with the flexibility of three separately reprogrammable blocks (two 4-KByte parameter blocks and one 112-KByte code block) into one versatile, cost-effective flash memory. Additionally, reprogramming one block does not affect code stored in another block, ensuring data integrity.

The flexibility of flash memory reduces costs throughout the life cycle of a design. During the early stages of a system's life, flash memory reduces prototype development and testing time, allowing the system designer to modify in-system software electrically versus manual removal of components. During production, flash memory provides flexible firmware for just-in-time configuration, reducing system inventory and eliminating unnecessary handling and less reliable socketed connections. Late in the life cycle, when software updates or code "bugs" are often unpredictable and costly, flash memory reduces update costs by allowing the manufacturers to send floppy updates versus a technician. Alternatively, remote updates over a communication link are possible at speeds up to 9600 baud due to flash memory's fast programming time.



Reprogrammable environments, such as the personal computer, are ideal applications for the 28F001BX. The internal state machine provides SRAM-like timings for program and erasure, using the Command and Status Registers. The blocking scheme allows BIOS update in the main and parameter blocks, while still providing recovery code in the boot block in the unlikely event a power failure occurs during an update, or where BIOS code is corrupted. Parameter blocks also provide convenient configuration storage, backing up SRAM and battery configurations. EISA systems, for example, can store hardware configurations in a flash parameter block, reducing system SRAM.

Laptop BIOSs are becoming increasingly complex with the addition of power management software and extended system setup screens. BIOS code complexity increases the potential for code updates after the sale, but the compactness of laptop designs makes hardware updates very costly. Boot block flash memory provides an inexpensive update solution for laptops, while reducing laptop obsolescence. For portable PCs and hand-held equipment, the deep powerdown mode dramatically lowers sys-

 $V_{CC}$ 800188 SYSTEM BUS A0 - A7, A16 28F001BX-T  $DQ_0 - DQ_7$  $AD_0 - AD_7$ RP# SYSTEM RESET# WE# WP# 0E# RD# CE# HCS# A<sub>8</sub> - A<sub>15</sub> A<sub>8</sub> - A<sub>15</sub> V<sub>CC</sub>  $v_{cc}$ 2 Kx8 - A<sub>10</sub> Ag SRAM MCS# CS# WE# RD# 0E#  $AD_0 - AD_7$  $D_0 - D_7$ 290406-5

Figure 5. 28F001BX-T in a 80C188 System

tem power requirements during periods of slow operation or sleep modes.

The 28F001BX gives the embedded system designer several desired features. The internal state machine reduces the size of external code dedicated to the erase and program algorithms, as well as freeing the microcontroller or microprocessor to respond to other system requests during program and erasure. The four blocks allow logical segmentation of the entire embedded software: the 8-KByte block for the boot code, the 112-KByte block for the main program code and the two 4-KByte blocks for updatable parametric data storage, diagnostic messages and data, or extensions of either the boot code or program code. The boot block is hardware protected against unauthorized write or erase of its vital code in the field. Further, the powerdown mode also locks out erase or write operations, providing absolute data protection during system powerup or power loss. This hardware protection provides obvious advantages for safety related applications such as transportation, military, and medical. The 28F001BX is well suited for minimum-chip embedded applications ranging from communications to automotive.



Figure 6. 28F001BX-B in a 80C51 System





#### PRINCIPLES OF OPERATION

The 28F001BX introduces on-chip write automation to manage write and erase functions. The write state machine allows for: 100% TTL-level control inputs; fixed power supplies during erasure and programming; minimal processor overhead with RAM-like write timings, and maximum EPROM compatiblity.

After initial device powerup, or after return from deep powerdown mode (see Bus Operations), the 28F001BX functions as a read-only memory. Manipulation of external memory-control pins yield standard EPROM read, standby, output disable or Intelligent Identifier operations. Both Status Register and Intelligent Identifiers can be accessed through the Command Register when  $V_{PP} = V_{PPL}$ .

This same subset of operations is also available when high voltage is applied to the  $V_{PP}$  pin. In addition, high voltage on  $V_{PP}$  enables successful erasure and programming of the device. All functions associated with altering memory contents—program, erase, status, and inteligent Identifier—are accessed via the Command Register and verified through the Status Register.

Commands are written using standard microprocessor write timings. Register contents serve as input to the WSM, which controls the erase and programming circuitry. Write cycles also internally latch addresses and data needed for programming or erase operations. With the appropriate command written to the register, standard microprocessor read timings output array data, access the intelligent identifier codes, or output program and erase status for verification.

Interface software to initiate and poll progress of internal program and erase can be stored in any of the 28F001BX blocks. This code is copied to, and executed from, system RAM during actual flash memory update. After successful completion of program and/or erase, code execution out of the 28F001BX is again possible via the Read Array command. Erase suspend/resume capability allows system software to suspend block erase and read data/execute code from any other block.

# Command Register and Write Automation

An on-chip state machine controls block erase and byte program, freeing the system processor for other tasks. After receiving the erase setup and erase confirm commands, the state machine controls block pre-conditioning and erase, returning progress via the Status Register. Programming is similarly controlled, after destination address and expected data are supplied. The program algorithm of past Intel Flash Memories is now regulated by the state machine, including program pulse repetition where required and internal verification and margining of data.

#### **Data Protection**

Depending on the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable (available only when memory updates are required) or hardwired to V<sub>PPH</sub>. When V<sub>PP</sub> = V<sub>PPL</sub>, memory contents cannot be altered. The 28F001BX Command Register architecture provides protection from unwanted program or erase operations even when high voltage is applied to V<sub>PP</sub>. Additionally, all functions are disabled whenever V<sub>CC</sub> is below the write lockout voltage V<sub>LKO</sub>, or when RP# is at V<sub>IL</sub>. The 28F001BX accommodates either design practice and encourages optimization of the processormemory interface.

The two-step program/erase write sequence to the Command Register provides additional software write protection.



Figure 7. 28F001BX-T Memory Map



Figure 8. 28F001BX-B Memory Map



#### **BUS OPERATION**

Flash memory reads, erases and writes in-system via the local CPU. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles.

#### Read

The 28F001BX has three read modes. The memory can be read from any of its blocks, and information can be read from the Intelligent Identifier or the Status Register. Vpp can be at either VppL or VppH.

The first task is to write the appropriate read mode command to the Command Register (array, Intelligent Identifier, or Status Register). The 28F001BX automatically resets to Read Array mode upon initial device powerup or after exit from deep powerdown. The 28F001BX has four control pins, two of which must be logically active to obtain data at the outputs. Chip Enable (CE#) is the device selection control, and when active enables the selected memory device. Output Enable (OE#) is the data input/output (DQ0-DQ7) direction control, and when active drives data from the selected memory onto the I/O bus. RP# and WE# must also be at V<sub>IH</sub>. Figure 12 illustrates read bus cycle waveforms.

# **Output Disable**

With OE# at a logic-high level ( $V_{IH}$ ), the device outputs are disabled. Output pins ( $DQ_0-DQ_7$ ) are placed in a high-impedance state.

### Standby

CE# at a logic-high level ( $V_{IH}$ ) places the 28F001BX in standby mode. Standby operation disables much of the 28F001BX's circuitry and substantially reduces device power consumption. The outputs (DQ0-DQ7) are placed in a high-impedance state independent of the status of OE#. If the 28F001BX is deselected during erase or program, the device will continue functioning and consuming normal active power until the operation is completed.

#### **Deep Power-Down**

The 28F001BX offers a 0.25  $\mu$ W V<sub>CC</sub> power-down feature, entered when RP# is at V<sub>IL</sub>. During read modes, RP# low deselects the memory, places output drivers in a high-impedance state and turns off all internal circuits. The 28F001BX requires time tp<sub>HQV</sub> (see AC Characteristics-Read Only Operations) after return from power-down until initial memory access outputs are valid. After this wakeup interval, normal operation is restored. The Command Register is reset to Read Array, and the Status Register is cleared to value 80H, upon return to normal operation.

During erase or program modes, RP# low will abort either operation. Memory contents of the block being altered are no longer valid as the data will be partially programmed or erased. Time  $t_{PHWL}$  after RP# goes to logic-high ( $V_{IH}$ ) is required before another command can be written.

| Table | 2 | 28F00 | 1RY | Rus | Operations |
|-------|---|-------|-----|-----|------------|
|       |   |       |     |     |            |

| . abio 21 201 of 15% bao operations |         |                 |                 |                 |                 |                 |                 |                 |                   |
|-------------------------------------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|
| Mode                                | Notes   | RP#             | CE#             | OE#             | WE#             | A <sub>9</sub>  | A <sub>0</sub>  | V <sub>PP</sub> | DQ <sub>0-7</sub> |
| Read                                | 1, 2, 3 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х               | Х               | Х               | D <sub>OUT</sub>  |
| Output Disable                      |         | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Х               | Х               | Х               | High Z            |
| Standby                             |         | V <sub>IH</sub> | V <sub>IH</sub> | Х               | X               | Х               | Х               | Х               | High Z            |
| Deep Power Down                     |         | V <sub>IL</sub> | Х               | Х               | Х               | Х               | Х               | Х               | High Z            |
| Intelligent Identifier (Mfr)        | 4       | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IL</sub> | Х               | 89H               |
| Intelligent Identifier (Device)     | 4, 5    | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>ID</sub> | V <sub>IH</sub> | Х               | 94H, 95H          |
| Write                               | 6, 7, 8 | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х               | Х               | Х               | D <sub>IN</sub>   |

#### NOTES:

- 1. Refer to DC Characteristics. When Vpp = VppL, memory contents can be read but not programmed or erased.
- 2. X can be VIL or VIH for control pins and addresses, and VPPL or VPPH for VPP.
- 3. See DC Characteristics for VPPL, VPPH, VHH and VID voltages.
- 4. Manufacturer and device codes may also be accessed via a Command Register write sequence. Refer to Table 3.  $A_1 A_8$ ,  $A_{10} A_{16} = V_{IL}$ .
- 5. Device ID = 94H for the 28F001BX-T and 95H for the 28F001BX-B.
- 6. Command writes involving block erase or byte program are successfully executed only when V<sub>PP</sub> = V<sub>PPH</sub>.
- Refer to Table 3 for valid D<sub>IN</sub> during a write operation.
- 8. Program or erase the boot block by holding RP# at V<sub>HH</sub> or toggling OE# to V<sub>HH</sub>. See AC Waveforms for program/erase operations.



The use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset it expects to read from the flash memory. Automated flash memories provide status information when accessed during write/erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input. In this application RP# is controlled by the same RESET# signal that resets the system CPU.

# **Intelligent Identifier Operation**

The Intelligent Identifier operation outputs the manufacturer code, 89H; and the device code, 94H for the 28F001BX-T and 95H for the 28F001BX-B. Programming equipment or the system CPU can then automatically match the device with its proper erase and programming algorithms.

#### PROGRAMMING EQUIPMENT

CE# and OE# at a logic low level ( $V_{IL}$ ), with  $A_9$  at high voltage  $V_{ID}$  (see DC Characteristics) activates this operation. Data read from locations 00000H and 00001H represent the manufacturer's code and the device code respectively.

#### **IN-SYSTEM PROGRAMMING**

The manufacturer- and device-codes can also be read via the Command Register. Following a write of 90H to the Command Register, a read from address location 00000H outputs the manufacturer code (89H). A read from address 00001H outputs the device code (94H for the 28F001BX-T and 95H for the 28F001BX-B). It is not necessary to have high voltage applied to  $V_{\rm PP}$  to read the Intelligent Identifiers from the Command Register.

#### Write

Writes to the Command Register allow read of device data and Intelligent Identifiers. They also control inspection and clearing of the Status Register. Additionally, when V<sub>PP</sub> = V<sub>PPH</sub>, the Command Register controls device erasure and programming. The contents of the register serve as input to the internal state machine.

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

Setup and Erase Confirm commands require both appropriate command data and an address within the block to be erased. The Program Setup Command requires both appropriate command data and the address of the location to be programmed, while the Program command consists of the data to be written and the address of the location to be programmed.

The Command Register is written by bringing WE# to a logic-low level ( $V_{IL}$ ) while CE# is low. Addresses and data are latched on the rising edge of WE#. Standard microprocessor write timings are used.

Refer to AC Write Characteristics and the AC Waveform for Write Operations, Figure 13, for specific timing parameters.

### **COMMAND DEFINITIONS**

When  $V_{PPL}$  is applied to the  $V_{PP}$  pin, read operations from the Status Register, intelligent identifiers, or array blocks are enabled. Placing  $V_{PPH}$  on  $V_{PP}$  enables successful program and erase operations as well.

Device operations are selected by writing specific commands into the Command Register. Table 3 defines these 28F001BX commands.

# **Read Array Command**

Upon initial device powerup and after exit from deep-powerdown mode, the 28F001BX defaults to Read Array mode. This operation is also initiated by writing FFH into the Command Register. Microprocessor read cycles retrieve array data. The device remains enabled for reads until the Command Register contents are altered. Once the internal write state machine has started an erase or program operation, the device will not recognize the Read Array command, until the WSM has completed its operation. The Read Array command is functional when  $V_{PP} = V_{PPL}$  or  $V_{PPH}$ .

# Intelligent Identifier Command for In-System Programming

The 28F001BX contains an Intelligent Identifier operation to supplement traditional PROM-programming methodology. The operation is initiated by writing 90H into the Command Register. Following the command write, a read cycle from address 00000H retrieves the manufacturer code of 89H. A read cycle from address 00001H returns the device code of 94H (28F001BX-T) or 95H (28F001BX-B). To terminate the operation, it is necessary to write another valid command into the register. Like the Read Array command, the Intelligent Identifier command is functional when V<sub>PP</sub> = V<sub>PP</sub> or V<sub>PPH</sub>.



Table 3, 28F001BX Command Definitions

| Command                    | Bus<br>Cycles | Notes   | First     | Bus Cycle |      | Second Bus Cycle |         |      |  |
|----------------------------|---------------|---------|-----------|-----------|------|------------------|---------|------|--|
|                            | Req'd         |         | Operation | Address   | Data | Operation        | Address | Data |  |
| Read Array/Reset           | 1             | 1       | Write     | Х         | FFH  |                  |         |      |  |
| Intelligent Identifier     | 3             | 2, 3, 4 | Write     | Х         | 90H  | Read             | IA      | IID  |  |
| Read Status Register       | 2             | 3       | Write     | Х         | 70H  | Read             | Х       | SRD  |  |
| Clear Status Register      | 1             |         | Write     | Х         | 50H  |                  |         |      |  |
| Erase Setup/Erase Confirm  | 2             | 2       | Write     | ВА        | 20H  | Write            | ВА      | D0H  |  |
| Erase Suspend/Erase Resume | 2             |         | Write     | Х         | вон  | Write            | Х       | D0H  |  |
| Program Setup/Program      | 2             | 2, 3    | Write     | PA        | 40H  | Write            | PA      | PD   |  |

#### NOTES:

- 1. Bus operations are defined in Table 2.
- 2. IA = Identifier Address: 00H for manufacturer code, 01H for device code.
  - BA = Address within the block being erased.
  - PA = Address of memory location to be programmed.
- 3. SRD = Data read from Status Register. See Table 4 for a description of the Status Register bits.
  - PD = Data to be programmed at location PA. Data is latched on the rising edge of WE#.
  - IID = Data read from Intelligent Identifiers.
- 4. Following the Intelligent Identifier command, two read operations access manufacture and device codes.
- 5. Commands other than those shown above are reserved by Intel for future device implementations and should not be used.

### **Read Status Register Command**

The 28F001BX contains a Status Register which may be read to determine when a program or erase operation is complete, and whether that operation completed successfully. The Status Register may be read at any time by writing the Read Status Register command (70H) to the Command Register. After writing this command, all subsequent read operations output data from the Status Register, until another valid command is written to the Command Register. The contents of the Status Register are latched on the falling edge of OE# or CE#, whichever occurs last in the read cycle. OE# or CE# must be toggled to VIH before further reads to update the Status Register latch. The Read Status Register command functions when  $V_{PP} = V_{PPI}$  or  $V_{PPH}$ .

# Clear Status Register Command

The Erase Status and Program Status bits are set to "1" by the Write State Machine and can only be

reset by the Clear Status Register command. These bits indicate various failure conditions (see Table 4). By allowing system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several bytes or erasing multiple blocks in sequence). The Status Register may then be polled to determine if an error occurred during that series. This adds flexibility to the way the device may be used.

Additionally, the V<sub>PP</sub> Status bit (SR.3), when set to "1", MUST be reset by system software before further byte programs or block erases are attempted. To clear the Status Register, the Clear Status Register command (50H) is written to the Command Register. The Clear Status Register command is functional when V<sub>PP</sub> = V<sub>PPI</sub> or V<sub>PPI</sub>.



**Table 4. 28F001BX Status Register Definitions** 

| WSMS | ESS | ES | PS | VPPS | R | R | R |
|------|-----|----|----|------|---|---|---|
| 7    | 6   | 5  | 4  | 3    | 2 | 1 | 0 |

SR.7 = WRITE STATE MACHINE STATUS

1 = Ready

0 = Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase In Progress/Completed

SR.5 = ERASE STATUS

1 = Error in Block Erasure

0 = Successful Block Erase

SR.4 = PROGRAM STATUS

1 = Error in Byte Program

0 = Successful Byte Program

SR.3 = V<sub>PP</sub> STATUS

1 = V<sub>PP</sub> Low Detect; Operation Abort

 $0 = V_{PP} OK$ 

SR.2-SR.0 = RESERVED FOR FUTURE ENHANCE-MENTS

These bits are reserved for future use and should be masked out when polling the Status Register.

#### NOTES:

The Write State Machine Status Bit must first be checked to determine program or erase completion, before the Program or Erase Status bits are checked for success.

If the Program AND Erase Status bits are set to "1s" during an erase attempt, an improper command sequence was entered. Attempt the operation again.

If  $V_{PP}$  low status is detected, the Status Register must be cleared before another program or erase operation is attempted.

The  $V_{PP}$  Status bit, unlike an A/D converter, does not provide continuous indication of  $V_{PP}$  level. The WSM interrogates the  $V_{PP}$  level only after the program or erase command sequences have been entered and informs the system if  $V_{PP}$  has not been switched on. The  $V_{PP}$  Status bit is not guaranteed to report accurate feedback between  $V_{PPL}$  and  $V_{PPH}$ .

# Erase Setup/Erase Confirm Commands

Erase is executed one block at a time, initiated by a two-cycle command sequence. An Erase Setup command (20H) is first written to the Command Register, followed by the Erase Confirm command (D0H). These commands require both appropriate command data and an address within the block to be erased. Block preconditioning, erase and verify are all handled internally by the Write State Machine, invisible to the system. After receiving the two-command erase sequence, the 28F001BX automatically outputs Status Register data when read (see Figure 10; Block Erase Flowchart). The CPU can detect the completion of the erase event by checking the WSM Status bit of the Status Register (SR.7).

When the Status Register indicates that erase is complete, the Erase Status bit should be checked. If erase error is detected, the Status Register should be cleared. The Command Register remains in Read Status Register Mode until further commands are issued to it.

This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, block erasure can only occur when  $V_{PP} = V_{PPH}$ . In the absence of this high voltage, memory contents are protected against erasure. If block erase is attempted while  $V_{PP} = V_{PPL}$ ,

the  $V_{PP}$  Status bit will be set to "1". Erase attempts while  $V_{PPL} < V_{PP} < V_{PPH}$  produce spurious results and should not be attempted.

# Erase Suspend/Erase Resume Commands

The Erase Suspend Command allows erase sequence interruption in order to read data from another block of memory. Once the erase sequence is started, writing the Erase Suspend command (B0H) to the Command Register requests that the WSM suspend the erase sequence at a predetermined point in the erase algorithm. The 28F001BX continues to output Status Register data when read, after the Erase Suspend command is written to it. Polling the WSM Status and Erase Suspend Status bits will determine when the erase operation has been suspended (both will be set to "1s").

At this point, a Read Array command can be written to the Command Register to read data from blocks other than that which is suspended. The only other valid commands at this time are Read Status Register (70H) and Erase Resume (D0H), at which time the WSM will continue with the erase sequence. The Erase Suspend Status and WSM Status bits of the Status Register will be cleared. After the Erase Resume command is written to it, the 28F001BX automatically outputs Status Register data when read (see Figure 11; Erase Suspend/Resume Flowchart).



# **Program Setup/Program Commands**

Programming is executed by a two-write sequence. The program Setup command (40H) is written to the Command Register, followed by a second write specifying the address and data (latched on the rising edge of WE#) to be programmed. The WSM then takes over, controlling the program and verify algorithms internally. After the two-command program sequence is written to it, the 28F001BX automatically outputs Status Register data when read (see figure 9; Byte Program Flowchart). The CPU can detect the completion of the program event by analyzing the WSM Status bit of the Status Register. Only the Read Status Register command is valid while programming is active.

When the Status Register indicates that programming is complete, the Program Status bit should be checked. If program error is detected, the Status Register should be cleared. The internal WSM verify only detects errors for "1s" that do not successfully program to "0s". The Command Register remains in Read Status Register mode until further commands are issued to it. If byte program is attempted while VpP = VpPL, the VpP Status bit will be set to "1". Program attempts while VpPL < VpP < VpPH produce spurious results and should not be attempted.

# EXTENDED ERASE/PROGRAM CYCLING

EEPROM cycling failures have always concerned users. The high electrical field required by thin oxide EEPROMs for tunneling can literally tear apart the oxide at defect regions. To combat this, some suppliers have implemented redundancy schemes, reducing cycling failures to insignificant levels. However, redundancy requires that cell size be doubled; an expensive solution.

Intel has designed extended cycling capability into its ETOX flash memory technology. Resulting improvements in cycling reliability come without increasing memory cell size or complexity. First, an advanced tunnel oxide increases the charge carrying ability ten-fold. Second, the oxide area per cell subjected to the tunneling electrical field is one-tenth that of common EEPROMs, minimizing the probability of oxide defects in the region. Finally, the peak electric field during erasure is approximately 2 Mv/cm lower than EEPROM. The lower electric field greatly reduces oxide stress and the probability of failure; increasing time to wearout by a factor of 100,000,000.

The 28F001BX-B and 28F001BX-T are capable of 100,000 program/erase cycles on each of the two parameter blocks, main block and boot block.

# ON-CHIP PROGRAMMING ALGORITHM

The 28F001BX integrates the Quick Pulse programming algorithm of prior Intel Flash Memory devices on-chip, using the Command Register, Status Register and Write State Machine (WSM). On-chip integration dramatically simplifies system software and provides processor-like interface timings to the Command and Status Registers. WSM operation, internal program verify and VPP high voltage presence are monitored and reported via appropriate Status Register bits. Figure 9 shows a system software flowchart for device programming. The entire sequence is performed with VPP at VPPH. Program abort occurs when RP# transitions to VIL, or VPP drops to VPPL. Although the WSM is halted, byte data is partially programmed at the location where programming was aborted. Block erasure or a repeat of byte programming will initialize this data to a known value.

#### **ON-CHIP ERASE ALGORITHM**

As above, the Quick Erase algorithm of prior Intel Flash Memory devices is now implemented internally, including all preconditioning of block data. WSM operation, erase success and V<sub>PP</sub> high voltage presence are monitored and reported through the Status Register. Additionally, if a command other than Erase Confirm is written to the device after Erase Setup has been written, both the Erase Status and Program Status bits will be set to "1". When issuing the Erase Setup and Erase Confirm commands, they should be written to an address within the address range of the block to be erased. Figure 10 shows a system software flowchart for block erase.

Erase typically takes 1-4 seconds per block. The Erase Suspend/Erase Resume command sequence allows interrupt of this erase operation to read data from a block other than that in which erase is being performed. A system software flowchart is shown in Figure 11.

The entire sequence is performed with  $V_{PP}$  at  $V_{PPH}$ . Abort occurs when RP# transitions to  $V_{IL}$  or  $V_{PP}$  falls to  $V_{PPL}$ , while erase is in progress. Block data is partially erased by this operation, and a repeat of erase is required to obtain a fully erased block.



# BOOT BLOCK PROGRAM AND ERASE

The boot block is intended to contain secure code which will minimally bring up a system and control programming and erase of other blocks of the device, if needed. Therefore, additional "lockout" protection is provided to guarantee data integrity. Boot block program and erase operations are enabled through high voltage V<sub>HH</sub> on either RP# or OE#, and the normal program and erase command sequences are used. Reference the AC Waveforms for Program/Erase.

If boot block program or erase is attempted while RP# is at  $V_{IH}$ , either the Program Status or Erase Status bit will be set to "1", reflective of the opera-

tion being attempted and indicating boot block lock. Program/erase attempts while  $V_{IH} < RP\# < V_{HH}$  produce spurious results and should not be attempted

#### **In-System Operation**

For on-board programming, the RP# pin is the most convenient means of altering the boot block. Before issuing Program or Erase confirms commands, RP# must transition to  $V_{HH}$ . Hold RP# at this high voltage throughout the program or erase interval (until after Status Register confirm of successful completion). At this time, it can return to  $V_{IH}$  or  $V_{II}$ .



| Bus<br>Operation | Command          | Comments                                                          |
|------------------|------------------|-------------------------------------------------------------------|
| Write            | Program<br>Setup | Data = 40H<br>Address = Byte to be<br>Programmed                  |
| Write            | Program          | Data to be programmed<br>Address = Byte to be<br>Programmed       |
| Read             |                  | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                  | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent bytes.

Full status check can be done after each byte or after a sequence of bytes.

Write FFH after the last byte programming operation to reset the device to Read Array Mode.

| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4<br>1 = Byte Program Error         |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple bytes are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 9. 28F001BX Byte Programming Flowchart





Figure 10. 28F001BX Block Erase Flowchart





Figure 11. 28F001BX Erase Suspend/Resume Flowchart

#### **Programming Equipment**

For PROM programming equipment that cannot bring RP# to high voltage, OE# provides an alternate boot block access mechanism. OE# must transition to V<sub>HH</sub> a minimum of 480 ns before the initial program/erase setup command and held at V<sub>HH</sub> at least 480 ns after program or erase confirm commands are issued to the device. After this interval, OE# can return to normal TTL levels.

### **DESIGN CONSIDERATIONS**

# **Three-Line Output Control**

Flash memories are often used in larger memory arrays. Intel provides three control inputs to accommo-

date multiple memory connections. Three-line control provides for:

- a) lowest possible memory power dissipation
- b) complete assurance that data bus contention will not occur

To efficiently use these control inputs, an address decoder should enable CE#, while OE# should be connected to all memory devices and the system's READ# control line. This assures that only selected memory devices have active outputs while deselected memory devices are in Standby Mode. RP# should be connected to the system POWERGOOD signal to prevent unintended writes during system power transitions. POWERGOOD should also toggle during system reset.



## **Power Supply Decoupling**

Flash memory power switching characteristics require careful device coupling. System designers are interested in 3 supply current issues; standby current levels (ISB), active current levels (ICC) and transient peaks producted by falling and rising edges of CE#. Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress transient voltage peaks. Each device should have a 0.1 µF ceramic capacitor connected between its V<sub>CC</sub> and GND, and between its V<sub>PP</sub> and GND. These high frequency, low inherent-inductance capacitors should be placed as close as possible to the device. Additionally, for every 8 devices, a 4.7 µF electrolytic capacitor should be placed at the array's power supply connection between V<sub>CC</sub> and GND. The bulk capacitor will overcome voltage slumps caused by PC board trace inductances.

# Vpp Trace on Printed Circuit Boards

Programming flash memories, while they reside in the target system, requires that the printed circuit board designer pay attention to the V<sub>PP</sub> power supply trace. The V<sub>PP</sub> pin supplies the memory cell current for programming. Use similar trace widths and layout considerations given to the V<sub>CC</sub> power bus. Adequate V<sub>PP</sub> supply traces and decoupling will decrease V<sub>PP</sub> voltage spikes and overshoots.

# V<sub>CC</sub>, V<sub>PP</sub>, RP# Transitions and the Command/Status Registers

Programming and erase completion are not guaranteed if V<sub>PP</sub> drops below V<sub>PPH</sub>. If the V<sub>PP</sub> Status bit of the Status Register (SR.3) is set to "1", a Clear Status Register command MUST be issued before further program/erase attempts are allowed by the WSM. Otherwise, the Program (SR.4) or Erase (SR.5) Status bits of the Status Register will be set to "1" if error is detected. RP# transitions to V<sub>IL</sub> during program and erase also abort the operations. Data is partially altered in either case, and the command sequence must be repeated after normal operation is restored. Device poweroff, or RP# transitions to V<sub>IL</sub>, clear the Status Register to initial value 80H.

The Command Register latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its state upon powerup, after exit from Deep-Powerdown or after  $V_{CC}$  transitions below  $V_{LKO}$ , is FFH, or Read Array Mode.

After program or erase is complete, even after V<sub>PP</sub> transitions down to V<sub>PPL</sub>, the Command Register must be reset to read array mode via the Read Array command if access to the memory array is desired.

# Power Up/Down Protection

The 28F001BX is designed to offer protection against accidental erasure or programming during power transitions. Upon power-up, the 28F001BX is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers up first. Power supply sequencing is not required. Internal circuitry in the 28F001BX ensures that the Command Register is reset to Read Array mode on power up.

A system designer must guard against spurious writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either to  $V_{IH}$  will inhibit writes. The Command Register architecture provides an added level of protection since alteration of memory contents only occurs after successful completion of the two-step command sequences.

Finally, the device is disabled, until RP# is brought to  $V_{IH}$ , regardless of the state of its control inputs. This provides an additional level of protection.

# 28F001BX Power Dissipation

When designing portable systems, designers must consider battery power consumption not only during device operation, but also for data retention during system idle time. Flash nonvolatility increases usable battery life because the 28F001BX does not consume any power to retain code or data when the system is off.

In addition, the 28F001BX's Deep-Powerdown mode ensures extremely low power dissipation even when system power is applied. For example, laptop and other PC applications, after copying BIOS to DRAM, can lower RP# to V<sub>IL</sub>, producing negligible power consumption. If access to the boot code is again needed, as in case of a system RESET#, the part can again be accessed, following the t<sub>PHAV</sub> wakeup cycle required after RP# is first raised back to V<sub>IH</sub>. The first address presented to the device while in powerdown requires time t<sub>PHAV</sub>, after RP# transitions high, before outputs are valid. Further accesses follow normal timing. See AC Characteristics—Read-Only Operations and Figure 12 for more information.



### **ABSOLUTE MAXIMUM RATINGS\***

| Operating Temperature  During Read                                                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Operating Temperature During Read40°C to $+85^{\circ}$ C(2) During Erase/Program40°C to $+85^{\circ}$ C(2)                                       |
| Temperature under Bias 10°C to 80°C(1)                                                                                                           |
| Temperature under Bias20°C to +90°C(2)                                                                                                           |
| Storage Temperature65°C to 125°C                                                                                                                 |
| Voltage on Any Pin<br>(except A <sub>9</sub> , RP#, OE#, V <sub>CC</sub> and V <sub>PP</sub> )<br>with Respect to GND2.0V to 7.0V <sup>(3)</sup> |
| Voltage on Ao. BP#, and OF#                                                                                                                      |

with Respect to GND ...... -2.0V to  $13.5V^{(3, 4)}$ 

During Erase/Program . . . . . -2.0V to 14.0V(3, 4)

with Respect to GND ..... – 2.0V to 7.0V<sup>(3)</sup>
Output Short Circuit Current ...... 100 mA<sup>(5)</sup>

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

V<sub>PP</sub> Program Voltage with Respect to GND

V<sub>CC</sub> Supply Voltage

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Operating temperature is for extended temperature product defined by this specification.
- 3. Minimum DC voltage is -0.5V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <20 ns. Maximum DC voltage on input/output pins is V<sub>CC</sub> +0.5V which, during transitions, may overshoot to V<sub>CC</sub> + 2.0V for periods <20 ns.
- 4. Maximum DC voltage on  $A_9$  or  $V_{PP}$  may overshoot to +14.0V for periods <20 ns.
- 5. Output shorted for no more than one second. No more than one output shorted at a time.

## **OPERATING CONDITIONS**

| Symbol | Parameter                | Min  | Max  | Unit |
|--------|--------------------------|------|------|------|
| TA     | Operating Temperature(1) | 0    | 70   | • °C |
| TA     | Operating Temperature(2) | -40  | 85   | °C   |
| Vcc    | Supply Voltage           | 4.50 | 5.50 | ٧    |

## DC CHARACTERISTICS $V_{CC} = 5.0V \pm 10\%$ , $T_A = 0^{\circ}C$ to $+70^{\circ}C$

| Symbol | Parameter                              | Notes | Min | Тур  | Max   | Unit | Test Conditions                                                                    |
|--------|----------------------------------------|-------|-----|------|-------|------|------------------------------------------------------------------------------------|
| կլ     | Input Load Current                     | 1     |     |      | ± 1.0 | μА   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or GND$                                  |
| ILO    | Output Leakage Current                 | 1     |     |      | ±10   | μÂ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>OUT</sub> = V <sub>CC</sub> or GND |
| Iccs   | V <sub>CC</sub> Standby Current        |       |     | 1.2  | 2.0   | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = RP# = V <sub>IH</sub>               |
|        |                                        |       |     | 30   | 100   | μΑ   | $V_{CC} = V_{CC} Max$ $CE # = RP # = V_{CC} \pm 0.2V$                              |
| ICCD   | V <sub>CC</sub> Deep-Powerdown Current | 1     |     | 0.05 | 1.0   | μΑ   | RP# = GND ±0.2V                                                                    |



# **DC CHARACTERISTICS** $V_{CC} = 5.0V \pm 10\%$ , $T_A = 0^{\circ}C$ to $+70^{\circ}C$ (Continued)

| Symbol            | Parameter                                     | Notes | Min  | Тур  | Max                   | Unit | Test Conditions                                                                      |
|-------------------|-----------------------------------------------|-------|------|------|-----------------------|------|--------------------------------------------------------------------------------------|
| ICCR              | V <sub>CC</sub> Read Current                  | 1     |      | 13   | 30                    | mΑ   | $V_{CC} = V_{CC} \text{ Max, CE} \# = V_{IL}$<br>f = 8 MHz, $I_{OUT} = 0 \text{ mA}$ |
| ICCP              | V <sub>CC</sub> Programming Current           | 1     |      | 5    | 20                    | mΑ   | Programming in Progress                                                              |
| ICCE              | V <sub>CC</sub> Erase Current                 | 1     |      | 6    | 20                    | mΑ   | Erase in Progress                                                                    |
| ICCES             | V <sub>CC</sub> Erase Suspend Current         | 1, 2  |      | 5    | 10                    | mA   | Erase Suspended<br>CE# = V <sub>IH</sub>                                             |
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby Current               | 1     |      | ±1   | ±10                   | μΑ   | $V_{PP} \leq V_{CC}$                                                                 |
|                   |                                               |       |      | 90   | 200                   | μΑ   | $V_{PP} > V_{CC}$                                                                    |
| $I_{PPD}$         | V <sub>PP</sub> Deep-Powerdown Current        | 1     |      | 0.80 | 1.0                   | μΑ   | $RP# = GND \pm 0.2V$                                                                 |
| Іррр              | V <sub>PP</sub> Programming Current           | 1     |      | 6    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress                        |
| I <sub>PPE</sub>  | V <sub>PP</sub> Erase Current                 | 1     |      | 6    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase in Progress                              |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend Current         | 1     |      | 90   | 300                   | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Suspended                                |
| I <sub>ID</sub>   | A <sub>9</sub> Intelligent Identifier Current | 1     |      | 90   | 500                   | μΑ   | $A_9 = V_{ID}$                                                                       |
| V <sub>IL</sub>   | Input Low Voltage                             |       | -0.5 |      | 0.8                   | ٧    |                                                                                      |
| V <sub>IH</sub>   | Input High Voltage                            |       | 2.0  |      | V <sub>CC</sub> + 0.5 | ٧    |                                                                                      |
| V <sub>OL</sub>   | Output Low Voltage                            |       |      |      | 0.45                  | ٧    | $V_{CC} = V_{CC} Min$ $I_{OL} = 5.8 mA$                                              |
| V <sub>OH</sub>   | Output High Voltage                           |       | 2.4  |      |                       | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = 2.5 mA$                                              |
| $V_{ID}$          | A <sub>9</sub> Intelligent Identifier Voltage |       | 11.5 |      | 13.0                  | ٧    | ,                                                                                    |
| V <sub>PPL</sub>  | V <sub>PP</sub> during Normal Operations      | 3     | 0.0  |      | 6.5                   | ٧    |                                                                                      |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Prog/Erase Operations  |       | 11.4 | 12.0 | 12.6                  | ٧    |                                                                                      |
| $V_{LKO}$         | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.5  |      |                       | ٧    | ·                                                                                    |
| $V_{HH}$          | RP#, OE# Unlock Voltage                       |       | 11.4 |      | 12.6                  | ٧    | Boot Block Prog/Erase                                                                |

# DC CHARACTERISTICS $V_{CC} = 5.0V \pm 10\%$ , $T_A = -40^{\circ}C$ to $+85^{\circ}C$

| Symbol | Parameter                              | Notes | Min | Тур  | Max  | Unit | Test Conditions                                         |
|--------|----------------------------------------|-------|-----|------|------|------|---------------------------------------------------------|
| IιL    | Input Load Current                     | 1     |     |      | ±1.0 | μА   | $V_{CC} = V_{CC} Max$ $V_{IN} = V_{CC} or GND$          |
| lLO    | Output Leakage Current                 | 1     |     |      | ±10  | μА   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or GND$      |
| Iccs   | V <sub>CC</sub> Standby Current        |       |     | 1.2  | 2.0  | mA   | $V_{CC} = V_{CC} Max$ $CE \# = RP \# = V_{IH}$          |
| •      |                                        |       |     | 30   | 150  | μА   | $V_{CC} = V_{CC} Max$ $CE \# = RP \# = V_{CC} \pm 0.2V$ |
| ICCD   | V <sub>CC</sub> Deep-Powerdown Current | 1     |     | 0.05 | 2.0  | μΑ   | RP# = GND ±0.2V                                         |



# DC CHARACTERISTICS $V_{CC} = 5.0V \pm 10\%$ , $T_{A} = -40^{\circ}\text{C}$ to $+85^{\circ}\text{C}$ (Continued)

| Symbol            | Parameter                                     | Notes | Min                  | Тур  | Max                  | Unit | Test Conditions                                                     |
|-------------------|-----------------------------------------------|-------|----------------------|------|----------------------|------|---------------------------------------------------------------------|
| ICCR              | V <sub>CC</sub> Read Current                  | 1     |                      | 13   | 35                   | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 8 MHz, $I_{OUT} = 0 mA$ |
| ICCP              | V <sub>CC</sub> Programming Current           | 1     |                      | 5    | 20                   | mΑ   | Programming in Progress                                             |
| ICCE              | V <sub>CC</sub> Erase Current                 | 1     |                      | 6    | 20                   | mΑ   | Erase in Progress                                                   |
| ICCES             | V <sub>CC</sub> Erase Suspend Current         | 1, 2  | -                    | 5    | 10                   | mA   | Erase Suspended<br>CE# = V <sub>IH</sub>                            |
| IPPS              | V <sub>PP</sub> Standby Current               | 1     |                      | ±1   | ±15                  | μΑ   | V <sub>PP</sub> ≤V <sub>CC</sub>                                    |
|                   | •                                             |       |                      | 90   | 400                  | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                   |
| I <sub>PPD</sub>  | V <sub>PP</sub> Deep-Powerdown Current        | 1     |                      | 0.80 | 1.0                  | μΑ   | RP# = GND ±0.2V                                                     |
| Іррр              | V <sub>PP</sub> Programming Current           | 1     |                      | 6    | 30                   | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress       |
| IPPE              | V <sub>PP</sub> Erase Current                 | 1     |                      | 6    | 30                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase in Progress             |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend Current         | 1     |                      | 90   | 400                  | μΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Suspended               |
| ID                | A <sub>9</sub> Intelligent Identifier Current | 1     |                      | .90  | 500                  | μΑ   | $A_9 = V_{ID}$                                                      |
| $V_{IL}$          | Input Low Voltage                             |       | -0.5                 |      | 0.8                  | ٧    |                                                                     |
| VIH               | Input High Voltage                            |       | 2.0                  |      | V <sub>CC</sub> +0.5 | ٧    |                                                                     |
| V <sub>OL</sub>   | Output Low Voltage                            |       |                      |      | 0.45                 | ٧    | $V_{CC} = V_{CC} Min$<br>$I_{OL} = 5.8 mA$                          |
| V <sub>OH1</sub>  | Output High Voltage (TTL)                     |       | 2.4                  |      |                      | ٧    | $V_{CC} = V_{CC} Min$ $I_{OH} = 2.5 mA$                             |
| V <sub>OH2</sub>  | Output High Voltage (CMOS)                    |       | 0.85 V <sub>CC</sub> |      |                      | ٧    | $I_{OH} = -2.5 \mu\text{A}$ $V_{CC} = V_{CC} \text{Min}$            |
|                   |                                               |       | V <sub>CC</sub> -0.4 |      | ; /                  |      | $I_{OH} = -100 \mu\text{A}$<br>$V_{CC} = V_{CC} \text{Min}$         |
| $V_{ID}$          | A <sub>9</sub> Intelligent Identifier Voltage |       | 11.5                 |      | 13.0                 | ٧    |                                                                     |
| V <sub>PPL</sub>  | V <sub>PP</sub> during Normal Operations      | 3     | 0.0                  |      | 6.5                  | ٧    |                                                                     |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Prog/Erase Operations  |       | 11.4                 | 12.0 | 12.6                 | ٧    |                                                                     |
| $V_{LKO}$         | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.5                  |      | i                    | ٧    |                                                                     |
| V <sub>HH</sub>   | RP#, OE# Unlock Voltage                       |       | 11.4                 |      | 12.6                 | ٧    | Boot Block Prog/Erase                                               |

# CAPACITANCE(4) TA = 25°C, f = 1 MHz

| Symbol           | Parameter          | Max | Unit | Conditions            |
|------------------|--------------------|-----|------|-----------------------|
| C <sub>IN</sub>  | Input Capacitance  | 8   | pF   | $V_{IN} = 0V$         |
| C <sub>OUT</sub> | Output Capacitance | 12  | pF   | V <sub>OUT</sub> = 0V |

1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T_{A} = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).

2. ICCES is specified with the device deselected. If the 28F001BX is read while in Erase Suspend mode, current draw is the sum of  $I_{CCES}$  and  $I_{CCP}$ . 3. Erase/Programs are inhibited when  $V_{PP} = V_{PPL}$  and not guaranteed in the range between  $V_{PPH}$  and  $V_{PPL}$ .

4. Sampled, not 100% tested.



### AC INPUT/OUTPUT REFERENCE WAVEFORM



A.C. test inputs are driven at  $V_{OH}$  (2.4  $V_{TTL}$ ) for a Logic "1" and  $V_{OL}$  (0.45  $V_{TTL}$ ) for a Logic "0". Input timing begins at  $V_{IH}$  (2.0  $V_{TTL}$ ) and  $V_{IL}$  (0.8  $V_{TTL}$ ). Output timing ends at  $V_{IH}$  and  $V_{IL}$ . Input rise and fall times (10% to 90%) < 10 ns.

#### STANDARD TEST CONFIGURATION AC TESTING LOAD CIRCUIT



#### HIGH SPEED TEST CONFIGURATION AC TESTING LOAD CIRCUIT







# AC CHARACTERISTICS—Read-Only Operations(1)

|                   | . 1                                                                          |       |     | 28F00            | 1BX-70 |                     | 28F00                 | 1BX-90 |    |
|-------------------|------------------------------------------------------------------------------|-------|-----|------------------|--------|---------------------|-----------------------|--------|----|
| Symbol            | Parameter                                                                    | Notes | ±   | = 5V<br>5%<br>pF | ± 1    | = 5V<br>10%<br>D pF | V <sub>CC</sub> ± 100 | Units  |    |
|                   |                                                                              | -     | Min | Max              | Min    | Max                 | Min                   | Max    | 1  |
| t <sub>AVAV</sub> | Read Cycle Time                                                              |       | 70  |                  | 75     |                     | 90                    |        | ns |
| t <sub>AVQV</sub> | Address to Output Delay                                                      |       |     | 70               |        | 75                  |                       | 90     | ns |
| tELQV             | CE# to Output Delay                                                          | 2     |     | 70               |        | 75                  |                       | 90     | ns |
| t <sub>PHQV</sub> | RP# to Output Delay                                                          |       |     | 600              |        | 600                 |                       | 600    | ns |
| t <sub>GLQV</sub> | OE# to Output Delay                                                          | 2     |     | 27               |        | 30                  |                       | 35     | ns |
| t <sub>ELQX</sub> | CE# to Output in Low Z                                                       | 3     | 0   |                  | 0      |                     | 0                     |        | ns |
| tEHQZ             | CE# to Output in High Z                                                      | 3     |     | 55               |        | 55                  |                       | 35     | ns |
| t <sub>GLQX</sub> | OE# to Output in Low Z                                                       | 3     | 0   |                  | 0      |                     | 0                     |        | ns |
| t <sub>GHQZ</sub> | OE# to Output in High Z                                                      | 3     |     | 30               |        | 30                  |                       | 30     | ns |
| t <sub>OH</sub>   | Output Hold from<br>Address CE#, or OE#<br>Change, Whichever<br>Occurs First | 3     | 0 . | -                | 0      |                     | 0                     | -      | ns |

- See AC Input/Output Reference Waveform for timing measurements.
- 2. OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.

  3. Sampled, but not 100% tested.

  4. See High Speed Test Configuration.

- 5. See Standard Test Configuration.



# AC CHARACTERISTICS—Read-Only Operations(1)

|                     | Versi            | ons(2)                                            | V <sub>CC</sub> ±1 | 0%    | N28F00 | 01BX-120<br>01BX-120<br>01BX-120 | E28F001BX-150<br>TE28F001BX-150<br>N28F001BX-150<br>TN28F001BX-150<br>P28F001BX-150 |     | Unit |
|---------------------|------------------|---------------------------------------------------|--------------------|-------|--------|----------------------------------|-------------------------------------------------------------------------------------|-----|------|
| Sym                 | bol              | Param                                             | neter              | Notes | Min    | Max                              | Min                                                                                 | Max |      |
| t <sub>AVAV</sub>   | t <sub>RC</sub>  | Read Cycle Tir                                    | ne                 |       | 120    |                                  | 150                                                                                 |     | ns   |
| t <sub>AVQV</sub> : | t <sub>ACC</sub> | Address to Out                                    | put Delay          |       |        | 120                              |                                                                                     | 150 | ns   |
| tELQV               | t <sub>CE</sub>  | CE# to Output                                     | Delay              | 3     |        | 120                              |                                                                                     | 150 | ns   |
| t <sub>PHQV</sub>   | tpwH             | RP# High to C                                     | utput Delay        |       |        | 600                              |                                                                                     | 600 | ns   |
| t <sub>GLQV</sub>   | toE              | OE# to Output                                     | Delay              | 3     |        | 50                               |                                                                                     | 55  | ns   |
| t <sub>ELQX</sub>   | t <sub>LZ</sub>  | CE# to Output                                     | Low Z              | 4     | 0      |                                  | 0                                                                                   |     | ns   |
| t <sub>EHQZ</sub>   | t <sub>HZ</sub>  | CE# High to C                                     | utput High Z       | 4     |        | 55                               |                                                                                     | 55  | ns   |
| tGLQX               | toLZ             | OE# to Output                                     | Low Z              | 4     | 0      |                                  | 0                                                                                   |     | ns   |
| tGHQZ               | t <sub>DF</sub>  | OE# High to C                                     | output High Z      | 4     |        | 30                               |                                                                                     | 30  | ns   |
|                     | toH              | Output Hold fro<br>Addresses, CE<br>Change, Which | # or OE#           | 4     | . 0    |                                  | 0                                                                                   |     | ns   |

#### **NOTES:**

1. See AC Input/Output Reference Waveform for timing measurements.

4. Sampled, not 100% tested.

<sup>2.</sup> Model Number Prefixes: E = TSOP (Standard Pinout), N = PLCC, P = PDIP, T = Extended Temperature. Refer to standard test configuration.

<sup>3.</sup> OE# may be delayed up to t<sub>CE</sub>-t<sub>OE</sub> after the falling edge of CE# without impact on t<sub>CE</sub>.









# AC CHARACTERISTICS—Write/Erase/Program Operations(1,9)

|                    |                  |                                                |         |     | 28F00               | IBX-70 | )                     | 28F00 | 1BX-90                |       |
|--------------------|------------------|------------------------------------------------|---------|-----|---------------------|--------|-----------------------|-------|-----------------------|-------|
| Symi               | ool              | Parameter                                      | Notes   | ±59 | = 5V<br>%(10)<br>pF | ± 10   | = 5V<br>%(11)<br>) pF | ± 10  | = 5V<br>%(11)<br>) pF | Units |
|                    |                  |                                                |         | Min | Max                 | Min    | Max                   | Min   | Max                   |       |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                               |         | 70  |                     | 75     |                       | 90    |                       | ns    |
| t <sub>PHWL</sub>  | tps              | RP# High Recovery to WE#<br>Going Low          | 2       | 480 |                     | 480    |                       | 480   |                       | ns    |
| tELWL              | tcs              | CE# Setup to WE# Going Low                     |         | 10  |                     | 10     |                       | 10    |                       | ns    |
| twLwH              | twp              | WE# Pulse Width                                |         | 35  |                     | 40     |                       | 40    |                       | ns    |
| t <sub>PHHWH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to WE# Going<br>High | 2       | 100 |                     | 100    |                       | 100   |                       | ns    |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE# Going High        | 2       | 100 |                     | 100    |                       | 100   |                       | ns    |
| t <sub>AVWH</sub>  | t <sub>AS</sub>  | Address Setup to WE# Going High                | 3       | 35  |                     | 40     |                       | 40    |                       | ns    |
| tovwh              | t <sub>DS</sub>  | Data Setup to WE# Going High                   | 4       | 35  |                     | 40     |                       | 40    |                       | ns    |
| twhox              | t <sub>DH</sub>  | Data Hold from WE# High                        |         | 10  |                     | 10     |                       | 10    |                       | ns    |
| twhax              | t <sub>AH</sub>  | Address Hold from WE# High                     |         | 10  |                     | 10     |                       | 10    |                       | ns    |
| twheh              | t <sub>CH</sub>  | CE# Hold from WE# High                         |         | 10  |                     | 10     |                       | 10    |                       | ns    |
| twhwL              | t <sub>WPH</sub> | WE# Pulse Width High                           |         | 35  |                     | 35     |                       | 35    |                       | ns    |
| twHQV1             |                  | Duration of Programming Operation              | 5, 6, 7 | 15  |                     | 15     |                       | 15    |                       | μs    |
| t <sub>WHQV2</sub> |                  | Duration of Erase Operation (Boot)             | 5, 6, 7 | 1.3 |                     | 1.3    |                       | 1.3   |                       | sec   |
| t <sub>WHQV3</sub> |                  | Duration of Erase Operation (Parameter)        | 5, 6, 7 | 1.3 |                     | 1.3    |                       | 1.3   |                       | sec   |
| t <sub>WHQV4</sub> |                  | Duration of Erase Operation (Main)             | 5, 6, 7 | 3.0 |                     | 3.0    |                       | 3.0   |                       | sec   |
| twHGL              |                  | Write Recovery before Read                     |         | 0   |                     | 0      |                       | 0     |                       | μs    |
| tQVVL              | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD            | 2, 6    | 0   |                     | 0      |                       | 0     |                       | ns    |
| tQVPH              | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD        | 2, 7    | 0   | -                   | 0      |                       | 0     |                       | ns    |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                        | 2       |     | 100                 |        | 100                   |       | 100                   | ns    |

#### NOTES:

- 1. Read timing characteristics during erase and program operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid AIN for byte programming or block erasure.
- 4. Refer to Table 3 for valid DIN for byte programming or block erasure.
- 5. The on-chip Write State Machine incorporates all program and erase system functions and overhead of standard Intel Flash Memory, including byte program and verify (programming) and block precondition, precondition verify, erase and erase verify (erasing).
- 6. Program and erase durations are measured to completion (SR.7 = 1). V<sub>PP</sub> should be held at V<sub>PPH</sub> until determination of program/erase success (SR.3/4/5 = 0).
- 7. For boot block programming and erasure, RP# should be held at V<sub>HH</sub> until determination of program/erase success (SR.3/4/5 = 0).
- 8. Alternate boot block access method.
- 9. Erase/Program Cycles on extended temperature products is 10,000 cycles.
- 10. See high speed test configuration.
- 11. See standard test configuration.



# AC CHARACTERISTICS—Write/Erase/Program Operations(1,9)

|                    | ,                | /ersions                                | V <sub>CC</sub> ± 10% | 10)     | 28F001 | BX-120 | 28F001 | BX-150 |      |
|--------------------|------------------|-----------------------------------------|-----------------------|---------|--------|--------|--------|--------|------|
| Symi               | ool              | Paramete                                | r                     | Notes   | Min    | Max    | Min    | Max    | Unit |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                        |                       |         | 120    |        | 150    |        | ns   |
| t <sub>PHWL</sub>  | t <sub>PS</sub>  | RP# High Recovery to W                  | E# Going Low          | 2       | 480    |        | 480    |        | ns   |
| tELWL              | tcs              | CE# Setup to WE# Goin                   |                       | 10      |        | 10     |        | ns     |      |
| twLWH              | t <sub>WP</sub>  | WE# Pulse Width                         |                       | 50      |        | 50     |        | ns     |      |
| t <sub>PHHWH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to WE#        | 2                     | 100     |        | 100    |        | ns     |      |
| t <sub>VPWH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to WE# Going      | High                  | 2       | 100    |        | 100    |        | ns   |
| t <sub>AVWH</sub>  | t <sub>AS</sub>  | Address Setup to WE# G                  | 3                     | 50      |        | 50     |        | ns     |      |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Data Setup to WE# Goin                  | 4                     | 50      |        | 50     |        | ns     |      |
| t <sub>WHDX</sub>  | t <sub>DH</sub>  | Data Hold from WE# High                 |                       | 10      |        | 10     |        | ns     |      |
| t <sub>WHAX</sub>  | t <sub>AH</sub>  | Address Hold from WE#                   | High                  |         | 10     |        | 10     |        | ns   |
| t <sub>WHEH</sub>  | t <sub>CH</sub>  | CE# Hold from WE# Hig                   | h ,                   |         | 10     |        | 10     |        | ns   |
| t <sub>WHWL</sub>  | t <sub>WPH</sub> | WE# Pulse Width High                    |                       |         | 50     |        | 50     |        | ns   |
| t <sub>WHQV1</sub> | :                | Duration of Programming                 | Operation             | 5, 6, 7 | 15     |        | 15     |        | μs   |
| t <sub>WHQV2</sub> |                  | Duration of Erase Operati               | on (Boot)             | 5, 6, 7 | 1.3    |        | 1.3    |        | sec  |
| twHQV3             |                  | Duration of Erase Operati               | on (Parameter)        | 5, 6, 7 | 1.3    |        | 1.3    |        | sec  |
| twHQV4             |                  | Duration of Erase Operati               | on (Main)             | 5, 6, 7 | 3.0    |        | 3.0    |        | sec  |
| twHGL              |                  | Write Recovery before Read              |                       |         | . 0    |        | 0      |        | μs   |
| tQVVL              | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD     |                       | 2, 6    | 0      |        | 0      |        | ns   |
| t <sub>QVPH</sub>  | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD |                       | 2, 7    | 0      |        | 0      |        | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                 |                       | 2       | 4      | 100    |        | 100    | ns   |

# **PROM Programmer Specifications**

|        | Versions V <sub>CC</sub> ± 10%   |             | 0%    | 28F001 | BX-120 | 28F001 | I I mia |      |
|--------|----------------------------------|-------------|-------|--------|--------|--------|---------|------|
| Symbol | pol Parameter                    |             | Notes | Min    | Max    | Min    | Max     | Unit |
| tGHHWL | OE# V <sub>HH</sub> Setup to WE  | # Going Low | 2, 8  | 480    |        | 480    |         | ns   |
| twhgh  | OE# V <sub>HH</sub> Hold from WE | E# High     | 2, 8  | 480    |        | 480    |         | ns   |

#### **NOTES**

- 1. Read timing characteristics during erase and program operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid  $A_{\mbox{\scriptsize IN}}$  for byte programming or block erasure.
- 4. Refer to Table 3 for valid DIN for byte programming or block erasure.
- 5. The on-chip Write State Machine incorporates all program and erase system functions and overhead of standard Intel Flash Memory, including byte program and verify (programming) and block precondition, precondition verify, erase and erase verify (erasing).
- 6. Program and erase durations are measured to completion (SR.7 = 1). V<sub>PP</sub> should be held at V<sub>PPH</sub> until determination of program/erase success (SR.3/4/5 = 0).
- 7. For boot block programming and erasure, RP# should be held at V<sub>HH</sub> until determination of program/erase success (SR.3/4/5 = 0).
- 8. Alternate boot block access method.
- 9. Erase/Program Cycles on extended temperature products is 10,000 cycles.
- 10. See standard test configuration.



# **ERASE AND PROGRAMMING PERFORMANCE**

| Parameter                    | Notes | 28  | 3F001BX-1 | 20   | 28  | 3F001BX-1 | 50   | Unit |
|------------------------------|-------|-----|-----------|------|-----|-----------|------|------|
| Parameter                    | Notes | Min | Typ(1)    | Max  | Min | Typ(1)    | Max  | Unit |
| Boot Block Erase Time        | 2     |     | 2.10      | 14.9 |     | 2.10      | 14.9 | Sec  |
| Boot Block Program Time      | 2     |     | 0.15      | 0.52 |     | 0.15      | 0.52 | Sec  |
| Parameter Block Erase Time   | 2     |     | 2.10      | 14.6 |     | 2.10      | 14.6 | Sec  |
| Parameter Block Program Time | 2     |     | 0.07      | 0.26 |     | 0.07      | 0.26 | Sec  |
| Main Block Erase Time        | 2     |     | 3.80      | 20.9 |     | 3.80      | 20.9 | Sec  |
| Main Block Program Time      | 2     |     | 2.10      | 7.34 | ,   | 2.10      | 7.34 | Sec  |
| Chip Erase Time              | 2     |     | 10.10     | 65   |     | 10.10     | 65   | Sec  |
| Chip Program Time            | 2     |     | 2.39      | 8.38 |     | 2.39      | 8.38 | Sec  |

NOTES: 1. 25°C, 12.0 Vpp. 2. Excludes System-Level Overhead.





Figure 13. 28F001BX Typical Programming Capability



Figure 14. 28F001BX Typical Programming Time at 12V





Figure 15. 28F001BX Typical Erase Capability



Figure 16. 28F001BX Typical Erase Time at 12V









Figure 18. Alternate Boot Block Access Method Using OE#



### ALTERNATE CE#-CONTROLLED WRITES(1)

|                    |                  |                                             |       |                                         | 28F00 | 1BX-70 | )                    | 28F00 | 1BX-90                |       |
|--------------------|------------------|---------------------------------------------|-------|-----------------------------------------|-------|--------|----------------------|-------|-----------------------|-------|
| Syml               | bol              | Parameter                                   | Notes | V <sub>CC</sub> = 5V<br>±5%(8)<br>30 pF |       | ± 10   | = 5V<br>%(9)<br>) pF | ± 10  | = 5V<br>)%(9)<br>) pF | Units |
|                    |                  |                                             |       | Min                                     | Max   | Min    | Max                  | Min   | Max                   |       |
| t <sub>AVAV</sub>  | twc              | Write Cycle Time                            |       | 70                                      |       | 75     |                      | 90    |                       | ns    |
| t <sub>PHEL</sub>  | tps              | RP# High Recovery to CE# Going Low          | 2     | 480                                     |       | 480    | ,                    | 480   |                       | ns    |
| twlel              | tws              | WE# Setup to CE# Going Low                  |       | 0                                       |       | 0      |                      | 10    | ,                     | ns    |
| t <sub>ELEH</sub>  | t <sub>CP</sub>  | CE# Pulse Width                             |       | 50                                      |       | 55     |                      | 55    |                       | ns    |
| t <sub>PHHEH</sub> | tphs             | RP# V <sub>HH</sub> Setup to CE# Going High | 2     | 100                                     |       | 100    |                      | 100   |                       | ns    |
| t <sub>VPEH</sub>  | t <sub>VPS</sub> | V <sub>PP</sub> Setup to CE# Going High     | 2     | 100                                     |       | 100    |                      | 100   |                       | ns    |
| t <sub>AVEH</sub>  | t <sub>AS</sub>  | Address Setup to CE# Going High             | 3     | 35                                      |       | 40     |                      | 40    |                       | ns    |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to CE# Going High                | 4     | 35                                      |       | 40     |                      | 40    |                       | ns    |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from CE# High                     |       | 10                                      |       | 10     |                      | 10    |                       | ns    |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold from CE# High                  |       | 10                                      |       | 10     |                      | 10    |                       | ns    |
| t <sub>EHWH</sub>  | t <sub>WH</sub>  | WE# Hold from CE# High                      |       | 0                                       |       | 0      |                      | 0     |                       | ns    |
| t <sub>EHEL</sub>  | t <sub>EPH</sub> | CE# Pulse Width High                        |       | 20                                      |       | 20     |                      | 20    |                       | ns    |
| t <sub>EHQV1</sub> |                  | Duration of Programming Operation           | 5, 6  | 15                                      |       | 15     |                      | 15    |                       | μs    |
| t <sub>EHQV2</sub> |                  | Duration of Erase Operation (Boot)          | 5, 6  | 1.3                                     |       | 1.3    |                      | 1.3   |                       | sec   |
| t <sub>EHQV3</sub> |                  | Duration of Erase Operation (Parameter)     | 5, 6  | 1.3                                     |       | 1.3    |                      | 1.3   |                       | sec   |
| t <sub>EHQV4</sub> |                  | Duration of Erase Operation (Main)          | 5, 6  | 3.0                                     | ,     | 3.0    |                      | 3.0   |                       | sec   |
| t <sub>EHGL</sub>  |                  | Write Recovery before Read                  |       | 0                                       |       | 0      |                      | 0     |                       | μs    |
| t <sub>QVVL</sub>  | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD         | 2, 5  | 0                                       |       | 0      |                      | 0     |                       | ns    |
| tQVPH              | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD     | 2, 6  | 0                                       |       | 0      |                      | 0     |                       | ns    |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                     | 2     |                                         | 100   |        | 100                  |       | 100                   | ns    |

#### NOTES

- 1. Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE#. In systems where CE# defines the write pulse width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid AIN for byte programming or block erasure.
- 4. Refer to Table 3 for valid D<sub>IN</sub> for byte programming or block erasure.
- 5. Program and erase durations are measured to completion (SR.7 = 1). V<sub>PP</sub> should be held at V<sub>PPH</sub> until determination of program/erase success (SR.3/4/5 = 0).
- 6. For boot block programming and erasure, RP# should be held at V<sub>HH</sub> until determination of program/erase success (SR.3/4/5 = 0).
- 7. Alternate boot block access method.
- 8. See high speed test configuration.
- 9. See standard text configuration.



## ALTERNATE CE #-CONTROLLED WRITES(1)

| Versions           |                  |                                             | V <sub>CC</sub> ± 10% |       | 28F001BX-120 |     | 28F001BX-150 |     |      |
|--------------------|------------------|---------------------------------------------|-----------------------|-------|--------------|-----|--------------|-----|------|
| Symbol             |                  | Parameter                                   |                       | Notes | Min          | Max | Min          | Max | Unit |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Write Cycle Time                            |                       |       | 120          |     | 150          |     | ns   |
| t <sub>PHEL</sub>  | t <sub>PS</sub>  | RP# High Recovery to CE# Going Low          |                       | 2     | 480          |     | 480          |     | ns   |
| t <sub>WLEL</sub>  | t <sub>WS</sub>  | WE# Setup to CE# Going Low                  |                       |       | 0            |     | 0            |     | ns   |
| t <sub>ELEH</sub>  | t <sub>CP</sub>  | CE# Pulse Width                             |                       |       | 70           |     | 70           |     | ns   |
| t <sub>PHHEH</sub> | t <sub>PHS</sub> | RP# V <sub>HH</sub> Setup to CE# Going High |                       | 2     | 100          |     | 100          |     | ns   |
| t <sub>VPEH</sub>  | tvps             | V <sub>PP</sub> Setup to CE# Going High     |                       | 2     | 100          |     | 100          |     | ns   |
| t <sub>AVEH</sub>  | t <sub>AS</sub>  | Address Setup to CE# Going High             |                       | 3     | 50           |     | 50           |     | ns   |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Data Setup to CE# Going High                |                       | 4     | 50           |     | 50           |     | ns   |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Data Hold from CE# High                     |                       |       | 10           |     | 10           |     | ns   |
| t <sub>EHAX</sub>  | t <sub>AH</sub>  | Address Hold from CE# I                     | High                  | l     | 15           |     | 15           |     | ns   |
| t <sub>EHWH</sub>  | t <sub>WH</sub>  | WE# Hold from CE# Hig                       | h                     |       | 0            |     | 0            |     | ns   |
| t <sub>EHEL</sub>  | t <sub>EPH</sub> | CE# Pulse Width High                        |                       |       | 25           |     | 25           |     | ns   |
| t <sub>EHQV1</sub> |                  | Duration of Programming                     | Operation             | 5, 6  | 15           |     | 15           |     | μs   |
| t <sub>EHQV2</sub> |                  | Duration of Erase Operati                   | on (Boot)             | 5, 6  | 1.3          |     | 1.3          |     | sec  |
| t <sub>EHQV3</sub> |                  | Duration of Erase Operati                   | on (Parameter)        | 5, 6  | 1.3          |     | 1.3          |     | sec  |
| t <sub>EHQV4</sub> |                  | Duration of Erase Operati                   | on (Main)             | 5, 6  | 3.0          |     | 3.0          |     | sec  |
| t <sub>EHGL</sub>  |                  | Write Recovery before Re                    | ad                    |       | 0            |     | 0            |     | μs   |
| t <sub>QVVL</sub>  | t <sub>VPH</sub> | V <sub>PP</sub> Hold from Valid SRD         |                       | 2, 5  | 0            |     | 0            |     | ns   |
| t <sub>QVPH</sub>  | t <sub>PHH</sub> | RP# V <sub>HH</sub> Hold from Valid SRD     |                       | 2, 6  | 0            |     | 0            |     | ns   |
| t <sub>PHBR</sub>  |                  | Boot-Block Relock Delay                     |                       | 2     |              | 100 |              | 100 | ns   |

# **PROM Programmer Specifications**

|                    | Versions                        | V <sub>CC</sub> ± 10% |       | 28F001BX-120 |     | 28F001BX-150 |     | Unit  |
|--------------------|---------------------------------|-----------------------|-------|--------------|-----|--------------|-----|-------|
| Symbol             | Parameter                       |                       | Notes | Min          | Max | Min          | Max | Oilit |
| t <sub>GHHEL</sub> | OE# V <sub>HH</sub> Setup to Ci | 2, 7                  | 480   |              | 480 |              | ns  |       |
| t <sub>EHGH</sub>  | OE# V <sub>HH</sub> Hold from ( | 2, 7                  | 480   |              | 480 |              | ns  |       |

#### NOTES:

- 1. Chip-Enable Controlled Writes: Write operations are driven by the valid combination of CE# and WE#. In systems where CE# defines the write pulse width (within a longer WE# timing waveform), all set-up, hold and inactive WE# times should be measured relative to the CE# waveform.
- 2. Sampled, not 100% tested.
- 3. Refer to Table 3 for valid AIN for byte programming or block erasure.
- 4. Refer to Table 3 for valid D<sub>IN</sub> for byte programming or block erasure.
- 5. Program and erase durations are measured to completion (SR.7 = 1). V<sub>PP</sub> should be held at V<sub>PPH</sub> until determination of program/erase success (SR.3/4/5 = 0).
- 6. For boot block programming and erasure, RP# should be held at  $V_{HH}$  until determination of program/erase success (SR.3/4/5 = 0).
- 7. Alternate boot block access method.







### **ORDERING INFORMATION**



### **VALID COMBINATIONS:**

|            | 32-Lead TSOP    | 32-Lead PLCC    | 32-Pin PDIP    |
|------------|-----------------|-----------------|----------------|
| Commercial | E28F001BX-T70   | N28F001BX-T70   | P28F001BX-T70  |
|            | E28F001BX-T90   | N28F001BX-T90   | P28F001BX-T90  |
|            | E28F001BX-T120  | N28F001BX-T120  | P28F001BX-T120 |
|            | E28F001BX-T150  | N28F001BX-T150  | P28F001BX-T150 |
|            |                 |                 |                |
|            | E28F001BX-B70   | N28F001BX-B70   | P28F001BX-B70  |
|            | E28F001BX-B90   | N28F001BX-B90   | P28F001BX-B90  |
|            | E28F001BX-B120  | N28F001BX-B120  | P28F001BX-B120 |
|            | E28F001BX-B150  | N28F001BX-B150  | P28F001BX-B150 |
|            |                 |                 |                |
| Extended   | TE28F001BX-T90  | TN28F001BX-T90  | TP28F001BX-T90 |
|            | TE28F001BX-T150 | TN28F001BX-T150 | TP28F001BX-B90 |
|            |                 |                 |                |
|            | TE28F001BX-B90  | TN28F001BX-B90  |                |
|            | TE28F001BX-B150 | TN28F001BX-B150 |                |

### **ADDITIONAL INFORMATION**

|       |                                                 | Order<br>Number |        |                                                                              | Order<br>Number |
|-------|-------------------------------------------------|-----------------|--------|------------------------------------------------------------------------------|-----------------|
|       | "ETOX II Flash Memory<br>Technology"            | 294005          | AP-316 | "Using Flash Memory for In-<br>System Reprogrammable<br>Nonvolatile Storage" | 292046          |
| RR-60 | "ETOX II Flash Memory Reliability Data Summary" | 293002          | AP-341 | "Designing an Updatable BIOS                                                 | 292077          |
|       |                                                 |                 |        | Using Flash Memory"                                                          |                 |



### **REVISION HISTORY**

| Number | Description                                                                                                                                                                                                                                                                 |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -004   | Removed Preliminary classification.                                                                                                                                                                                                                                         |
|        | Latched address A <sub>16</sub> in Figure 5.                                                                                                                                                                                                                                |
|        | Updated Boot Block Program and Erase section: "If boot block program or erase is attempted while RP# is at V <sub>IH</sub> , elther the Program Status or Erase Status bit will be set to "1", reflective of the operation being attempted and indicating boot block lock." |
|        | Updated Figure 11, 28F001BX Erase Suspend/Resume Flowchart                                                                                                                                                                                                                  |
|        | Added DC Characteristics typical current values                                                                                                                                                                                                                             |
|        | Combined $V_{PP}$ Standby current and $V_{PP}$ Read current into one $V_{PP}$ Standby current spec with two test conditions (DC Characteristics table)                                                                                                                      |
|        | Added maximum program/erase times to Erase and Programming Performance table.                                                                                                                                                                                               |
|        | Added Figures 13-16                                                                                                                                                                                                                                                         |
|        | Added Extended Temperature proliferations                                                                                                                                                                                                                                   |
| -005   | PWD changed to RP# for JEDEC standardization compatibility                                                                                                                                                                                                                  |
|        | Revised symbols, i.e.; $\overline{CE}$ , $\overline{OE}$ , etc. to $CE\#$ , $OE\#$ , etc.                                                                                                                                                                                   |
| -006   | Added specifications for -90 and -70 product versions.                                                                                                                                                                                                                      |
|        | Added V <sub>OH</sub> CMOS Specification.                                                                                                                                                                                                                                   |



# APPLICATION NOTE

# Using Intel's Boot Block Flash Memory Parameter Blocks to Replace EEPROM

PETER HAZEN SENIOR TECHNICAL MARKETING ENGINEER

November 1994

# USING INTEL'S BOOT BLOCK FLASH MEMORY PARAMETER BLOCKS TO REPLACE EEPROM

| CONTENTS                                            | PAGE  | CONTENTS                    | PAGE  |
|-----------------------------------------------------|-------|-----------------------------|-------|
| 1.0 INTRODUCTION                                    | 4-343 | 8.0 SYSTEM REQUIREMENTS     | 4-345 |
| 2.0 REVIEW OF FLASH MEMORY                          | 4.040 | 9.0 POWER LOSS              | 4-346 |
| FUNDAMENTALS                                        |       | 10.0 INITIALIZATION         | 4-347 |
| 3.0 SYSTEM OPERATION                                | 4-343 | 11.0 BIT MANIPULATION       | 4-347 |
| 4.0 SOFTWARE SCHEME FOR EMULATING BYTE ALTERABILITY |       | 12.0 TIMING                 | 4-347 |
|                                                     | 4-344 | 13.0 CYCLING                | 4-348 |
| 5.0 PARAMETER DATA<br>STRUCTURE                     | 4-344 | 14.0 CONCLUSION             | 4-348 |
| 6.0 BLOCK TRANSFERS                                 | 4-345 | 15.0 ADDITIONAL INFORMATION |       |
| 7.0 ERASING THE PARAMETER                           | 4.045 | 15.1 References             | 4-348 |



### 1.0 INTRODUCTION

Intel's Boot Block Flash Memories provide updatable code and data storage for a wide range of applications including cellular phones, modems, PC BIOS, automobile engine control and many others. System designers reduce system cost and improve reliability by using Intel's flash memory parameter blocks to replace EEPROM for parameter data storage.

Using software techniques described in this paper, designers can replace EEPROM with Intel's flash memory parameter blocks in many applications that previously used EEPROM for parameter data storage. For example, cellular phone designs use Intel's flash memory parameter blocks to store data such as telephone numbers, time of use and user identification information. Automobile manufacturers use Intel's parameter blocks in engine control applications to store fault codes and engine optimization parameters. In each of these cases, manufacturers save both EEPROM component and inventory costs by using Intel's Boot Block Flash Memory for parameter storage in addition to storing application code. Additionally, improved reliability is achieved with lower system device and pin counts. Finally, the amount and frequency of parameter storage is improved.

This paper describes a linked-list data structure for storing parameters in Intel's flash memory parameter blocks using a scheme that emulates byte alterablility. A review of flash memory fundamentals shows how flash is used in a system and defines the constraints for implementing the software scheme. Reference source code will be available from Intel in the near future.

# 2.0 REVIEW OF FLASH MEMORY FUNDAMENTALS

Flash technology brings unique attributes to system memory. Like RAM, flash memory is electrically modified in-system. Like ROM, flash is nonvolatile, retaining data after power is removed. However, unlike RAM, flash cannot be rewritten on a byte basis. Flash memory reads and writes on a byte-by-byte basis, and adds a new requirement: it must be erased before it can be rewritten. Table 1 shows each flash memory operation, the size of data, and the time it takes for each operation.

Writing (or programming) flash is the process of changing "1"s to "0"s. Erasing flash is the process of changing "0"s to "1"s Flash memory is erased on a block-by-block basis. Blocks are defined by a fixed address range as shown in Intel's 4-M Boot Block Memory Map in

Figure 1. When a block is erased, all address locations within a block are erased in parallel, independent of other blocks in the flash memory device.

Intel's Flash Memory Boot Block products are specified to work over 100,000 cycles when operating at 5V  $V_{\rm CC}.$  A cycle is defined as an Erase operation. For example, if each of the 8 Kbytes in one of the parameter blocks are successively programmed and then the block erased, 1 cycle has completed. This specification is important in determining how many parameters can be stored and how many times those parameters can be updated.

Since flash memory cannot be re-written to the same address location without first erasing an entire block of memory, software techniques are used to emulate byte alterability using the two 8-KB parameter blocks shown in Figure 1.

Table 1. Flash Memory Read, Write and Erase Operations\*

| Operation | Min<br>Segment  | Typical<br>Time | Max<br>Time |
|-----------|-----------------|-----------------|-------------|
| Read      | Byte            | 60 ns           | 60 ns       |
| Write     | Byte            | 10 μs           | 160 μs      |
| Erase     | Block<br>(8 KB) | 0.8 sec         | 4.4 sec     |

\*Specifications for Intel's SmartVoltage 4-M boot block product operating in x8 mode at 5.0V  $V_{\rm CC}$  and 5.0V  $V_{\rm PP}$ . Refer to the SmartVoltage 2/4-M Datasheets.

### 3.0 SYSTEM OPERATION

In addition to storing parametric data, Intel's boot block flash memory is often used to store updatable application code. In many systems, the hardware-lockable boot block stores the kernel code necessary to initialize the system and invoke a recovery routine if code is lost. The boot block also typically stores the code necessary to program and erase the flash memory. (1) Today, flash memory products do not provide the capability to read from one address location in the flash device while writing to another address in the same device. This means any code that writes to flash must be downloaded to RAM.



Program and Erase code for Intel's boot block flash memory products is available on the Intel BBS.





Figure 1. Intel's Boot Block Flash Memory Map



Figure 2. For In-System Write to Flash, Code is Executed out of RAM

# 4.0 SOFTWARE SCHEME FOR EMULATING BYTE ALTERABILITY

By using the two parameter blocks in Intel's boot block components along with software techniques, data can be stored a byte at a time and the Erase operation of flash can be completed as a background task, to emulate byte alterability.

### **5.0 PARAMETER DATA STRUCTURE**

A linked-list data structure provides an arrangement of data that is well-suited to the needs of flash memory. For example, suppose we want to store three parameters that will be updated. We store each parameter in a record. Each record has two fields: parameter\_value and next\_record. The first field contains the value of the parameter. The second field is a pointer containing the address of the next record for that parameter. ParameterX is a pointer variable that contains the address of the first record for that parameter. So Parameter1 represents an address. Stored at that address is the address of the first record of Parameter 1. The first record contains the first Parameter1 value and the address of the second Parameter1 record. The second record contains the latest value for that parameter and the address of the third record, and so on. In the last record, the next record field contains FFH to indicate there are no more records. FFH is used here to indicate no more records, since this is the default state of an erased byte in flash memory. Each time a parameter is updated, the code searches for the first available address location in the parameter block, writes the new value in the value field of the new record, and then updates the next\_record field of the previous record. So, each record includes a value and a pointer, or link to the next record. Such a data structure is called a linked list. By using a linked list the system can quickly find the latest value for a given parameter.

Figure 3 shows an example of the linked-list structure. To simplify the example, a one-byte field is used for both parameter\_value and next\_record. In an actual implementation, at least two bytes would be needed for next\_record, which points to another location in the parameter block. The number of bytes required for parameter\_value will depend on the specific parameter information being stored.



|            |         | ,                                     |
|------------|---------|---------------------------------------|
| Address    | Content |                                       |
| Parameter1 | 01H     | Parameter 1 Pointer variable          |
| Parameter2 | 03H     | Parameter 2 Pointer variable          |
| Parameter3 | 05H     | Parameter 3 Pointer variable          |
| 01H        | F8H     | Parameter 1 value = F8H               |
| 02H        | 07H \   | Parameter 1 next_record = 07H         |
| 03H        | 22H \   | Parameter 2 value = 22H               |
| 04H        | 09Н \   | Parameter 2 next_record = 09H         |
| 05H        | 44H \   | Parameter 3 value = 44H               |
| 06H        | FFH X   | Parameter 3 next_record = FFH = lates |
| 07H        | 55H 🌋   | Parameter 1 value = 55H               |
| 08H        | OBH     | Parameter 1 next_record = 0BH         |
| 09H        | F2H ▲   | Parameter 2 value = F2H               |
| 0AH        | FFH )   | Parameter 2 next_record = FFH = lates |
| овн        | F4H ▲   | Parameter 1 value = F4H               |
|            | FFH     | Parameter 1 next record = FFH = lates |

Figure 3. A Linked List Parameter Record Includes Two Fields: Parameter\_Value and Next\_ Record

An alternative approach to using a linked-list structure, is to define a parameter ID field and a parameter status field that indicates whether the current parameter record is the latest. In this alternate scheme, to retrieve the latest parameter, the system reads through every parameter instance until it finds the latest value for a given parameter.

### **6.0 BLOCK TRANSFERS**

Parameters are stored until the parameter block is filled or until there is not enough memory in the parameter block to store another complete record. When this point is reached, the latest value for each parameter is transferred to the second parameter block, and the linked-list data structure continues in the second parameter block.

A Block\_Header record at the beginning of each parameter block indicates the status of the block. That is, information such as which parameter block is the active block, if the block is transferring data, and if the block is erased.

## 7.0 ERASING THE PARAMETER BLOCK

After the valid parameters are transferred from the first parameter block to the second, the first parameter block is erased. Recall that flash memory requires approximately half a second to erase each parameter block. Since this much time may not be available during system operation. Intel's flash memory products feature an Erase Suspend command. With this command, the Erase operation can be suspended to allow the system to read from another block in the device. When an Erase Suspend command is given to the flash memory, the Erase operation is suspended and the memory enters an erase suspend state where the system can read from another block in the flash memory. When time is available again for erasure, the Erase Resume command instructs the flash memory to continue erase from the point where it previously suspended erase. This allows the Erase operation to be implemented within a finite software loop time, by using multiple calls. Once the first parameter block is completely erased, it is ready to store parameter records after the second parameter block is filled. It is important to note that no new parameters may be written until the Block Erase operation completes. Current boot block flash memories do not allow writes while erase is suspended. See Figure 4 for a review of the parameter storage scheme.

### 8.0 SYSTEM REQUIREMENTS

As described earlier, RAM is required to execute code during program and erase operations. The amount of RAM required depends on the complexity of the parameter storage data base. The code that must be downloaded to RAM includes the flash memory read, write and erase routines. The size of this code is in the range of 512 bytes to 1 Kbyte. In addition, Flash memory space will be necessary to store the program code. Reference code that will be available from Intel, is approximately 15 KB in size. Only a small subset if this, approximately 1 KB, is downloaded to RAM.

Another system requirement is an adequate V<sub>PP</sub> voltage for write and erase. Many of today's flash memory products require 12V to write and erase in-system. Intel's new SmartVoltage products feature 5V Write and Erase operation when 12V is not available.





Figure 4. Using Two Parameter Blocks to Emulate Byte Alterability

### 9.0 POWER LOSS

What if power is lost in the middle of an erase or in the process of updating parameter values? Power loss can be reliably handled by defining additional fields in both the parameter and block records. For example, in addition to the parameter\_value and next\_record fields that we defined for our parameter record, we can define

a parameter\_status field. One status field bit indicates that a parameter update is beginning and another that the parameter update has completed. So, if we lose power in the process of updating a parameter, we know the status of each parameter entry when power is restored. For example, when power is restored, if we find that the status bit reflects that a parameter update began but did not finish, we know that record is invalid and should be discarded. The same concept can be



applied to the block\_status record to handle Erase operations that may be interrupted by power failure as well as parameter transfers between blocks.

### 10.0 INITIALIZATION

An initialization process determines the state of the parameter blocks. By reading the block\_status record you can determine which block is the active block and whether the other block must be erased. Upon the first initialization, the parameter blocks can be erased and the block\_status records created.

### 11.0 BIT MANIPULATION

Earlier, we reviewed how flash memory is read and programmed on a byte-by-byte basis, and erased on a block basis. Intel's flash memory actually has the capability to be programmed one bit (or multiple bits) at a time. Recall flash memory programming is the process of changing "1"s to "0"s. Single bits can be programmed by masking the other bits in a byte or word with "1"s as shown in Figure 5. By taking advantage of this feature, you can minimize the memory space necessary for the various status fields.

| Example 1:<br>1111 1111<br>0111 1111 | Memory Contents<br>Program Data       |
|--------------------------------------|---------------------------------------|
| 0111 1111                            | Resultant Memory Contents             |
| Example 2:<br>0111 1111<br>1011 1111 | Memory Contents<br>Program Data       |
| 0011 1111                            | Resultant Memory Contents             |
| Example 3:<br>0011 1111<br>0001 1111 | Memory Contents<br>Program Data       |
| 0001 1111                            | Resultant Memory Contents<br>292148-5 |

Figure 5. Flash Memory can be Programmed a Bit at a Time by Masking all Other Bits in a Byte with "1"s

### 12.0 TIMING

System timing analysis is required to determine the amount of time available for:

- · Reading parameters
- Downloading write/erase code to RAM
- Writing parameters
- Transferring parameters to a new block
- Erasing a parameter block

Precise timing will depend on the specific system implementation. In addition to the device timing, software overhead timing should be considered.

The time required for reading parameters will depend on the size of each parameter record and the number of parameter record instances that must be read before reaching the valid parameter record. Multiply the number of byte or word reads by the system read cycle time to determine the total time for reading a valid parameter.

Each time a Write or Erase operation is executed on the flash memory, a sub-routine containing the program and erase drivers must first be downloaded to RAM. The time required for downloading this code to RAM depends on the size of the code, which is likely to be 1 KB or less. Multiplying the code size by the write cycle time determines the time for downloading the code to RAM.

To determine the maximum time required for writing a parameter, the worst case word or byte write time is needed for the flash memory component. By multiplying the worst-case word write time by the number of words per parameter record, the worst-case parameter write time can be determined.

The time for transferring valid parameters from one parameter block to the other will, of course, depend on the number of parameters stored. If this operation is completed as a foreground task, a block of time will be required that includes the time to read the valid parameters and write these parameters to the new parameter block. This operation can also be treated as a background task which is often necessary. For applications with a defined main software loop time, the transfer operation can be executed by determining the available time in the main loop, beginning the transfer of parameters and then suspending this task before the main loop time expires. Multiple calls of the main loop are required to completely transfer all parameters to the new block. Total time to complete the task will depend



on the amount of time available in each loop and the number of calls necessary to complete the operation.

Like parameter transfers, block erase can be treated as a foreground or background operation. When treating erase as a background operation, total erase time will depend on the amount of time available in the software loop. Determine the number of calls required by dividing the total erase time by the amount of time available in each call. Multiply the number of calls by the total time per loop to determine the total time for erasing a parameter block.

### 13.0 CYCLING

Intel's flash memory boot block products are specified at 100,000 erase cycles. To determine how this affects your parameter storage, use the equation shown in Figure 6. The equation can be solved for either the number of parameter records or the parameter record size, depending on which variables are known. This implementation provides improved cycling endurance, as compared to EEPROM.



Figure 6. Parameter Storage Equation

### 14.0 CONCLUSION

This paper describes software techniques for emulating byte alterability using two flash memory parameter blocks. System designers reduce system cost and improve reliability by using Intel's boot block parameter blocks for parameter data storage, replacing EEPROM.

### 15.0 ADDITIONAL INFORMATION

### 15.1 References

| Order Number | Document                                                          |
|--------------|-------------------------------------------------------------------|
| 290530       | 2-Mbit SmartVoltage Boot Block Flash Memory Family                |
| 290531       | 4-Mbit SmartVoltage Boot Block Flash Memory Family                |
| 290539       | 8-Mbit SmartVoltage Boot Block Flash Memory Family                |
| 292130       | AB-57 "Intel's Boot Block Architecture for Safe Firmware Updates" |



# APPLICATION BRIEF

# 2/4/8-Mbit SmartVoltage Boot Block Flash Memory Family Overview

COLLIN K. ONG TECHNICAL MARKETING ENGINEER

December 1994

4



### 1.0 INTRODUCTION

This document includes a feature overview, pinouts, and memory maps for Intel's SmartVoltage boot block family, including 2/4/8-Mbit densities. These products offer feature and function compatibility, including the SmartVoltage technology (SVT) outlined below. Follow the design steps in Section 5.0 to upgrade today's designs to SVT.

### 2.0 BOOT BLOCK ARCHITECTURE

Intel's current boot block architecture products offer the familiar features that optimize it for updatable firmware storage. These features include:

- Hardware-lockable boot block for secure kernel code storage
- Parameter blocks for parameter storage
- Main blocks for modular code updates, facilitating updatable firmware
- x8 or x16 user-selectable I/O operation
- RP# for reset and write protection
- PSOP and TSOP packages

Intel is now integrating its SmartVoltage technology into the boot block family in order to increase the flexibility of these components.

## 3.0 PINOUT COMPATIBLE DENSITY UPGRADES

In addition, Intel is committed to providing density upgrades with pinout compatibility for the 2-Mbit, 4-Mbit, and 8-Mbit densities. The pinouts in Figures 2, 3, and 4 illustrate these compatible upgrade paths.



Figure 1. The SmartVoltage Technology Boot Block Line Features a Pinout-Compatible Upgrade Path

## 4.0 NEW SMARTVOLTAGE TECHNOLOGY FEATURES

SmartVoltage offers the following new features:

- 1. Voltage Flexibility
- V<sub>CC</sub> = 3.3V or 5V with enhanced circuits to optimize low-voltage performance when low power consumption is critical.
- Program/Erase operation with V<sub>PP</sub> = 5V for convenient in-system writes without a DC-DC converter or V<sub>PP</sub> = 12V when write/erase performance is a concern, such as during production.
- 2. Write Protection
- WP# pin replaces a DU pin and is used in conjunction with the Vpp and RP# pins, as detailed in the table below, to control write protection of the boot block (see note on PSOP pinout diagram).

| V <sub>PP</sub>     | RP#             | WP#             | Write Protection          |
|---------------------|-----------------|-----------------|---------------------------|
| V <sub>IL</sub>     | Х               | Х               | All Blocks Locked         |
| ≥ V <sub>PPLK</sub> | V <sub>IL</sub> | Х               | All Blocks Locked (Reset) |
| ≥ V <sub>PPLK</sub> | V <sub>HH</sub> | X.              | All Blocks Unlocked '     |
| ≥ V <sub>PPLK</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Boot Block Locked         |
| ≥ V <sub>PPLK</sub> | V <sub>IH</sub> | V <sub>IH</sub> | All Blocks Unlocked       |

### 5.0 UPGRADING FROM 12V TO SVT

If you are designing with 12V V<sub>PP</sub> products today, you must adhere to the following design steps to ensure you can upgrade to SVT:

- If using 5V Program/Erase, allow for connecting Vpp to 5V and disconnecting Vpp from 12V.
- If adding a switch on Vpp for write protection, switch to GND instead of VCC.
- Connect WP# (DU on existing products) to V<sub>CC</sub>, GND, or a control signal. This pin cannot be left floating.



### 6.0 PACKAGE PINOUTS



Figure 2. The 40-Lead TSOP Offers the Smallest Form Factor for Space-Constrained Applications



NOTE:

For the 8-Mbit device, pin 2 has been changed to A18 (WP# on 2/4-Mbit). Designs planning on upgrading to the 8-Mbit density from the 2/4-Mbit density in this package should design pin 2 to control WP# functionality at the 2/4-Mbit level and allow for pin 2 to control A<sub>18</sub> after upgrading to the 8-Mbit density.

Figure 3. The 44-Lead PSOP Offers a Convenient Upgrade from JEDEC ROM Standards





Figure 4. The 48-Lead TSOP Offers the Smallest Form Factor for x16 Operation



Figure 5. The 56-Lead TSOP Offers Compatibility between 2 and 4 Mbits



### 7.0 MEMORY MAPS



Figure 6. Byte-Wide x8-Mode Memory Maps (Top Boot)



Figure 7. Byte-Wide x8-Mode Memory Maps (Bottom Boot)





Figure 8. Word-Wide x16-Mode Memory Maps (Top Boot)



Figure 9. Word-Wide x16-Mode Memory Maps (Bottom Boot)



### 8.0 PRODUCT OFFERINGS

### **Existing Boot Block Products**

| Product  | Density x Org.       | Pkg.    | Speed (ns)<br>(V <sub>CC</sub> = 5V) | Speed (ns)<br>(V <sub>CC</sub> = 3.3V) | Extended Temp. | Avail. |  |
|----------|----------------------|---------|--------------------------------------|----------------------------------------|----------------|--------|--|
| 28F001BX | 1 Mb, 128Kx8         | P, N, E | 70, 90, 120, 150                     |                                        | ~              | Now    |  |
| 28F200BX | 2 Mb, 256Kx8/128Kx16 | PA, E   | 60, 80, 120                          |                                        | ~              | Now    |  |
| 28F002BX | 2 Mb, 256Kx8         | E       | 60, 80, 120                          |                                        | <i>V</i>       | Now    |  |
| 28F200BL | 2 Mb, 256Kx8/128Kx16 | PA, E   | (1)                                  | 150                                    | <b>⊿</b> (2)   | Now    |  |
| 28F002BL | 2 Mb, 256Kx8         | Е       | (1)                                  | 150                                    | <b>(</b> 2)    | Now    |  |
| 28F400BX | 4 Mb, 512Kx8/256Kx16 | PA, E   | 60, 80, 120                          |                                        | . ~            | Now    |  |
| 28F004BX | 4 Mb, 512Kx8         | Е       | 60, 80, 120                          |                                        | ν.             | Now    |  |
| 28F400BL | 4 Mb, 512Kx8/256Kx16 | PA, E   | (1)                                  | 150                                    | <b>∠</b> (2)   | Now    |  |
| 28F004BL | 4 Mb, 512Kx8         | Е       | (1)                                  | 150                                    | <b>∠</b> (2)   | Now    |  |

### NOTES:

<sup>1.</sup> The BL products also operate at 5V V<sub>CC</sub> for programmer compatibility. 2.  $-20^{\circ}\text{C} - +70^{\circ}\text{C}$  operating range for Read-Only available Q4'94.



### **SmartVoltage Boot Block Products**

| Product  | Density x Org.        | Pkg.   | Speed (ns)<br>(V <sub>CC</sub> = 5V) | Speed (ns)<br>(V <sub>CC</sub> = 3.3V) | Extended<br>Temp. |
|----------|-----------------------|--------|--------------------------------------|----------------------------------------|-------------------|
| 28F200BV | 2 Mb, 256Kx8/128Kx16  | 44, 56 | 60, 80, 120                          | 110, 150, 180                          | <i>1</i>          |
| 28F200CV | 2 Mb, 256Kx8/128Kx16  | 48     | 60, 80, 120                          | 110, 150, 180                          | 10                |
| 28F002BV | 2 Mb, 256Kx8          | 40     | 60, 80, 120                          | 110, 150, 180                          | 1/                |
| 28F400BV | 4 Mb, 512Kx8/256Kx16  | 44, 56 | 60, 80, 120                          | 110, 150, 180                          | ν.                |
| 28F400CV | 4 Mb, 512Kx8/256Kx16  | 48     | 60, 80, 120                          | 110, 150, 180                          | 10                |
| 28F004BV | 4 Mb, 512Kx8          | 40     | 60, 80, 120                          | 110, 150, 180                          | <i>V</i>          |
| 28F800BV | 8 Mb, 1024Kx8/512Kx16 | 44     | TBD                                  | TBD                                    | <i>V</i>          |
| 28F800CV | 8 Mb, 1024Kx8/512Kx16 | 48     | TBD                                  | TBD                                    | <i>ν</i>          |
| 28F008BV | 8 Mb, 1024Kx8         | 40     | TBD                                  | TBD                                    | "                 |

### NOTE:

1. BV products also operate at 5V V<sub>CC</sub> for programmer compatibility.



Figure 10. Decoding the Product Names



# APPLICATION NOTE

# Designing an Updatable BIOS Using FLASH Memory

BRIAN DIPERT
DON VERNER
MCD MARKETING APPLICATIONS

October 1993

# **Designing an Updatable BIOS Using Flash Memory**

| CONTENTS                                                                                                                                                                                                                                                                                                                                                                                                                                      | PAGE                                                 | <b>CONTENTS</b> PAGE                                                                                                       | :       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|---------|
| 1.0 INTRODUCTION                                                                                                                                                                                                                                                                                                                                                                                                                              | 4-359                                                | 4.0 SOFTWARE DESIGN CONSIDERATIONS                                                                                         | ,       |
| 2.0 FLASH MEMORY  2.1 EPROM Roots; Review of Flat Process vs. EPROM & EEPROI   2.2 Program and Erase Automatic   2.3 Blocked Architecture   2.4 Deep Powerdown Mode   2.5 28F001BX Pinouts, Physical   Layout and Upgrade   Plastic Dual-In Line   Plastic Leaded Chip Carrier   Thin Small Outline Package   2.6 V <sub>PP</sub> Specifications   Fixed V <sub>PP</sub> and V <sub>CC</sub> RP#, V <sub>CC</sub> and V <sub>PP</sub> Lockout | sh<br>M 4-359<br>on 4-359<br>4-360<br>4-361<br>4-362 | 4.1 Update Software for a Modified System                                                                                  | 3 1 1 5 |
| Protection  3.0 HARDWARE DESIGN CONSIDERATIONS                                                                                                                                                                                                                                                                                                                                                                                                | 4-366                                                | 4.7 Power Management 4-379  5.0 SUMMARY 4-380                                                                              | •       |
| 3.1 BIOS Boot Code Requirement<br>and System Configurations                                                                                                                                                                                                                                                                                                                                                                                   | 4-367<br>on                                          | 5.1 Traditional BIOS Storage and Disadvantages                                                                             | )       |
| Security Using a MOSFET Switch 3.3 Modifying an Existing Motherboard                                                                                                                                                                                                                                                                                                                                                                          | 4-370<br>s                                           | APPENDIX A—Software Routines 4-381  APPENDIX B—MS-DOS ROM Version Overview 4-397  APPENDIX C—BIOS Vendor Information 4-398 | 7       |
| 3.4 In-System Write vs. On-Board Programming  3.5 Ideas for Using Extra Adaptor Space                                                                                                                                                                                                                                                                                                                                                         | 4-371                                                | APPENDIX D—Microprocessor/ Microcontroller Compatibility Chart                                                             | Э       |



### 1.0 INTRODUCTION

As PC computing platforms increase in complexity, so does the associated BIOS code. Sophisticated hardware and BIOS software increase the potential for revisions. Time-to-market goals require faster completion of designs from conception to production, leaving less time for new-peripheral BIOS support. As an example, many 80286-based PC/ATs lack BIOS support for  $3\frac{1}{2}$ " floppy drives! Once a computer is out the door, code revisions are far more difficult and costly. Code revisions with EPROM require either a service call or sending EPROMs to the end user, assuming nothing else goes wrong in the process. The alternative to BIOS update is a prematurely obsolete system, unable to support new industry standards and peripheral systems.

Flash memory offers the same nonvolatile storage as EPROM, but additionally offers in-system write capability. Using Intel's 28F001BX for BIOS storage, code updates are done quickly in the factory during test and debug, while allowing cost-effective field updates to end users via floppy disks or modem BBS.

This application note describes various methods of implementing a flash memory BIOS using the 28F001BX. Design targets are both laptop and desktop systems. The primary emphasis is on application of flash memory for BIOS and ROM executable software applications. Detailed 28F001BX information is covered in the datasheet, available through your local sales office.

### 2.0 FLASH MEMORY

This section provides a brief overview of Intel's Flash Memory and in particular, Intel's 28F001BX blocked flash memory family. It covers the following:

- Flash memory's EPROM roots
- Program and Erase Automation
- Blocked Architecture
- Deep Powerdown Mode
- Pinouts, physical layout and upgrade for different packages
- V<sub>PP</sub> specifications

Major features of the 28F001BX are in-system write, selective block erase, program/erase automation, SRAM-like command interface, deep powerdown capability, fixed  $V_{CC}$  and  $V_{PP}$  supplies and hardware lock-out protection.

# 2.1 EPROM Roots; Review of Flash Process vs EPROM & EEPROM

Intel's ETOX II (EPROM Tunnel OXide) flash memory is a single-transistor cell providing nonvolatile

storage like EPROM, with electrical erase similar to EEPROM. Reprogramming flash memory entails electrically erasing all data bits in parallel, then randomly programming data into any byte in the array. The programming operation is achieved via channel hot electron injection (CHE), just like EPROMs. Flash electrical erasure, however, is accomplished through Fowler-Nordheim (FN) tunneling. Using separate program and erase methods (CHE vs. FN Tunneling), in different cell locations, drain vs. source, permits process optimization for high cycling endurance—the number of complete erase and re-writes. Traditional low-density EEPROMs tunnel through the same memory cell junction for both programming and erasure. Because EEPROMs erase before programming each byte, these processes must occur very fast. Therefore, internal voltages used to program or erase 5V-only EEPROM memory cells are high (e.g., 18V-30V). The combination of higher voltage with programming and erasing through the same junction contributes to EEPROM's oxide breakdown, poor data retention and reduced cycling capability.

Intel's flash memory erasure (tunneling) voltage is below the critical oxide breakdown voltage. By using block erasure instead of EEPROM's byte erasure, erase times are relaxed, reducing tunneling voltages. Programming Intel's Flash Memory is non-destructive to the floating gate oxide compared to EEPROM's use of tunneling for programming. These features for erase and programming provide Intel's Flash Memory with the highest endurance (typically over 100K cycles) compared to that of traditional EEPROM cycling. Furthermore, flash memory exhibits lower failure rates at any given cycle count.

### 2.2 Program and Erase Automation

The 28F001BX integrates a Write State Machine (WSM) on-chip to internally implement program and erase algorithms. Operations are initiated through command sequence writes to the Command Register, and progress is reported back to the user through Status Register bits. Software timers are no longer required, as timing is now regulated through the on-chip oscillator. System software requirements are decreased in comparison to past algorithms, minimizing overhead and development effort, and allowing code execution and interrupt servicing while simultaneously programming or erasing the device.

The Erase Suspend command halts block erase to execute code or read data from any other block. This feature gives the system the capability to service higher level interrupts requiring data from the 28F001BX during the erase interval. After issuing the Erase Resume command, the WSM continues erase where it left off when suspended.





Figure 1. 28F001BX Memory Maps

### 2.3 Blocked Architecture

The 28F001BX family combines the safety of a hardware-protected 8 Kbyte "boot" block with the flexibility of two 4 Kbyte "parameter" blocks and one 112 Kbyte main block. Each block can be individually erased and programmed without affecting code stored in another block, ensuring data integrity. The boot block is intended to contain secure code which minimally will bring up the system and download code to the other blocks of the 28F001BX if required. Once programmed, it is hardware-locked from further alteration, guaranteeing true non-volatility.

The 28F001BX-T's lockable block location provides compatibility with microprocessors and microcontrollers that boot from the top of the memory map, such as many of Intel's microprocessor families. The seg-

mentation of the 28F001BX-B is identical. Its lockable block location provides compatibility with microprocessors that boot from low memory, such as Motorola and AMD products. See Figure 1 for illustrations of the two memory maps available in the 28F001BX family.

The two 4 Kbyte parameter blocks have multiple uses in BIOS environments. They can be used to back up the CMOS setup parameters such as floppy and hard disk type, processor speed, system memory size, graphic display type and presence of a coprocessor. Today, should the system battery fail, the user loses information in battery-backed SRAM. The non-volatile parameter blocks provide the system capability to automatically back up and recover this information. Also, EISA systems can store software variable information such as add-in board addresses, DMA channels and interrupt values/levels.





Figure 2. 28F001BX DIP Pin Configuration

### 2.4 Deep Powerdown Mode

Market analysts predict that the high-growth segments of the PC industry for the next several years will be in the laptop, palmtop and handheld product lines. Power management software is becoming an integral part of PC system BIOS as manufacturers attempt to squeeze the maximum amount of system operation time from their battery pack power supplies. A key indicator of this trend is Intel's i386TMSL microprocessor superset, which adds hardware power management to the Intel 386 architecture and answers the needs of low-power applications.

The 28F001BX family features deep powerdown capability and is ideally suited for these same battery-operated systems. Powerdown is entered through low voltage on the RP# pin. Typical power consumption through  $V_{\rm CC}$  in powerdown is 0.25  $\mu$ W, regardless of power supply voltages and activity on the external bus. Once BIOS is shadowed to system DRAM for high-speed execution, the 28F001BX can be shut down for minimal current drain.

This same pin, with 12V present on it, gates program and erase of the boot block. Such a hardware lockout preserves the system boot code once initially programmed and protects it from inadvertent alteration or computer virus compromise.





Figure 3. 28F001BX PLCC Lead Configuration

# 2.5 28F001BX Pinouts, Physical Layout and Upgrade

Intel's 28F001BX is offered in three standard 32-pin packages: Plastic Dual In-line Package (PDIP), Plastic Leaded Chip Carrier (PLCC), and Thin Small Outline Package (TSOP). All three pinouts provide backward compatibility with Intel's 28F010 bulk-erase flash. See Figures 2, 3, and 4 for pinout details.

### Plastic Dual In-Line Package

PDIPs with sockets provide an excellent way to prototype and debug new designs. The 28F001BX is backward pin-compatible with 1 Mbit standard flash and EPROMs.

### **Plastic Leaded Chip Carrier**

Most system designs today require surface mount technology (SMT) due to shrinking board real estate and portable form factors. PLCC is one SMT component that uses as little as 35% of the overall board space compared to PDIP. Its small size is attributed to the center-to-center lead spacing of 50 mils versus 100 mils, as well as its four-sided pinout. The J-lead design allows the PLCC to be directly soldered to the circuit board. Most SMT manufacturing equipment can easily handle the PLCC's 50-mil lead pitch. PLCC SMT sockets such as that offered by AMP (P/N 821977-1) have an identical foot-print for 32-pin devices. Such sockets can be used in place of directly soldering a PLCC for prototype build and code testing. Once the reprogramming code is tested and debugged, flash PLCCs can then be surface-mounted without socketing during production runs.



### Thin Small Outline Package

TSOP is the package of choice for hand-held equipment or palmtop/laptop computers. These compact systems require minimal height and area for all components, for which TSOP excels. TSOP height measures 1.2mm versus 3.5mm for PLCC. TSOP area is 8mm x 20mm compared to PLCC's 11.43mm x 13.97mm. Therefore, TSOP has significantly less total volume: TSOP = 172.8mm³, while PLCC = 656.3mm³, and DIP = 1872.3mm³. State-of-the-art center-to-center terminal spacing of 20 mils yields a smaller package with narrower conductor traces than PLCC or PDIP. Location

of pins on both ends of the package allows traces for TSOP to be routed underneath the chip, reducing board layers. TSOP for the 28F001BX is available in the standard (E) pin configuration. For multiple chip flash systems, Intel's bulk-erase 28F010 flash memory is available in both standard (E) and reverse (F) pin configurations (see Figure 5) allowing components to be laid out end-to-end and side-to-side for highest board density (see Figure 6). Note how pins 32–17 on the standard pinout match pins 1–16 on the reverse pinout, and how pins 1–16 on the standard pinout match pins 32–17 on the reverse pinouts.



Figure 4. 28F001BX TSOP Lead Configuration





Figure 5. 28F010 Standard and Reverse TSOP Lead Configurations





Figure 6. 28F001BX and 28F010's in Serpentine Layout Using TSOPs

### 2.6 V<sub>PP</sub> Specifications

### Fixed V<sub>PP</sub> and V<sub>CC</sub>

Flash memories, like EPROMs, require a 12V programming power supply. Unlike EPROMs, however, the Vpp for flash memory is a fixed, standard level. When combined with the Command Register erase/program control, Intel flash memories use a simple, SRAM-like hardware interface with standard microprocessor timings.

Intel's Flash Memory  $V_{PP}$  specification is 12.0V  $\pm 0.6V$  (5%), compatible with most off-the-shelf system power supplies. The IBM PC technical reference manual specifies the 12V power supply at 12.0V, +5% and -4%. Additionally, some hard and floppy drives require 12V  $\pm 5\%$ . Therefore, most PC power supplies have 12V supplies with  $\pm 5\%$  or better tolerance. Possi-

ble exceptions to this are laptop and/or palmtop PCs. Some of these require 5V-only designs, in which case 5V is charge-pumped to 12V. It is essential to use the specified Vpp when programming and erasing flash. Once the commands to program or erase are issued, the device internally derives the required voltage references from the Vpp supply. Therefore, an improper Vpp level degrades the performance of the part.

The Write State Machine automatically monitors the voltage present on the  $V_{PP}$  pin, beginning when program or erase setup commands are issued and continuing throughout the internal algorithm interval. If low  $V_{PP}$  is detected, the WSM automatically aborts the program or erase attempt and reports an improper voltage error to the user through the Status Register. The hardware design section discusses various methods of  $V_{PP}$  generator if your 12V power supply does not meet the proper tolerances or 12V is not available.



### RP#, VCC and VPP Lockout Protection

The RP# (Resert/Powerdown) pin provides hardware write protection for 28F001BX flash memories. Until this pin transitions to TTL-level V<sub>IH</sub>, write attempts to the device Command Register are ignored, regardless of power supply levels or activity on the system bus and control inputs. Typically, the system designer will gate this signal with a system POWER GOOD indicator output to ensure system stability before memory accesses begin.

The 28F001BX family provides additional protection for designs that tie 12V directly to the device. Since the 12V supply is less capacitively loaded than the 5V supply, the 12V power supply reaches full value faster during power-on. If Command Register lockout protection was not provided, a finite possibility exists that inadvertent writes may occur during power-on. For this case, Intel's 28F001BX flash memory supplies Command Register lockout protection when V<sub>CC</sub> is below 2.5V, preventing writes to flash memory from occurring. Since CMOS logic is valid at 2.0V, a 0.5V margin of protection exists, providing extra time for control signals to settle before the Command Register is activated. Program/erase inhibit is guaranteed with VPP below 6.5V, with corresponding  $V_{PP}$  low reported through the Status Register. Once  $V_{CC}$  reaches 2.5V, the Command Register begins processing valid commands, and program/erase attempts may initiate with Vpp greater than 6.5V. At this point, the system is responsible for write control.

When the 28F001BX  $V_{CC}$  powers up, or after the RP# pin transitions to  $V_{IL}$  and back to  $V_{IH}$ , the Command Register is automatically initialized to Read Array mode.

# 3.0 HARDWARE DESIGN CONSIDERATIONS

The system level hardware requirements for implementing BIOS and application storage in flash are:

- Write Enable available to all of the flash memory
- 12V routed to flash location or generated on-board
- CMOS control-signal interface, or RP# gated by a power-good signal
- Data buffer or transceiver that works in both write and read directions
- Space in memory map allocated for each application's size

Intel's i386SL microprocessor superset was chosen for the design example, shown in Figure 7. The Intel386SL microprocessor superset integrates all major components of a Intel386 based design on two chips, including bus memory, cache controllers and the ISA peripheral subsystem. Additionally, it consolidates hardware power management for battery-operated designs such as laptop, handheld and palmtop computers.

Note the clean interface between the superset and 28F001BX-T. Flash memory was comprehended early in the design of the Intel386SL microprocessor superset, to ensure a minimal-chip interface. Transceivers for the system bus, as well as a flash memory CE# signal, are integrated on the Intel386SL.



Figure 7. Intel386SL Microprocessor Superset with 28F001BX-T Flash BIOS



The RP# pin is gated by a power good signal to ensure control logic integrity before writes to the 28F001BX-T are allowed. It is also gated by System Reset, to abort program or erase if required for CPU reboot, and by a separate General Purpose Input-Output (GPIO) line to power down the device once BIOS is shadowed to RAM. CMOS logic will guarantee lowest power dissipation.

Similarly, system 12V is gated both by System Reset and a GPIO line. Software can switch 12V to the 28F001BX-T only when programming or erasing it, minimizing system power consumption. Vpp generation and switching methods are discussed in Section 3.3.

Application code, assuming a ROM in the BIOS socket, is sometimes designed to write to BIOS locations to generate software timing delays (versus using NOPs). Gating WR# to the flash memory with a GPIO line disables writes until desired by BIOS update software.

# 3.1 BIOS Boot Code Requirements and System Configurations

The previous design assumed that shadow RAM was available in the system. Referencing Figure 8, we see that the BIOS is actually stored in the main block of the 28F001BX, from system address E0000H-FBFFFH. In this scenario, the processor jump vectors, BIOS checksum and recovery code are stored in the 8 Kbyte boot block. This is the area the processor will jump to on powerup or after reset. The boot block code will execute a checksum check of the main block for a valid BIOS. If successful, the processor will check system RAM, copy the main block code to high memory DRAM and jump to this area for the remainder of

Power On Self Test (POST), as well as further BIOS calls. Optionally, the 28F001BX can then be disabled for power savings.

If BIOS checksum determines an invalid BIOS, the system RAM and floppy drive (or possibly modem) are initialized using the boot block recovery code. The system requests (through screen display or speaker "beeps") that the user install the BIOS update floppy disk. A search of the floppy disk is made for a specific file name, and once found, update code is used to re-initialize the main BIOS block. System reboot restores normal operation. Alternatively, the BIOS recovery code can contain specific, non-DOS sector/track information pertaining to the location of the new BIOS update file. Thus, the file is protected and not readable to basic DOS users.

If ROM BIOS disable is overriden by system software or the user (through setup utility), the design must compensate for the altered BIOS location to prevent BIOS calls jumping to incorrect code locations. The following two methods provide alternative solutions for the system designer.

### **Address Shift Configuration**

In this scenario, after BIOS initialization is complete, a write to a latch, register or flip-flop shifts addresses for future BIOS code fetches by 16 Kbytes. This allows the system to correctly access the main block and bypass parameter and boot blocks. A system reset or loss of power clears this latch, allowing booting from the boot block once again. Figure 9 shows the input and output signals required for a µPLD address shifter. It shifts addresses in the range FFFFFH-E4000H (112 Kbytes) to FBFFFH-E0000H.



Figure 8. 28F001BX-T in 1 Mbyte DOS Memory Map





Figure 9. Address Shift Circuitry

### **Address Inversion Configuration**

Figure 10 presents an alternative approach to configuring the 28F001BX in the system memory map. Simple inversion of address line A<sub>16</sub> to the 28F001BX moves the boot block to the lower half of flash memory as seen by the system. In normal operation, the processor boots and executes from the main array areas, which store the system BIOS, video BIOS and/or DOS in ROM.



Figure 10. Inversion Configuration (Normal)

If power loss aborts a BIOS update, the main array block will be partially programmed/erased and the code in this block unusable. The system will "hang" or not boot at all. To boot from the boot recovery block, restore address  $A_{16}$  polarity, producing the memory map shown in Figure 11. A keyboard sequence, switch on the back of the PC or jumper on the motherboard can toggle  $A_{16}$  restore logic and "un-invert" it. After reconfiguration, the processor boots from the boot block and executes its recovery algorithm to restore main array block contents. Re-inverting  $A_{16}$  reinstates normal system bootup and operation.



Figure 11. Inversion Configuration (Recovery)

Since standard BIOS code does not support boot block recovery, your BIOS software engineers must design the recovery code for the 8 Kbyte block. See Section 4.6 for a flowchart of an example recovery algorithm. Third-party BIOS vendors, working with Intel, have also developed recovery code for the 28F001BX (see Appendix C). With the exception of this recovery section, the rest of the BIOS remains the same.



### 3.2 Vpp Generation

For flash BIOS designs, the 12V V<sub>PP</sub> can be provided by:

- 1. Using the existing 12V supply from PC Power Supply, or
- 2. Generating 12V using a charge pump or DC-DC converter from the 5V supply.

Flash typically requires only 10 mA for program or erase (30 mA max); otherwise only 10  $\mu$ A is drawn in standby mode, and 0.8  $\mu$ A in deep powerdown mode.

### **Using System 12V Directly**

As stated earlier, the IBM PC technical reference manual specifies the 12V supply as +5% and -4%, which meets the Intel Flash Memory  $V_{PP}$  requirement. If your power supply meets this condition and has CMOS logic, 12V from the PC power supply can be tied directly to flash memory, eliminating the need to add extra

circuitry for  $V_{PP}$  generation. This is possible due to the RP#,  $V_{CC}$  and  $V_{PP}$  write lockout protection offered in the 28F001BX.

### Pumping 5V to 12V

If your system does not provide 12V or does not meet flash memory specifications, several 5-to-12V converters are available, including surface-mount versions. Application Note AP-316, available from your local Intel Sales Office, lists several VPP solutions which offer on/off control of Vpp and provide a steady Vpp rise and little overshoot. Figure 12 shows one example. On power-up, system reset or when V<sub>CC</sub> is below 4.5V, V<sub>PP</sub> is forced off. It is enabled (or disabled) by writing to the VppEN# I/O port address. On/off capability is essential for battery-operated equipment and eliminates the need for WE# filtering. The VppEN# signal "OR'ed" with the system memory write (MEMWR#) functions as the clock signal for the 74FC74 D-flipflop. The D-input is latched when MEMWR# goes high. Writing a one or a zero turns Vpp on or off, respectively.



Figure 12. Vpp Generation with Write Protection



Linear Technology's LT1072, a switching regulator, is used as a 5V to 12V charge pump. The 10.7K and 1.24K resistors are used to establish the correct reference voltage to obtain 12V. The 100 µF capacitor at the output can handle up to 200 mA. For a single- or double-chip BIOS design, this capacitor value can be halved or even quartered to allow selection of a SMT capacitor value, since the maximum Ipp current per device is only 30 mA (10 mA typical). Allow sufficient time when switching Vpp on, letting the charge pump level out and enabling the Command Register to receive program or erase commands. The diode, MUR120, keeps the inductor from absorbing current from the charged output capacitor.

### Security

Controlling V<sub>PP</sub> provides the benefit of system hardware security. Beyond this, you can design for even higher security levels. The first level could be the design of a simple software password routine that would only turn on V<sub>PP</sub> when a correct password is given. Alternatively, you can provide a jumper to allow 12V to the part for a BIOS update and then return it when reprogramming is finished. The system should check this pin to see if the jumper was left in the programming position and remind the user to move it. Unless V<sub>PP</sub> is at 12V, the flash memory contents cannot be changed and acts just like ROM. Disabling V<sub>PP</sub> until voltages have stabilized provides additional power-up protection.

The Motorola component, MC34064, is an under-voltage sensing circuit that begins functioning when  $V_{CC}$  is above 1V. Between 1V and 4.6V, the RESET# output is active. This (or a system RESET#) clears the 74FC74, keeping V<sub>PP</sub> off. Alternatively, if you use CMOS logic, you could make use of Intel's flash memory V<sub>CC</sub> and V<sub>PP</sub> lockout functions. While V<sub>CC</sub> is below 2.5V, the Command Register is locked out. Since CMOS control logic is active at 2.0V, a 0.5V safety margin exists for control logic to settle down before the part becomes active. Program and erase attempts are inhibited with V<sub>PP</sub> below 6.5V. For both CMOS and non-CMOS designs (i.e., control logic active at 2.0V), gate RP# with the power supply's "Power Good" signal or the MC34064's RESET# output (Figure 13). Until RP# transitions to VIH, the part ignores all write attempts, regardless of power supply voltages and bus activity.



Figure 13. Vpp Switch Using MTD4P05

### Using a MOSFET Switch

For laptops or palmtops, an always-active 12V may not provide acceptable power management. For these systems, a MOSFET switch will toggle 12V to the flash memory, minimizing current draw when not needed. Several DC switches exist, but there are a few issues to consider in your selection. Choose a switch with low "ON" resistance to keep the Vpp voltage within flash memory tolerances. The system 12V power supply must be specified to a tighter range to allow for any voltage drop through the switch. Allocate an I/O line (V<sub>PP</sub> enable) to turn the switch on and off. To handle "warm RESETS", the VPP enable must be gated with the system RESET# line. The Motorola MTD4P05 is one example of a surface-mount switch with low drainsource resistance. Assuming a 12V + 5% and -4%supply:

$$\begin{array}{ll} R_{DS} = & 0.6\Omega \\ I_{PP} = & 30 \text{ mA (Worst Case)} \\ \Delta V_{SWITCH} \, Drop = & (30 \text{ mA x } 0.6\Omega) = 0.02V, \\ & \ll & (4\% \text{ of } V_{PP} =) \, 0.48V. \end{array}$$

Figure 13 shows a schematic of a V<sub>PP</sub> switch design.

## 3.3 Modifying an Existing Motherboard

### **EPROM/ROM Designs**

If you are modifying an existing motherboard design for a flash memory BIOS, there are a few things you should consider. First, check the logic design to determine if WR# is decoded and connected to the BIOS EPROM location. Typical motherboard logic designs do not allow writes to the EPROM locations and treat EPROM writes as invalid (e.g., ROMCS# not generated with MEMWR#). This is overcome by generating the BIOS location's WR# externally by either adding the necessary discrete logic or adding a 3-to-8 decoder (see Figure 14 for an example). In either case, tap into the M/IO# and WR# control lines and configure the decoder to provide a logic low for the M "AND" WR# "AND" BIOS address condition.





Figure 14. Discrete and Single-Chip Decoder WE # Solutions

Secondly, check to see if the BIOS code transceiver or buffer for the EPROM location works in both directions. The transceiver may need a special BIOS call to unlock it in the "write" direction, or you may have to reprogram the logic for that portion of your board. If your chip set data buffer works only in one direction, a transceiver and direction logic must be added to the CPU bus to pass data to and from flash memory.

Your system must also be capable of routing 12V to the BIOS socket for program and erase. Control RP# with system RESET# and POWERGOOD (see Section 3.0) and optionally provide capability for deep powerdown mode via an I/O line. Finally, address inversion or shift mechanisms outline in Section 3.1 can optionally be added for recovery capability with the 28F001BX.

### 28F010 Flash Memory Designs

If your design currently incorporates Intel's 28F010 flash memory, hardware upgrade to the 28F001BX is simple. Transceiver, BIOS write and Vpp requirements will have already been considered in the original design. Control RP# as described in Section 3.0. Finally, invert or shift the system addresses as in Section 3.1 if BIOS "ROM" access after shadowing to DRAM is anticipated.

# 3.4 In-System Write vs On-Board Programming

When devices are soldered directly to a printed circuit board, one of two sources control flash memory reprogramming:

- 1. the system's own processor, or
- 2. a PROM programmer connected to the board.

These options are called In-System Write (ISW) and On-Board Programming (OBP), respectively. Their respective benefits are discussed in detail in AP-316.

With ISW, the system drives the reprogramming process and generates V<sub>PP</sub> locally. Under this scenario, the board manufacturer will initially program at least the boot block in a PROM programmer. This removes the need for circuitry on-board to unlock the boot block, guaranteeing boot code integrity throughout system life. A good design practice for ISW-type designs is to socket the first few flash BIOS prototypes. SMT-only designs can also socket using PLCC SMT sockets. Socketing enables the system designer to easily work out any bugs with in-system flash reprogramming by allowing the removal of a flash part for external reprogramming in a PROM programmer. Once ISW reprogramming is fully debugged, pre-programmed flash parts can be soldered directly to the circuit board without a socket. All flash memory components are exposed to a data-retention bake testing and checked for any data loss before shipping. It is extremely unlikely that data in a production flash device can be corrupted from heat by a production-run soldering application.



OBP uses an external board programmer to supply V<sub>PP</sub> and V<sub>HH</sub> and control the programming process. Certain design considerations must be evaluated prior to laying out the design. Some manufacturers using TSOP may also want to remove a handling step from the manufacturing process by providing the capability to program flash for the first time after being soldered directly onto the circuit board. OBP can accomplish this if the design is first laid out correctly to support OBP. External circuitry generates voltages needed to unlock and program/erase the boot block.

# 3.5 Ideas for Using Extra Adaptor Space

Laptop and palmtop systems may have adaptor space available in the system memory map since there typically isn't much room for add-in boards. Additionally, they may not use up the entire 128K of BIOS space due to their fixed feature set and limited upgrade capability. This extra memory space can hold ROM executable programs like Lotus 123, WordPerfect, Microsoft Works, etc. Using Intel's flash TSOPs, a small application cache can reduce a laptop's disk access and increase battery life.

Additionally, ROM-Executable DOS can be placed anywhere in adapter space. For example, MS-DOS ROM Version 3.22 requires 62 KB of adaptor space today (this may change on subsequent revisions). One location for MS-DOS ROM Version 3.22 is directly un-

der the BIOS (again see Figure 8). Today's typical BIOS consumes 64 KB or less; consequently, both the BIOS and MS-DOS ROM Version 3.22 could reside in a single 28F001BX (128 Kbytes), yielding reduced chipcount. However, if power management code is added to the BIOS, system BIOS code could grow to 80 KB or more. Therefore, designs that include both power management and MS-DOS ROM Version 3.22 should consider using both a 28F001BX and 28F010 flash device (or two 28F001BX's). This leaves extra space for BIOS and MS-DOS ROM to grow in the design, while providing additional storage for the video BIOS.

### 4.0 SOFTWARE DESIGN CONSIDERATIONS

Intel's Flash Memory provides a cost-effective, updatable, nonvolatile code storage medium. The 28F001BX integrates the Quick-Pulse Programming and Quick-Erase algorithms of prior Intel Flash Memories onchip, using the Command Register, Status Register and Write State Machine (WSM). On-chip integration dramatically reduces system overhead, simplifies system software creation and debug and provides SRAM-like timings to the Command and Status Registers. WSM operation, internal program/erase verify and Vpp high voltage presence are monitored and reported via appropriate Status Register bits. Table 1 lists the 28F001BX command set, while Table 2 details the Status Register bits and their meanings.

| Table 1. | 28F001BX | Command | <b>Definitions</b> |
|----------|----------|---------|--------------------|
|          |          |         |                    |

| Table 11 201 00 IDA Communia Deminione |               |         |           |           |      |           |           |      |  |
|----------------------------------------|---------------|---------|-----------|-----------|------|-----------|-----------|------|--|
| Command                                | Bus<br>Cycles | Notes   | First     | Bus Cycle |      | Secon     | d Bus Cyc | le   |  |
|                                        | Req'd         | 1, 2    | Operation | Address   | Data | Operation | Address   | Data |  |
| Read Array/Reset                       | 1             |         | Write     | Х         | FFH  | 4         |           |      |  |
| Intelligent Identifier                 | 3             | 1, 2, 3 | Write     | Х         | 90H  | Read      | IA        | IID  |  |
| Read Status Register                   | 2             | 2       | Write     | Х         | 70H  | Read      | Х         | SRD  |  |
| Clear Status Register                  | 1             |         | Write     | Х         | 50H  |           |           |      |  |
| Erase Setup/Erase Confirm              | 2             | 1       | Write     | ВА        | 20H  | Write     | ВА        | DOH  |  |
| Erase Suspend/Erase Resume             | 2             |         | Write     | Х         | вон  | Write     | X         | D0H  |  |
| Program Setup/Program                  | 2             | 1, 2    | Write     | PA        | 40H  | Write     | PA        | PD   |  |

### **NOTES:**

- 1. IA = Identifier Address; 00H for manufacturer code, 01H for device code.
  - BA = Address within the block being erased.
- PA = Address of memory location to be programmed.
- 2. SRD = Data read from Status Register. See Table 2 for a description of Status Register bits.
  - PD = Data to be programmed at location PA. Data is latched on the rising edge of WE#.
  - IID = Data read from intelligent identifier.
- 3. Following the intelligent identifier command, two read operations access the manufacturer and device codes.
- 4. Commands other than shown above are reserved by Intel for future device implementations and should not be used.



### Table 2. 28F001BX Status Register Definitions

|                  |           |           |    |          |              | ·            |               |
|------------------|-----------|-----------|----|----------|--------------|--------------|---------------|
| WSMS             | ESS       | ES        | PS | VPPS     | R            | R            | R             |
| 7                | 6         | 5         | 4  | 3        | 2            | 1            | 0             |
| WRITE STA        | ATE MACHI | NE STATUS |    | NOTES:   |              |              |               |
| 1 = Ready        | y :       |           |    | The Writ | e State Ma   | achines Stat | us Bit must   |
| 0 = Busy checked |           |           |    |          | to determine | program or   | erase complet |

success

tempted.

SR.7 =

Busy

SR.6 = ERASE SUSPEND STATUS

1 = Erase Suspended

0 = Erase In Progress/Completed

SR.5 = ERASE STATUS

1 = Error In Block Erase

0 = Successful Block Erase SR.4 = PROGRAM STATUS

> 1 = Error In Byte Program 0 = Successful Byte Program

 $SR.3 = V_{PP} STATUS$ 

1 = V<sub>PP</sub> Low Detect, Operation Abort

 $0 = V_{PP} OK$ 

The VPP Status bit, unlike an A/D converter, does not provide continuous indication of VPP level. The WSM interrogates the V<sub>PP</sub> level only after the program or erase command sequences have been entered and informs the system if Vpp has not been switched on. The Vpp Status bit is not guaranteed to report accurate feedback between V<sub>PPL</sub> and V<sub>PPH</sub>.

fore the Program or Erase Status bits are checked for

If the Program AND Erase Status bits are set to 1's dur-

ing an erase attempt, an improper command sequence

If VPP low status is detected, the Status Register must be

cleared before another program or erase operation is at-

was entered. Attempt the operation again.

SR.2-SR.0 = RESERVED FOR FUTURE ENHANCEMENTS

These bits are reserved for future use and should be masked out when polling the Status Register.

The WSM on-chip oscillator internally times the program/erase algorithms, making software timers unnecessary. Block precondition is also controlled by the WSM as part of the erase algorithm. Block data programming to "0's" before erasing is no longer needed.

Intel's high quality design, manufacturing and testing result in outstanding reliability and performance throughout device life. Although Program Status and Erase Status bits are provided for Status Register completeness, errors will probably not be encountered, if proper V<sub>PP</sub> levels and software sequences are implemented.

Intel offers standard software drivers, written in "C". to assist software engineers implementing 28F001BX reprogramming for update utilities. These high-level routines, found in Appendix A, are adaptable to a wide range of µP and µC platforms and system architectures.

Covered in this section are the major software steps for a flash BIOS update utility:

- Update software for a modified system
- · Pseudo-Code overview

- Initializing the system
- Code loader routine
- Flash re-programming
- Recovery routines
- Power management

### **Update Software for a Modified** System

The design example of Section 3.0 assumes BIOS shadowing for BIOS code execution while allowing BIOS writes to the flash socket. Many systems provide a register which enables BIOS writes and reads. Some systems may not allow BIOS reads from RAM while performing BIOS writes to the flash socket, or vice versa. The reasons may be simple; no shadow RAM exists in the system (8088 or 8086 systems), or system logic treats "ROM writes" as an invalid operation. In these cases, perform all your required BIOS calls before you erase and program the flash memory. But keep in mind, to update the user on the progress of flash programming and indicate when programming is finished, you should add some basic screen or speaker "beep" routines to your update utility.



#### 4.2 Pseudo-Code Overview

The following pseudo-code for an update utility provides a brief description of the process of updating a BIOS in-situ. It is based on software developed by a customer for a PC platform with BIOS update capability. This Intel386-33 MHz system uses the 28F001BX for BIOS storage. Modify the flowchart below, if needed, for your particular chipset and hardware environment.

#### **Pseudo-Code for Flash Update Routine**

Initialize system (set up user screen, check battery power, check device ID)

Get BIOS file options (from floppy or modem)

If no file present

Send error message to insert BIOS update floppy, or press ESC to exit

Display BIOS update files, prompt user for choice and load to memory

If file invalid,

Prompt for file or exit

Inform user what is about to happen, with option to continue or exit

If user continues, inform them to not turn off the power or soft-reboot (CNTL-ALT-DEL)

Erase 28F001BX main/parameter blocks

If system interrupt occurs

Suspend erase if flash memory access is required Resume Erase

Write file[s] into flash memory
Indicate to user that flash reprogramming is over
Reboot the system

#### 4.3 Initializing the System

#### **Checking Power**

If your application is a laptop or palmtop computer, first check the battery to make sure there is enough power to do the update. If not, inform the user to recharge the system before continuing the update and exit the update program. This ensures that the system won't stop in the middle of an update. Next, initialize access to flash for reads and writes, then try reading the device ID through the Command Register. Checking the device ID before programming or erasing helps determine

if reads and writes work correctly and that the flash memory in the system matches your code before starting to reprogram the part. The manufacturer ID for Intel flash memories is 89H (10001001), located at device address 00000H. Device IDs are located at address 00001H; the ID for the 28F001BX-T is 94H (10010100), and the 28F001BX-B device ID is 95H (10010101). These device addresses, in the DOS memory map, correspond to system addresses E0000H (mfgr. ID) and E0001H (device ID). If A<sub>16</sub> inversion is used as described in Section 3.1, system addresses for mfgr. ID and device ID under normal operation are F0000H and F0001H.

#### NOTE:

During the initialization, you can also perform a scan of the adaptor space to ascertain if there is more flash in the system. Other Intel Flash Memories share common manufacturer IDs but have unique device IDs, listed below:

| Device     | Device<br>ID (Hex) | Device ID<br>(Binary) |
|------------|--------------------|-----------------------|
| 28F256A    | В9Н                | 10111001              |
| 28F512     | B8H                | 10111000              |
| 28F010     | B4H                | 10110100              |
| 28F020     | BDH                | 10111101              |
| 28F001BX-T | 94H                | 10010100              |
| 28F001BX-B | 95H                | 10010101              |

#### 4.4 Code Loader Routine

The update utility described in the previous section provides an optional mouse-driven color graphical user interface (GUI) and allows not only BIOS update to the main block but also update of the parameter blocks, and copy/compare of block data to a DOS file. These types of features convey to the end user the ease and simplicity of performing a BIOS update. For example, the main block update utility lists all possible BIOS files in the selected drive and directory, and prompts the user for the desired file. System OEMs may want to encode a specific BIOS file name into the generic loader utility ".COM" or ".EXE" file. This allows automatic reading of the new BIOS file into a program buffer, bypassing the user prompt.

Once the file is loaded into RAM, the routine informs the user of the impending BIOS update and provides the option to exit if desired. If continued, it warns the user to not turn off power or reboot during the BIOS update procedure. It then erases and reprograms the main block with new BIOS data, notifies the user of successful update and reboots.

#### 4.5 Flash Reprogramming Routines

#### **On-Chip Erase Algorithm**

The 28F001BX system erase algorithm is shown in Figure 15. Note that the actual device erase algorithm (Quick-Erase) is controlled internally, including all timing and block preconditioning. This provides the same high level of reliability proven on Intel's ETOX II technology, while reducing system debug efforts. Erase progress is reported to system software thru specific Status Register bits. The 28F001BX erases all bits of a block in parallel. Minimum and typical erase times for each block are listed below:

| Block           | Minimum<br>Time (Sec) | Typical<br>Time (Sec) |
|-----------------|-----------------------|-----------------------|
| Parameter (ea.) | 1.3                   | 2.1                   |
| Main            | 3.0                   | 3.8                   |
| Boot            | 1.3                   | 2.1                   |

The actual erase time depends on the  $V_{PP}$  voltage level (11.4V–12.6V), temperature and the number of erase cycles already completed on the part. System software must comprehend adequate time for  $V_{PP}$ , after enabled, to ramp to 12V before erase is attempted. Capacitors on the  $V_{PP}$  bus, in addition to the intrinsic pump nature of many 12V solutions, cause an RC ramp. Systems that direct-wire 12V need not worry about this delay.

#### **Erase Suspend/Resume**

Erase suspend gives the user the ability, while erasing a block of the 28F001BX, to read data or execute code from another block. This capability, in conjunction with the minimal system overhead provided by the WSM, makes disabling of interrupts during block erase unnecessary. Once given the erase suspend command, the WSM halts, reports suspend status to the Status Register and allows array reads. When issued erase resume, it proceeds at the point where it was suspended. Figure 16 details the system code flowchart that suspends and resumes erase.





| Bus<br>Operation | Command | Comments                   |
|------------------|---------|----------------------------|
| Write            | Erase   | Data = 20H                 |
| }                | Setup   | Address = Within Block     |
| Write            | Erase   | to be erased<br>Data = D0H |
| Wille            | Liase   | Address = Within Block     |
|                  |         | to be erased               |
| Read             |         | Status Register Data.      |
|                  |         | Toggle OE# or CE# to       |
|                  |         | update Status Register     |
| Standby          |         | Check SR.7                 |
|                  |         | 1 = Ready, 0 = Busy        |

Repeat for subsequent blocks.

Full status check can be done after each block or after a sequence of blocks.

Write FFH after the last block erase operation to reset the device to Read Array Mode.

#### **FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                      |
|------------------|---------|-----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect  |
| Standby          |         | Check SR.4, 5 Both 1 = Command Sequence Error |
| Standby          |         | Check SR.5<br>1 = Block Erase Error           |

SR.3 MUST be cleared, if set during an erase attempt, before further attempts are allowed by the Write State Machine.

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 15. 28F001BX Block Erase Algorithm





Figure 16. 28F001BX Erase Suspend/Resume Algorithm





| Bus<br>Operation | Command          | Comments                                                          |
|------------------|------------------|-------------------------------------------------------------------|
| Write            | Program<br>Setup | Data = 40H<br>Address = Byte to<br>be programmed                  |
| Write            | Program          | Data to be Programmed Address = Byte to be programmed             |
| Read             |                  | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          |                  | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent bytes.

Full status check can be done after each byte or after a sequence of bytes.

Write FFH after the last byte programming operation to reset the device to Read Array Mode.

#### **FULL STATUS CHECK PROCEDURE**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4  1 = Byte Program Error           |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple bytes are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

Figure 17. 28F001BX Byte Programming Algorithm



#### **On-Chip Programming Algorithm**

As with 28F001BX erase, the Intel flash Quick-Pulse algorithm is internally controlled by the WSM. Figure 17 shows a system software flowchart for the Command Register/Status Register interface. Minimum and typical programming times (per byte) are 15 µs and 18 µs, respectively. Actual time varies with Vpp, temperature and cumulative programming cycles on the device. Ensure that stable 12V is applied to the device before attempting byte programming.

#### **Full Status Checks**

After polling the Status Register and determining that the WSM is again READY, system software should further analyze the Status Register to ensure that program or erase has successfully completed. The WSM will return to READY status after program or erase command sequences under any of the following conditions:

- Program/erase completed successfully,
- V<sub>PP</sub> transition below specification during the program/erase attempt,
- Improper sequence of erase setup/confirm commands to the WSM, or
- Inability to erase the specified block, or program the desired byte.

Figures 15 and 17 detail the additional Status Register data analysis to ensure that program or erase have successfully occurred.

#### 4.6 Recovery Routine Overview

Unsuccessful BIOS update can occur for any of the reasons listed below:

- 1. Vpp transitions out of specified tolerance during program or erase.
- Incorrect code in the update BIOS disk file, or damaged BIOS disk.
- 3. Loss of system power during program or erase.
- System reset (such as reboot) during program or erase.

The Status Register, through bit 3, reports  $V_{\rm PPH}$  loss to system software. The BIOS update utility can detect scenario 1 and recover by simply re-attempting block update.

A checksum of update BIOS code after copy from disk to RAM, before flash erase and reprogram, will eliminate error caused by scenario 2. PC motherboard logic should gate the 28F001BX RP# pin with both POWER GOOD and RESET# signals, to abort program or erase attempts if either scenario 3 or 4 were to occur. This allows the processor to execute code out of the 8 Kbyte boot block upon system recovery. System reset or loss of system power will clear the Status Register to value 80H, leave the block being updated partially programmed or erased and reset the 28F001BX to Read Array mode. As detailed previously in Section 3.1, a checksum of the main block will alert the system to an incomplete BIOS. Recovery is achieved by the following or similar steps:

- Initialize CPU and system logic.
- Initialize the system floppy disk.
- Prompt the user to insert a BIOS diskette, through speaker "beep".
- Erase and reprogram the main and/or parameter blocks with file data.
- Reboot

#### 4.7 Power Management

Battery-powered PCs incorporate a variety of techniques to prolong system life between recharges. Typically, power management software senses user inactivity and shuts off power-intensive sections of the system. Options include:

- Display powerdown
- Disk/hard drive powerdown
- · System clock slowdown or suspend, and
- Powerdown of non-volatile circuitry in the system.

The 28F001BX fits the latter description. When the RP# pin transitions to GND, the device enters an ultra-low power mode, typically consuming 0.25  $\mu$ W thru V<sub>CC</sub>. This technique can also be used to power down the BIOS memory after BIOS code has been shadowed to DRAM, if available in the system. When not programming or erasing the 28F001BX, the system should shut off 12V V<sub>PP</sub> to the part to minimize current draw through this supply.

User inactivity is typically detected if the keyboard has not been used, or the disk drive has not been accessed, for a predetermined interval (this is often user-programmable). Power management software must ensure that a BIOS update is not occurring, before powering down the 28F001BX, to prevent incomplete update.

For more information on power management techniques, consult datasheets and application notes on the Intel386SL microprocessor superset.



#### 5.0 SUMMARY

#### 5.1 Traditional BIOS Storage and Disadvantages

Traditional BIOS storage has been in EPROM, which offers nonvolatility and factory programming capability. In earlier PCs, the BIOS code was fairly simple (relative to today's software) and updates were infrequent, so EPROMs or ROMs were an acceptable BIOS storage medium. Today's systems are much more sophisticated, with many designs supporting the Intel i386/i486TM microprocessors and new bus architectures like MCA and EISA for the first time. These new buses allow peripherals to take control of the system bus . . . it is difficult to guess what new system configurations might emerge. Therefore, the potential for a change in the BIOS code is much greater and the frequency of change is likely to increase.

A system designer may use EPROMs for BIOS storage to reduce initial system (component) costs, but the long-term update cost is much more than the difference between EPROM and flash memory components. A major manufacturer of PCs has estimated that a service call for a BIOS update with EPROMs can cost upwards of \$300.00 for ONE update at ONE site. EPROMs are also susceptible to bent leads during insertion by the technician, or more likely, the end user. Service is becoming a key differentiator between the multitudes of PC makers. Reducing the number of times a PC has to be opened for any reason and providing improved service increases customer confidence and promotes a reliable image.

#### 5.2 Advantages of an Updatable BIOS

Using flash memory for BIOS storage provides a flexible code medium that allows the BIOS code to adapt to changing hardware and software conditions. BIOS updates in flash are inexpensive, via a floppy disk or modem. They remove EPROM inventories, reduce packaging requirements, reduce total postage costs and eliminate service cost for BIOS code updates by removing the need for a technician to do the update. A company that supports mutiple OEMs can improve version management control by using a flash BIOS and floppies or a BBS for updates. An additional benefit is that not only the BIOS, but DOS itself can be stored in the same flash memory device.

## 5.3 Advantages of Adding DOS in FLASH

Once the requirements for flash memory BIOS are met, the capability is also in place for adding DOS in FLASH. Why put DOS in FLASH? For laptop and palmtop PCs, battery longevity is of paramount concern, followed closely by weight and increasing user RAM (640 KB) space. Extra user RAM is needed for applications that require more than the typical 570 Kbytes (640 KB-70 KB) available with disk-based DOS. Digital Research Incorporated and Microsoft both make "DOS-in-ROM" products that address these needs. MS-DOS ROM version 3.22 is an example.

Microsoft's MS-DOS ROM Version 3.22 is a full-function version of MS-DOS 3.2. It features instant-on and employs only 15 KB of the 640 KB DOS RAM user space, leaving the rest for applications. Since MS-DOS ROM Version 3.22 loads from adaptor space, both disk access and DOS loadtime are reduced. For laptops, anything that can reduce disk access equates to battery longevity. Laptops can reduce weight by using MS-DOS ROM Version 3.22 and replacing the floppy drive with an IC card. Adding MS-DOS ROM Version to desktops also liberates additional user RAM for the same above reasons, but may not be optimal for high speed 32-bit systems.

All future versions of MS-DOS will be supported with equivalent versions of MS-DOS ROM. See Appendix B for more information.

#### 5.4 Advantages of Adding 1 MB-4 MB of Resident Code Storage

There is a growing need for systems to be able to provide a small suite of bundled applications. Benefits to the user are faster application execution thru reduced hard or floppy disk access, no power used to store the resident code, and instant-on. No time is wasted transferring data over a disk I/O interface. The code is instead loaded to RAM with a simple memory copy function or procedure. In some cases, code is directly executed by the processor. Tandy's Deskmate is an example of such a system. Future versions of Deskmatelike user interfaces could easily be made flash-updatable. SRAM is too expensive and requires power to just store files. Furthermore, battery backup is not a reliable means of achieving nonvolatility. Intel's Flash Memory can provide user configurability for 1 MB-4 MB of code storage for just 2x-3x the cost of EPROMs and less than half the cost of SRAM. Applications such as Lotus 123, WordPerfect and Microsoft Works also come in either a direct-execute "ROM" version or a load-from-ROM format. Many other ROM application software packages are in development, servicing the successful and growing needs of the laptop/palmtop computers. Therefore, if an application can be stored or runs from ROM, it can be stored and run from flash. As software packages are periodically updated, flash memory provides the capability of updating these "ROM" applications at little cost to the software vendor and with no system disassembly required.



## APPENDIX A SOFTWARE ROUTINES

```
Copyright Intel Corporation, 1991
   Brian Dipert, Intel Corporation, July 14, 1991, Revision 1.4
   The following drivers control the Command and Status Registers of
     the 28F001BX Flash Memory to drive byte program, block erase, Status
     Register read and clear and array read algorithms.
     Sample Vpp and RP# control blocks are also included.
   The functions listed below are included:
     erasbgn(): Begins block erasure
/*
     erassusp(): Suspends erase to allow reading data from a block of the
/*
                 28F001BX other than that being erased
     erasres(): Resumes erase if suspended
                 Polls the Write State Machine to determine if block erase or
     end():
                 byte program have completed
     eraschk(): Executes full status check after erase completion
                                                                                   */
     progbgn(): Begins byte programming
     progchk(): Executes full status check after byte program completion
                 Reads and returns the manufacturer and device IDs of the
     idread():
                 target 28F001BX
                                                                                   */
     statrd():
                 Reads and returns the contents of the Status Register
                                                                                   */
     statclr(): Clears the Status Register
                 Puts the 28F001BX in Read Array mode
     rdmode():
     rdbyte():
                 Reads and returns a specified byte from the target 28F001BX
     vppup():
                 Enables high voltage Vpph
     vppdown(): Disables Vpph
                 Ramps the RP# pin to high voltage Vhh. enabling boot block
     pwdon():
                 program/erase
     pwdoff():
                 Disables high voltage Vhh on RP#, disabling program
/*
                 and erase of boot block
/*
   Addresses are transferred to functions as pointers to far bytes (ie long
     integers). An alternate approach is to create a global array the size of the
     28F001BX and locate "over" the 28F001BX in the system memory map. Accessing
                                                                                   */
     specific locations of the 28F001BX is then accomplished by passing the chosen
     function an offset from the array base versus a specific address. Different
     microprocessor architectures will require different array definitions; ie for
     the Intel architecture, define it as "byte boot [2][10000]" and pass each
     function TWO offsets to access a specific location. MCS-51 architectures
     are limited to "byte boot[10000]"; alternate approaches such as writing to
     control bits will be required to access the full flash array
                                                                                   */
/* To create a far pointer, a function such as MK_FP() can be used, given
/*
                                                                                   */
     a segment and offset in the Intel architecture. I use Turbo-C; see your
     compiler reference manual for additional information.
```



```
/* Revision History: Rev 1.4
   Changes from 1.0 to 1.1: Added typedef for "byte" to accurately reflect
     this x8 device. Altered variable definitions accordingly. Combined
                                                                          */
/*
     functions progend() and erasend() into function end().
                                                                          */
/*
                                                                          */
   Changes from 1.1 to 1.2: Added this revision history block. Added above
                                                                          */
/*
     comments on alternate addressing methods.
                                                                          */
/*
                                                                          */
   Changes from 1.2 to 1.3: Added pass/fail error return from idread(),
/*
     idread() at beginning of progbgn() and erasbgn(), pass/fail error
                                                                          */
/*
     return from progbgn() and erasbgn().
                                                                          */
/*
                                                                          */
   Changes from 1.3 to 1.4: Revised code to reflect simplified program and
                                                                          */
/*
     erase algorithms. 28F001BX automatically transitions to Read Status Register
/*
     mode after program command sequence, erase command sequence and remains in
                                                                          */
/*
     Read Status Register mode after Erase Suspend is issued. Address 0000H is no
     longer required to read or clear the Status Register.
    **********************
typedef unsigned char byte:
/**********************
/* Function: Main
/* Description: Included only to omit errors when attempting to compile code.
/* The end customer would insert their main program here.
main()
/* Function: Erasgbn
                                                                          */
/*
     Description: Begins erase of a block.
                                                                          */
/*
     Inputs: blckaddr: System address within the block to be erased
/*
     Outputs: None
/*
     Returns: 0 = Erase successfully initiated
/*
             l = Erase not initiated (ID check error)
     Device Read Mode on Return: Status Register (ID if returns 1)
/* Erase Setup command
#define ERASETUP
                 0X20
#define ERASCONF
                 OXDO
                        /* Erase Confirm command
int erasbgn(blckaddr)
byte far *blckaddr:
                         /* blckaddr is an address within the block to be
                              erased
                       /* ID read error; device not powered up?
if (idread()==1)
   return (1);
*blckaddr = ERASETUP;
                       /* Write Erase Setup command to block address
*blckaddr = ERASCONF;
                        /* Write Erase Confirm command to block address
return (0);
```



```
Function: Erassusp
     Description: Suspends block erase to read from another block
                                                                            */
                                                                            */
     Inputs: None
     Outputs: None
                                                                            */
     Returns: 0 = Erase suspended
             1 = Error; Write State Machine not busy (erase suspend not possible) */
     Device Read Mode on Return: Read Status Register
/* Mask to isolate the WSM Status bit of the
                                                                            */
#define RDYMASK
                 0X80
                         /*
                                                                            */
                               Status Register
                         /* Status Register value after masking, signifying
#define WSMRDY
                 0X80
                                                                            */
                                                                            */
                               that the WSM is no longer busy
#define SUSPMASK
                 0X40
                         /*Mask to isolate the Erase Suspend Status bit of the
                                                                            */
                                                                            */
                                Status Register
#define ESUSPYES
                  0X40
                         /* Status Register value after masking, signifying
                         /*
                                that erase has been suspended
                                                                            */
#define STATREAD
                 0X70
                         /* Read Status Register command
                                                                            */
#define SYSADDR
                  0
                         /* This constant can be initialized to any address
                                                                            */
                         /*
                                within the memory map of the target 28F001BX
                                                                            */
                         /*
                                                                            */
                                and is alterable depending on the system
                         /*
                                architecture
#define SUSPCMD
                  OXBO
                        /* Erase Suspend command
int erassusp()
byte far *stataddr;
                        /* Pointer variable used to write commands to device
stataddr = (byte far *)SYSADDR:
                         /* Write Erase Suspend command to the device
*stataddr = SUSPCMD:
*stataddr = STATREAD:
                         /* Write Read Status Register command to 28F001BX
while ((*stataddr & RDYMASK) != WSMRDY)
                         /* Will remain in while loop until bit 7 of the
                         /*
                                Status Register goes to 1, signifying that the */
                         /*
                                 WSM is no longer busy
if ((*stataddr & SUSPMASK) == ESUSPYES)
                         /* Erase is suspended ... return code "0"
           return(0);
return(1);
                         /* Erase has already completed; suspend not possible.
                                Error code "1"
                         /*
```



```
Function: Erasres
/*
     Description: Resumes block erase previously suspended
                                                                         */
/*
                                                                         */
     Inputs: None
     Outputs: None
                                                                         */
     Returns: 0 = Erase resumed
                                                                         */
             1 = Error; Erase not suspended when function called
                                                                         */
     Device Read Mode on Return: Status Register
#define RDYMASK
                  0X80
                         /* Mask to isolate the WSM Status bit of the
                                                                         */
                         /* Status Register
                                                                         */
                        /* Status Register value after masking, signifying
#define WSMRDY
                  0X80
                                                                         */
                        /* that the WSM is no longer busy
                                                                         */
#define SUSPMASK
                  0X40
                        /* Mask to isolate the Erase Suspend Status bit
                                                                         */
                        /* of the Status Register
                                                                         */
#define ESUSPYES
                        /* Status Register value after masking, signifying
                                                                         */
                        /*
                                that erase has been suspended
                                                                         */
#define STATREAD
                  0X70
                        /* Read Status Register Command
                                                                         */
                 . 0
                         /* This constant can be initialized to any
#define SYSADDR
                                                                         */
                         /*
                                address within the memory map of the target
                        /*
                                28F001BX and is alterable depending on the
                         /*
                                system architecture
#define RESUMCMD
                  OXDO
                         /* Erase Resume Command
int erasres()
byte far *stataddr;
                       /* Pointer variable used to write commands to device */
stataddr = (byte far *) SYSADDR.
*stataddr = STATREAD; /* Write Read Status Register command to 28F001BX
if ((*stataddr & SUSPMASK) != ESUSPYES)
                        /* Erase not suspended. Error code "1"
   return (1);
                        /* Write Erase Resume command to the device
*stataddr = RESUMCMD;
                                                                         */
while ((*stataddr & SUSPMASK) == ESUSPYES)
                                                                         */
                         /* Will remain in while loop until bit 6 of the
                         /*
                                Status Register goes to 0, signifying
                        /*
                                erase resumption
while ((*stataddr & RDYMASK) == WSMRDY)
                         /* Will remain in while loop until bit 7 of the
                                                                         */
                         /*
                              Status Register goes to 0, signifying
                         /*
                                that the WSM is once again busy
return (0);
```



```
Function: End
/*
     Description: Checks to see if the WSM is busy
/*
                 (is program/erase completed?)
                                                                          */
/*
     Inputs: None
                                                                          */
     Outputs: statdata: Status Register data read from device
     Returns: 0 = Program/Erase completed
                                                                          */
             1 = Program/Erase still in progress
                                                                          */
     Device Read Mode on Return: Status Register
/***********************
#define RDYMASK
                         /* Mask to isolate the WSM Status bit of the
                  0X80
                                                                          */
                         /*
                                Status Register
                                                                          */
#define WSMRDY
                  0X80
                         /* Status Register value after masking, signifying
                                                                          */
                         /*
                                that the WSM is no longer busy
                                                                          */
#define STATREAD
                  0X70
                         /* Read Status Register command
                                                                          */
                         /* This constant can be initialized to any
#define SYSADDR
                                                                          */
                  0
                         /*
                                address within the memory map of the target
                                                                          */
                         /*
                                28F001BX and is alterable depending on the
                                                                          */
                         /*
                                system architecture
                                                                          */
int end (statdata)
bvte *statdata:
                         /* Allows Status Register data to be passed back
                                to the main program for further analysis
byte far *stataddr;
                         /* Pointer variable used to write commands to
                         /*
                                device
stataddr = (byte far*)SYSADDR;
*stataddr = STATREAD:
                         /* Write Read Status Register command to 28F001BX
if (((*statdata = *stataddr) & RDYMASK) != WSMRDY)
    return (1):
                         /* Program/erasure still in progress...code "1"
return (0);
                         /* Program/erase attempt completed...code "0"
```



```
Function: Eraschk
                                                                                   */
     Description: Completes full Status Register check for erase (proper
                                                                                   */
/*
        command sequence, VPP low detect, erase success). This routine assumes
                                                                                    */
/*
        that erase completion has already been checked in function end() and
                                                                                    */
/*
        therefore does not check the WSM Status bit of the Status Register
                                                                                    */
/*
     Inputs: statdata: Status Register data read in function end
                                                                                    */
/*
                                                                                    */
     Outputs: None
/*
     Returns: 0 = Erase completed successfully
                                                                                    */
/*
               1 = Error; Vpp low detect
               2 = Error; Block erase error
                                                                                    */
               3 = Error; Improper command sequencing
     Device Read Mode on Return: Same as when entered
                                                                                    */
#define ESEQMASK
                    0X30
                            /* Mask to isolate the Erase and Program
                                                                                   */
                                       Status bits of the Status Register
#define ESEQFAIL
                    0X30
                            /* Status Register value after masking if erase
                                                                                    */
                                       command sequence error has been detected
                                                                                    */
#define ERRMSK
                    0220
                             /* Mask to isolate the Erase Status bit of the
                                                                                    */
                            /*
                                                                                   */
                                       Status Register
                            /* Status Register value after masking if erase error
#define ERASERR
                    0X20
                                       has been detected
                                                                                   */
#define VLOWMASK
                    80X0
                            /* Mask to isolate the Vpp Status bit of the Status
                                                                                    */
                            /*
                                       Register
                                                                                    */
                            /* Status Register value after masking if Vpp low
#define VPPLOW
                    80X0
                                                                                    */
                                                                                    */
                                       has been detected
int eraschk(statdata)
 byte statdata;
                            /* Status Register data that has been already read
                                      from the 28F001BX in function end()
 if ((statdata & VLOWMASK) == VPPLOW)
                            /* Vpp low detect error, return code "1"
      return (1);
 if ((statdata & ERRMSK) == ERASERR)
                            /* Block erase error detect, return code "2"
      return (2);
 if ((statdata & ESEQMASK) == ESEQFAIL)
      return (3);
                            /* Erase command sequence error, return code "3"
                            /* Block erase success, return code "0"
 return (0);
}
```



```
/***************
/* Function: Progbgn
     Description: Begins byte program sequence
     Inputs: pdata: Data to be programmed into the device
             paddr: Target address to be programmed
     Outputs: None
     Returns: 0 = Program successfully initiated
              1 = Program not initiated (ID check error)
     Device Read Mode on Return: Status Register (ID if returns 1)
#define SETUPCMD
                   0X40
                          /*Program Setup command
int progbgn (pdata,paddr)
byte pdata;
                           /* Data to be programmed into the 28F001BX
byte far *paddr;
                           /* paddr is the destination address for the data
                                    to be programmed
if (idread() == 1)
                          /* Device ID read error...powered up?
     return (1):
*paddr = SETUPCMD;
                           /* Write Program Setup command and
                                     destination address
*paddr = pdata;
                           /* Write program data
                                    and destination address
return (0);
```



| /**********                                                                   | *****                                                                  | ****************                                 | ****/ |  |
|-------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------|-------|--|
| /* Function: Proge                                                            | hk                                                                     |                                                  | */    |  |
| * Description: Completes full Status Register check for byte program (Vpp low |                                                                        |                                                  |       |  |
| /* detect, prog                                                               | * detect, programming success). This routine assumes that byte program |                                                  |       |  |
| /* completion h                                                               | as alrea                                                               | ady been checked in function end() and           | */    |  |
|                                                                               | es not                                                                 | check the WSM Status bit of the Status Register  | */    |  |
| /* Inputs: statda                                                             | ta: Stat                                                               | tus Register data read in function end           | */    |  |
| /* Outputs: None                                                              |                                                                        |                                                  | */    |  |
|                                                                               | yte pro                                                                | gramming completed successfully                  | */    |  |
|                                                                               | rror; V                                                                | PP low detect                                    | */    |  |
| /* 2 = E                                                                      | rror; B                                                                | yte program error                                | */    |  |
| /* Device Read Mo                                                             | de on Re                                                               | eturn: Status Register                           | */    |  |
| /*********                                                                    | *****                                                                  | ***************                                  | ****/ |  |
| #define PERRMSK 0                                                             | X10 /*                                                                 | Mask to isolate the Program Status bit of the    | */    |  |
|                                                                               | /*                                                                     | Status Register                                  | */    |  |
| #define PROGERR 0                                                             | X10 /*                                                                 | Status Register value after masking if program   | */    |  |
|                                                                               | /*                                                                     | error has been detected                          | */    |  |
| #define VLOWMASK O                                                            | X08 /*                                                                 | Mask to isolate the VPP Status bit of the Status | */    |  |
|                                                                               | /*                                                                     | Register                                         | */    |  |
| #define VPPLOW 0                                                              | X08 /*                                                                 | Status Register value after masking if VPP low   | */    |  |
|                                                                               | /*                                                                     | has been detected                                | */    |  |
| int progchk (statda                                                           | ıta)                                                                   |                                                  |       |  |
| byte statdata;                                                                | /*                                                                     | Status Register data that has been already read  | */    |  |
|                                                                               | /*                                                                     | from the 28F001BX in function end()              | */    |  |
| -                                                                             |                                                                        |                                                  |       |  |
| if ((statdata & VI                                                            | OWMASK)                                                                | == VPPLOW)                                       |       |  |
| return (1);                                                                   | /*                                                                     | VPP low detect error, return code "1"            | */    |  |
| if ((statdata & PE                                                            | ERRMSK) :                                                              | == PROGERR)                                      |       |  |
| return (2);                                                                   | /*                                                                     | Byte program error detect, return code "2"       | */    |  |
| return (0);                                                                   | /*                                                                     | Byte/string program success, return code "0"     | */    |  |



```
*/
/*
      Description: Reads the manufacturer and device IDs from the target 28F001BX
/*
      Inputs: None
                                                                                   */
/*
      Outputs: mfgrid: Returned manufacturer ID
                                                                                   */
/*
              deviceid: Returned device ID
                                                                                   */
/*
     Returns: 0 = ID read correct
                                                                                   */
/*
              1 = Wrong or no ID
                                                                                   */
      Device Read Mode on Return: Intelligent Identifier
                                                                                   */
     *********************************
#define MFGRADDR
                               /* Address "0" for the target 28F001BX...
                                                                                   */
                               /*
                                          alterable depending on the system
                                                                                   */
                                /*
                                          architecture
                                                                                   */
#define DEVICADD
                      1
                                /* Address "1" for the target 28F001BX...
                                                                                   */
                               /*
                                          alterable depending on the system
                                                                                   */
                               /*
                                          architecture
                                                                                   */
#define IDRDCOMM
                      0X90
                                /* Intelligent Identifier command
                                                                                   */
#define INTELID
                      0X89
                               /* Manufacturer ID for Intel devices
                                                                                   */
                                                                                   */
#define DVCIDBT
                      0X94
                               /* Device ID for 28F001BX-T; change to 95H if
                                /*
                                         using 28F001BX-B!!!
                                                                                   */
int idread (mfgrid.deviceid)
byte *mfgrid;
                                /* The manufacturer ID read by this function, to
                               /*
                                                                                   */
                                          be transferred back to the calling
                                                                                   */
                                          program
byte *deviceid;
                                /* The device ID read by this function, to be
                                                                                   */
                                /*
                                          transferred back to the calling function */
 byte far *tempaddr;
                                /* Pointer address variable used to read IDs
                                                                                   */
 tempaddr = (byte far*) MFGRADDR;
 *tempaddr= IDRDCOMM;
                               /* Write intelligent identifier command to an
                                                                                   */
                               /*
                                        address within the 28F001BX memory map
                               /*
                                                                                   */
                                          (in this case, OOH)
 *mfgrid = *tempaddr;
                               /* Read mfgr ID, tempaddr still points at address "0" */
 tempaddr = (byte far*)DEVICADD;/* Point to address "1" for the device specific ID
                                                                                   */
                               /* Read device ID
                                                                                   */
 *deviceid= *tempaddr;
 if ((*mfgrid != INTELID)||(*deviceid != DVCIDBT))
     return (1);
                               /* ID read error; device powered up?
                                                                                   */
 return (0);
```



```
/* Function: Statrd
                                                                          */
/*
      Description: Returns contents of the target 28F001BX Status Register
                                                                          */
/*
      Inputs: None
                                                                          */
/*
      Outputs: statdata: Returned Status Register data
/*
      Returns: Nothing
                                                                          */
      Device Read Mode on Return: Status Register
     *******************
#define STATREAD
                  OX70 /* Read Status Register command
                                                                          */
                         /* This constant can be initialized
#define SYSADDR
                                                                          */
                         /*
                                   to any address within the
                                                                          */
                          /*
                                  memory map of the target 28F001BX
                                                                          */
                          /*
                                                                          */
                                  and is alterable depending on
                                                                          */
                          /*
                                   the system architecture
int statrd(statdata)
                          /* Allows Status Register data to
                                                                          */
byte *statdata:
                          /*
                                   be passed back to the calling program
                                                                          */
                          /*
                                    for further analysis
byte far *stataddr;
                         /* Pointer variable used to write
                         /*
                                    commands to device
stataddr = (byte far*)SYSADDR;
 *stataddr = STATREAD;
                         /* Write Read Status Register
                          /*
                                   command to 28F001BX
*statdata = *stataddr;
return:
```



```
*/
  Function: Statclr
/*
   Description: Clears the 28F001BX Status Register
                                                                */
/*
   Inputs: None
                                                                */
/*
   Outputs: None
                                                                */
/*
                                                                */
   Returns: Nothing
    Device Read Mode on Return: Status Register
#define STATCLER
               0X50
                     /* Clear Status Register command
#define SYSADDR
               0
                     /* This constant can be initialized to any
                     /* address within the memory map of the target*/
                     /*
                                                               */
                            28F001BX and is alterable depending on
                     /*
                                                               */
                             the system architecture
int statclr()
byte far *stataddr:
                     /* Pointer variable used to write commands to
                     /* device
stataddr = (byte far*)SYSADDR:
*stataddr = STATCLER;
                     /* Write Clear Status Register command to
                        28F001BX
return:
Description: Puts the target 28F001BX in Read Array Mode. This function
      might be used, for example, to prepare the system for return to code
/*
      execution out of the flash memory after program or erase algorithms
     have been executed off-chip
/*
                                                                */
    Inputs: None
                                                                */
/*
    Outputs: None
    Returns: Nothing
    Device Read Mode on Return: Array
#define RDARRAY
                     /* Read Array command
               OXFF
                     /* This constant can be initialized to any
                                                               */
#define SYSADDR
              0
                     /*
                       address within the memory map of the target */
                                                               */
                     /*
                           28F001BX and is alterable depending on
                         the system architecture
                                                               */
                     /*
int rdmode()
byte far *tempaddr;
                     /* Pointer variable used to write commands to
                     /*
                             device
tempaddr = (byte far*)SYSADDR;
*tempaddr = RDARRAY; /* Write Read Array command to 28F001BX
                                                               */
return;
```



```
/* Function: Rdbyte
     Description: Reads a byte of data from a specified address and
                 returns it to the calling program
     Inputs: raddr: Target address To be read from
     Outputs: rdata: Data at the specified address
     Returns: Nothing
     Device Read Mode on Return: Array
#define RDARRAY
                         /* Read array command
                  OXFF
int rdbyte (rdata,raddr)
byte *rdata;
                          /* Returns data read from the device at
                          /* specified address
byte far *raddr:
                          /* Raddr is the target address to be read from
                          /* Write read array command to an address within
 *raddr = RDARRAY;
                                 the 28F001BX memory map (in this case the */
                          /*
                                    target address)
                                                                             */
*rdata = *raddr;
                          /* Read from the specified address and store
                                                                             */
return;
```



```
Function: Vppup
                                                                      */
/*
    Description: Ramps the Vpp supply to the target 28F001BX to enable
/*
    programming or erase. This routine can be tailored to the individual
                                                                      */
                                                                      */
     system architecture. For purposes of this example, I assumed that a
                                                                      */
     system Control Register existed at system address 20000 hex.
                                                                      */
     with the following definitions:
      Bit 7: Vpph Control:
                            1 = Enabled
                            0 = Disabled
                                                                      */
     Bit 6: PWD Control:
                            1 = PowerDown Enabled
                                                                      */
                            0 = PowerDown Disabled
                                                                      */
      Bits 5-0: Undefined
     Inputs: None
     Outputs: None
                                                                      */
/*
     Returns: Nothing
                                                                      */
/*
     Device Read Mode on Return: As existed before entering the function.
                                                                      */
     Part is now ready for program or erase command sequence
#define VPPHIGH
                         0X80
                                 /* Bit 7 = 1, Vpp elevated to Vpph
#define SYSCADDR
                         OX20000 /* Assumed system Control Register Address */
int vppup()
byte far *contaddr;
                                 /* Pointer variable used to write data
                                         to the System Control Register */
contaddr = (byte far*)SYSCADDR;
 *contaddr = *contaddr | VPPHIGH;
                                 /* Read current Control Register data,
                                 /*
                                          "OR" with constant to ramp Vpp */
return;
}
```



```
Function: Vppdown
     Description: Ramps down the Vpp supply to the target 28F001BX to
      disable programming/erase. See above for a description of the
      assumed system Control Register.
     Inputs: None
     Outputs: None
     Returns: Nothing
     Device Read Mode on Return: As existed before entering the function. Part
      now has high Vpp disabled. If program or erase was in progress when
      this function was called, it will complete unsuccessfully with Vpp low error */
       in the Status Register.
#define VPPDWN
                   OX7F
                            /* Bit 7 = 0, Vpp lowered to Vppl
#define SYSCADDR
                  OX20000 /* Assumed system Control Register Address
int vppdown()
byte far *contaddr;
                           /* Pointer variable used to write data to the
                                       system Control Register
contaddr = (byte far*)SYSCADDR;
 *contaddr = *contaddr & VPPDWN;
                            /* Read current Control Register data, "AND" with
                                       constant to lower Vpp
 return;
```



```
/* Function: Pwdon
                                                                           */
    Description: Toggles the 28F001BX RP# pin low to put the device in Deep
                                                                           */
/*
     PowerDown mode. See above for a description of the assumed
                                                                           */
                                                                           */
     system Control Register.
                                                                           */
    Inputs: None
                                                                           */
    Outputs: None
     Returns: Nothing
                                                                           */
                                                                           */
    Device Read Mode on Return: The part is powered down. If program or erase
     was in progress when this function was called, it will abort with
                                                                           */
/*
                                                                           */
      resulting partially programmed or erased data. Recovery in the form of
/*
      repeat of program or erase will be required once the part
                                                                           */
      transitions out of powerdown, to initialize data to a known state.
#define PWD
                 0X40 /* Bit 6 = 1, RP# enable
#define SYSCADDR
                 0X20000
                         /* Assumed system Control Register Address
int pwdon()
                          /* Pointer variable used to write data to the
byte far *contaddr;
                                    system Control Register
contaddr = (byte far*)SYSCADDR;
*contaddr = *contaddr | PWD; /* Read current Control Register data, "OR" with
                                    constant to enable Deep PowerDown
return:
```



```
Function: Pwdoff
                                                                                    */
/*
     Description: Toggles the 28F001BX RP# pin high to transition the part
                                                                                    */
/*
      out of Deep PowerDown. See above for a description of the assumed system
                                                                                    */
/*
                                                                                    */
      Control Register.
                                                                                    */
*/
*/
     Inputs: None
     Outputs: None
     Returns: Nothing
                                                                                    */
     Device Read Mode on Return: Read Array mode. Low voltage is removed
      from RP#. 28F001BX output pins will output valid data time tPHQV
      after the RP# pin transitions high (reference the datasheet AC
      Read Characteristics) assuming valid states on all other control
      and power supply pins.
#define PWDOFF
                      OXBF
                                 /* Bit 6 = 0, RP# disabled
#define SYSCADDR
                     0X20000
                                /* Assumed system Control Register Address
int pwdoff()
byte far *contaddr;
                                 /* Pointer variable used to write data to the
                                            system Control Register
contaddr = (byte far*)SYSCADDR;
*contaddr = *contaddr & PWDOFF; /* Read current Control Register data, "AND" with
                                          constant to disable Deep PowerDown
return;
```



# APPENDIX B MS-DOS ROM VERSION OVERVIEW

#### **Technical Highlights**

(Taken from Microsoft Product Overview)

#### **RAM Economy**

Because MS-DOS ROM Version executes from ROM, only 15 KB of system RAM space is required for MS-DOS. For a typical user, this will result in a savings of about 40 KB of RAM over disk-based MS-DOS. As a result of this savings, the user is able to run more programs and work with larger data files with the ROM Version than with disk-based MS-DOS. Instant-On MS-DOS ROM Version provides a significant reduction in "boot time", or the amount of time it takes from the completion of the power-on self test until a DOS prompt appears. With the ROM Version, this typically takes one second.

#### No End-User Installation

MS-DOS ROM Version is pre-installed by the OEM (original equipment manufacturer) in the system, thus freeing end users from the task of installing MS-DOS.

#### **Adaptable to OEM Hardware Platforms**

MS-DOS ROM Version is structured such that it allows the OEM to include a specific routine to determine which drive to boot from and any specific parameters if booting from the ROM drive. This makes it possible to easily port the ROM Version to a wide variety of hardware environments. MS-DOS ROM Version

is also positioned independent, in that it can reside anywhere in the "reserved" space (the area between 640 KB and 1 MB). This provides an additional Version to the specific requirements of the OEM's hardware platform.

#### **ROM Economy**

MS-DOS ROM Version occupies only 62 KB of ROM space, thus minimizing the amount of ROM that an OEM must include in the system. Three modules reside in the reserved space: COMMAND.COM, IO.SYS and the DOS Kernel. All three are position independent, so an OEM can decide where to place these modules in the reserved area.

#### **National Language Support**

Microsoft offers a full compliment of localized version of MS-DOS ROM Version, including Kanji and Chinese translations.

#### Ease of Development

As PCs become the engines for many embedded applications, manufacturers would like to develop new applications utilizing existing PC software tools. MS-DOS ROM allows manufacturers to take full advantage of these tools. For instance, a programmer can develop and debug an application onto a PC subsystem which may be embedded into a larger system. This benefit translates into a cost savings when developing a solution for vertical markets.



# APPENDIX C BIOS VENDOR INFORMATION

American Megatrends Inc. (AMI) 1346 Oakbrook Drive, Suite 120 Norcross, GA 30093 (404) 263-8181

Award Software Inc. 130 Knowles Drive Los Gatos, CA 95030 (408) 370-7979

Phoenix Technologies, LTD. 40 Airport Parkway San Jose, CA 95110 (408) 452-6500

Systemsoft Corporation 313 Speen Street Natick, MA 01760 (508) 651-0088 This list is intended for example only, and in no way represents all companies that support BIOS software. Since this industry developes many new solutions each year, Intel recommends that the designer contact the vendors for their latest products. Intel will continue to work with BIOS vendors to develop optimum solutions. Intel Corporation assumes no responsibility for circuitry or software other than circuitry embodied in Intel products. No software patent licenses are implied.



# APPENDIX D MICROPROCESSOR/MICROCONTROLLER COMPATIBILITY CHART

| 28F001BX-T             | 28F001BX-B                |
|------------------------|---------------------------|
| x86 Family             | i960 KA/KB Microprocessor |
| i860™ Family           | i960 SA/SB Microprocessor |
| i960 CA Microprocessor | MCS®-51 Family            |
|                        | MCS®-96 Family            |

#### **REVISION HISTORY**

| Number | Description                                            |
|--------|--------------------------------------------------------|
| -005   | Changed PWD# to RP# to match JEDEC naming conventions. |
|        | Updated RP# control circuitry of Figure 7.             |

**AP-363** 



# APPLICATION NOTE

## **Extended Flash Bios Concepts For Portable Computers**

SALIM FEDEL
SENIOR APPLICATIONS ENGINEER

October 1993

# **Extended Flash Bios Concepts** for Portable Computers

| CONTENTS                                                                                                                                                 | PAGE                             | CONTENTS                                                                   | PAGE                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------|------------------------------------|
| 1.0 INTRODUCTION                                                                                                                                         | 4-402                            | 5.0 SOFTWARE DESIGN CONSIDERATIONS                                         | 4-411                              |
| 2.0 PC BIOS TODAY AT THE<br>128 KBYTE CODE SIZE LIMIT<br>3.0 WHY BIOS CODE WILL GRO<br>BEYOND 128 KBYTES                                                 | w                                | 5.1 16 Kbyte Recovery Co<br>5.2 28F200BX Reprogram<br>5.3 Power Management | ode 4-413<br>mming 4-413           |
| 3.1 Advanced Power Manageme                                                                                                                              | ent 4-404                        | 6.0 DESIGNING A 3.3V SYS                                                   | STEM 4-414                         |
| 3.2 Optimizing New Portable Applications 3.3 Putting Microsoft* MS-DOS Operating System ROM Versi the BIOS Chip 3.4 Relocated Resident VGA CO VIDEO BIOS | 5.0<br>ion into<br>4-404<br>ode: | 6.1 Low Voltage Chips 6.2 Power Savings and In Battery Life                | nproved<br>4-414<br>4-414<br>Flash |
| 4.0 HARDWARE DESIGN FOR A 256-KBYTE BIOS                                                                                                                 | 4-405                            | REFERENCES                                                                 |                                    |
| 4.1 Intel 28F200BX/002BX Boot Block Flash Memory Family                                                                                                  | APPENDIX A                       |                                                                            |                                    |
| 4.2 Extended Flash BIOS Desig<br>Example                                                                                                                 | 4-406                            | APPENDIX C                                                                 |                                    |
| 4.3 The ISA Sliding Window 4.4 The 28F200BX-T/28F002B the 1 Mbyte DOS Memory Ma                                                                          | X-T in                           |                                                                            |                                    |

<sup>\*</sup>Microsoft is a registered trademark of Microsoft Corporation.



#### 1.0 INTRODUCTION

PC BIOS has been migrating to flash-based designs with the introduction of highly optimized flash memory architectures. The first phase of this shift in paradigm was from ROM/EPROM-based BIOS to Bulk Erase Flash memory-based BIOS to provide for in-system updatable BIOS and hence an easy update capability when BIOS changes are required.

The second phase improved the basic flash design to migrate towards boot block flash memory architecture with the Intel 28F001BX Flash Memory. This improvement enabled the implementation of additional features and provided a true design capability for portable PC BIOS.

The third phase of this paradigm shift now starting to evolve, deals with the need to grow beyond the traditional BIOS space limit of 128 Kbytes imposed by the original PC architecture to accommodate the advanced features of today's portable and desktop systems.

This application note describes in detail this third phase in BIOS hardware and software implementation. Specifically it will investigate why BIOS needs to grow beyond the 128 Kbyte code size. Then, a design example using the Intel 28F200BX Boot Block Flash Memory will be explained in terms of both hardware and software. Finally, low voltage PC BIOS designs incorporating 3.3V components are described.

#### 2.0 PC BIOS TODAY AT THE 128 KBYTE CODE SIZE LIMIT

The Basic Input/Output System (BIOS) code is the lowest system level software which manages the interaction between all hardware components (CPU, Chip-Sets and I/O) with all software modules (Operating Systems and Applications Code). BIOS manages many functions in a PC, such as Power-On Self Test (POST), input vector creation, I/O services and system initialization. Therefore BIOS is the essential interface layer for full system functionality and compatibility.

The original PC architecture, developed in 1981, put restrictions on the size and mapping of the BIOS code which was then a very simple piece of software (on the order of 32 Kbytes for the original BIOS code). It was located at the top of the PC's (8088) memory map which at the time was a maximum of 1 Mbyte.

Then in 1984, the PC AT (80286) BIOS was expanded another 32 Kbytes for a total of 64 Kbytes. Subsequently, towards the late 1980s, more elaborate BIOS set-up utilities started to be an integral part of the BIOS code. In addition, personal computer manufacturers designed custom features into their BIOS code to offer more system flexibility. This increase in code complexity expanded the AT BIOS code another 64 Kbytes (for a total of 128 Kbytes) To occupy the total BIOS reserved space in the 1 Mbyte memory map.

In the DOS memory map, BIOS is mapped down from the top of the 1-Mbyte address space (F0000H to FFFFFH). Additional BIOS code space is available for future enhancements from E0000H to EFFFFH. The next 256 Kbytes in the DOS memory map are reserved for adapter space to accommodate add-in boards (for enhanced graphics cards for instance). Finally the remaining 640 Kbytes are reserved for the user to load his/her applications for execution. See Figure 1 for a graphical description.

### 3.0 WHY BIOS CODE WILL GROW BEYOND 128 KBYTES

As advances in computer design affect both desktop systems (with the addition of EISA, PCI and on-board SCSI capabilities) and portable systems (with the addition of advanced power management capability and I/O cards), the need for larger amounts of non-volatile memory space becomes evident.

A Notebook or a Palmtop computer design, for instance, may put the operating system, the system management code, set-up or utility programs into the non-volatile memory area to conserve precious RAM space for applications.

Additionally, Video BIOS can also be mapped into the Flash BIOS area.

Therefore, to implement advanced capabilities and provide new features (as described above) into powerful mobile computers, the 128 Kbyte BIOS code size limit had to be removed as it shall be explored in the next section.

The BIOS of today and the future must adapt to the new requirements of portable PC designs and take advantage of the new capabilities of low power PC chipsets and I/O devices to achieve the highest performance and longest battery life at the lowest system cost.





Figure 1. 128 Kbyte BIOS Code Segmentation in 1-Mbyte DOS Memory Map



#### 3.1 Advanced Power Management

High integration CPUs and chip-sets allow for the design of light, small form factor portable computers with long battery life.

BIOS is the ideal place for implementing the power management techniques pioneered with the Intel386SL Microprocessor Superset. BIOS software vendors have implemented APM code for the latest generation of Notebook PCs.

This added level of functionality imposed on the BIOS code increases the need for larger code space beyond the traditional 128 Kbyte BIOS implementations seen in today's portable systems.

APM code typically requires an additional 32 Kbyte of code space beyond the basic 64 Kbyte standard BIOS. Therefore, with the addition of APM, BIOS code grows to 96 Kbytes.

## 3.2 Optimizing New Portable Applications

With the implementation of PCMCIA cards for non-volatile file storage (with flash memory cards) and the ability to communicate over a telephone line (with modem cards), mobile computers have truly become powerful tools on the road.

The establishment of a common PC card standard for full system compatibility is described in the PCMCIA Standard release 2.0 (Personal Computer Memory Card International Association). Intel has developed a similar set of specifications fully compatible with the PCMCIA release 2.0 standard called the Exchangeable Card Architecture (ExCA). In order to implement card capability in a portable computer, additional BIOS code called Socket Services is minimally required to manage the system card functionality. To implement the specifications, socket services needs an additional 16 Kbyte of code space.

Furthermore, in the pen-based PC applications, there are even greater BIOS requirements to design-in unique features such as: pen extensions, touchscreen capability

and character recognition interface code. These new features require the implementation of additional BIOS code (may be 16 Kbytes to 32 Kbytes).

To take full advantage of Desktop system capabilities and performance while still having a portable computer to take on the road, docking station designs were conceived. This added level of complexity for the portable computer increases the code required in a basic system BIOS.

#### 3.3 Putting Microsoft MS-DOS 5.0 Operating System ROM Version into the BIOS Chip

Additionally, MS-DOS 5, ROM version is now becoming a standard in virtually all diskless sub-notebook, notebook and pen PC implementations. Many factors contribute to this approach. Chief among them is the reduced disk access and the resulting longer battery life. Another factor is the instant boot capability which is essential in certain applications.

Today's MS-DOS 5, ROM version occupies 64 Kbytes of code space as specified from the Microsoft Product Description.

### 3.4 Relocated Resident VGA Code: VIDEO BIOS

As described above in section 3.0, video BIOS can also be mapped into the system Flash BIOS memory allowing the entire system non-volatile storage requirements to be satisfied with one Flash device. Resident VGA BIOS code takes approximately another 32 Kbytes of memory space.

In summary, adding all the above code size requirements, the resulting BIOS storage area increases from the initial 128 Kbyte requirement to somewhere between 208 Kbytes (without pen extensions) to 240 Kbytes (including a pen input capability).

There are already portable designs today which have filled a 256 Kbyte code space to accommodate some of the above mentioned needs.



## 4.0 HARDWARE DESIGN FOR A 256 KBYTE BIOS

## 4.1 Intel 28F200BX/002BX Boot Block Flash Memory Family

Building upon the wide acceptance of the Intel28F001BX 1 Mbit flash memory for BIOS designs, a new family of higher density flash components is now available to solve the PC designer's need of implementing extended BIOS code beyond 128 Kbytes.

These new flash memories at the 2 Megabit density levels, are structured around the same boot block architecture as the Intel 28F001BX and are therefore compatible. They provide block erasure capability, boot code hardware protection and very low power consumption as in the case of the 28F001BX.

In addition, they incorporate new features to simplify the device interface and allow the system designer to optimize platform designs.

These new features are summarized as follows:

- User selectable 8-bit or 16-bit read/write operation (28F200BX)
- 60ns access time performance
- 16 Kbytes Boot Block space which is hardware protected

(Word Addresses) 1FFFFH 16-Kbyte BOOT BLOCK 1E000H 1DFFFH 8-Kbyte PARAMETER BLOCK 1D000H 1CFFFH 8-KByte PARAMETER BLOCK 1C000H 1BFFFH 96-Kbyte MAIN BLOCK 10000H **OFFFFH** 128-Kbyte MAIN BLOCK 00000H Valid Addresses in X16 Mode (BYTE# = 1): A0-A16 Valid Addresses in X8 Mode (BYTE# = 0): A-1 (lowest order address) and A0-A16

• Two, 8 KBytes Parameter Blocks

- One, 96 KByte Main Block
   One, 128 KByte Main Block
- c-bit only operation and packaging for space sensitive applications (28F002BX)

In this section, we will describe these new features in more detail and discuss their system applicability.

The blocking scheme, while still of the boot block type, is expanded by defining additional blocks (2 main blocks) to allow for software modularization and a self-contained design.

As the size of the BIOS code stored in any one device grows due to the complexity and high integration of chip-sets, so does the "kernel" code stored in the boot section. The boot and parameter blocks were accordingly doubled in size in comparison to the 28F001BX device. The two parameter blocks of 8 KBytes each allow the PC designer to store BIOS extensions or Battery-Backed SRAM configuration data (CMOS RAM, EISA configuration parameters). The two main blocks are used to store the main BIOS code in modular fashion if so desired for future easy updates. These main blocks can also be used to store ROM-executable Operating System software such as MS-DOS 5, ROM version or drivers and utilities. Refer to Figure 2 for the block locations for both the 28F200BX-T and 28F002BX-T.



28F002BX-T Top Boot Map

28F200BX-T Top Boot Map

Figure 2. 28F200BX-T/002BX-T Memory Maps



In addition, the 28F200BX/002BX devices incorporate new capabilities desired by today's sophisticated PC designers.

The byte-wide or word-wide feature available as a designer-selectable option gives the ability to interface to an 8-bit or 16-bit wide bus. The performance and hardware goals of some systems may require 16-bit BIOS data bus. A system with a small amount of RAM and a large amount of flash memory-based operating system code for example, may require a 16-bit BIOS data bus to maintain a high performance level of operation.

The high access speed of these new devices, which for the first time break the 60 ns barrier at the 2M and 4M densities, is another big advantage the PC designer can fully exploit to increase system performance and acceptance in the marketplace. For example, a PC designer may choose to execute BIOS directly out of flash memory instead of shadowing to system RAM as well as execute MS-DOS 5, ROM version out of flash for instant-on capability and to achieve better overall system performance.

Block erasure allows independent modification of code and data and maximum flexibilty in production as well as after the system is shipped. The boot block, which is hardware protected, insures that minimal BIOS code is present to always boot up the system successfully. The 16 Kbyte boot block is protected from alteration during system power excursions by a high voltage pin. This write protection pin called RP# has to transition to 12V with the normal Vpp voltage pin to allow for boot block write and erase operations.

If systems are designed with the ability to jumper or switch RP# to high voltage (12V), guaranteed full non-volatility of the boot code is achieved. This feature always guarantees system recovery from power failure and provides the security needed for the end user when performing BIOS code updates.

To meet the crucial needs of lower power consumption, the 28F200BX/002BX devices incorporate a deep-power down current mode activated through the RP# pin under the TTL/CMOS level control. When this pin transitions to ground the device typically consumes 1 microwatt through the  $V_{\rm CC}$  supply pin.

In addition, the 28F200BX/002BX devices include an Automatic Power Savings feature during active mode of operation. This feature allows the memory chip to put itself in a very low current state when it is enabled but not accessing a new memory location.

The 28F200BX/002BX devices incorporate an internal Write State Machine, Command User Interface and a Status Register to fully control the program and erase operations and greatly simplify the user write and erase algorithms and hence the update code procedure. They also include an erase suspend feature which allow the system to service interrupts and access the device during BIOS code updates (refer to Appendix B).

Finally, the 28F200BX/002BX, 2-Megabit devices have an equivalent 4-Megabit boot block flash memory family of devices called the 28F400BX/004BX, allowing for easy density upgrade and total compatibility between systems using both types of memories. Refer to the documentation mentioned in the reference section of this application note.

Figure 3 is a block diagram description of the 28F200BX/002BX products.

## 4.2 Extended Flash BIOS Design Example

This design example focuses primarily on how to interface the Intel 28F200BX-T or 28F002BX-T Boot Block flash memories to the Intel386SL Microprocessor Superset in a 16-bit wide or an 8-bit wide configuration respectively. This is an extended BIOS design example which demonstrates how the barrier of the 128-Kbyte BIOS size memory is eliminated. The design principles in this example apply to designs incorporating chip sets interfaced to SL Enhanced CPUs. Figure 4 shows an interface diagram of the Intel 28F200BX-T Boot Block Flash memory (128 K x 16) to the Intel386SL Microprocessor superset. Figure 5 shows an equivalent interface diagram of the Intel 28F002BX-T Boot Block flash memory (256 K x 8) to the Intel386SL Microprocessor Superset.

The Intel386SL Microprocessor Superset Flash BIOS interface supports up to 256 Kbytes of flash memory BIOS (a 2 Megabit flash memory device) to enable the system designer to meet specific design goals as described in section 3 above.

The Intel386SL Microprocessor Superset supports the following features:

- Up to 256 Kbytes flash memory BIOS
- VGA BIOS mapping into system BIOS
- · 8-bit or 16-bit BIOS interface
- Programmable number of flash memory wait states for read access (from zero to fifteen Wait-States to optimize the system performance)
- · BIOS shadowing mechanism

AP-363



Flash BIOS size configurations in the Intel386SL Microprocessor Superset system are controlled by programming certain registers located in the normal I/O address space.

When a 256 Kbyte Flash BIOS configuration is programmed into the Intel386SL Microprocessor Superset, 128 Kbytes are directly accessible in the E0000H-FFFFFH address range. The other 128 Kbytes are decoded at the top of the 16th or 32nd Megabyte of the Intel386SL superset address space, i.e., either:

FC0000H-FDFFFFH or 1FC0000H-1FDFFFFH. This extra ROM space is accessed by programming the ISA sliding control register to point to one of these two areas and then accessing the ISA sliding window in the D0000H-DFFFFH address range (64 Kbytes). This mechanism allows complete access of the 256 Kbytes of BIOS code without having to enter the Intel386SL protected mode.

The BIOS code size is used to internally decode the ROM address space and generate two chip select signals: ROMCS0# and ROMCS1#, to control the Flash

BIOS device. In the case of a single Flash BIOS device, only ROMCSO# is needed to drive the CE# chip select signal of the flash memory.

In the diagram of Figure 4 note the following:

- BYTE# signal is set high to enable 16-bit operation of the flash device.
- The highest order system address line SA<sub>16</sub> is inverted when FLIP# signal becomes active at bootup time to relocate the boot kernel code at the top of the 1 Mbyte memory map for the system to boot from it. (See section 4.5).
- ROM16/8# is set high to enable 16-bit bus operations.
- RP# signal is gated by the PWRGOOD signal (for reset when power fails) and by system RESET signal
- V<sub>PP</sub> supply voltage is switched to the flash device only when BIOS updates are required.

In addition to the above considerations, note the following in Figure 5:

- The highest order system address line SA<sub>17</sub> is also inverted when FLIP# signal becomes active at system boot-up time.
- ROM16/8# is set low to enable 8-bit only bus operations.





Figure 4. Key Attributes of this Optimized BIOS Interface should be Incorporated in BIOS Designs > 128 Kbytes.





Figure 5. Key Attributes of this Optimized BIOS Interface should be Incorporated in BIOS Designs > 128 Kbytes.



#### 4.3 ISA Sliding Window

An ISA sliding window mechanism is similar to the Expanded Memory System or EMS mechanism. It allows the access of extended memory on the ISA bus in real mode. Hence, there is no conflict in memory allocation when the BIOS chip is accessed during system power-up. This is a straightforward method of implementing a 256 Kbyte extended Flash BIOS. Figure 6 shows how extended memory is accessed with the ISA sliding window. This capability is designed into Intel's 386SL CPU and should be defined into chip sets supporting SL enhanced CPUs.

Therefore to use a 256 Kbyte Flash device the following steps are specified as an example:

#### Example:

Enable support of 256 Kbyte Flash BIOS Enable Flash BIOS write access

One BIOS Flash Bank used

Program zero Flash wait states (for 16 MHz Intel386SL with a 60 ns Intel 28F200BX-T or 28F002BX-T).

Program the ISA Sliding Window to access memory between FC0000H and FDFFFFH.

if ROM Chip-select decode register is not enabled enable ROM chip-select decode register

enable ISAWINDOW control register

# 4.4 The 28F200BX-T/28F002BX-T in the 1 Mbyte DOS Memory Map

In addition, due to the above mapping considerations when interfacing a 256 Kbyte flash BIOS chip to any chip set or the Intel386SL Microprocessor Superset, it is necessary to flip the 256 Kbyte flash memory device in half at boot time to relocate the Boot Block in the correct physical address at FFFFFH for the Intel386SL CPU to boot from it. This is due to the fact that the Intel386SL Microprocessor Superset uses the bottom 128 Kbytes of the 256 Kbyte Flash chip to map down to the real mode 128 Kbyte allocated BIOS space.

Figure 7 shows how the Intel 28F200BX-T flash memory device fits in the DOS 1 MByte memory map. The same memory map applies to the 28F002BX-T device when designing an 8-bit only system.

# 5.0 SOFTWARE DESIGN CONSIDERATIONS

The subject of BIOS code update is already discussed extensively in references [1] and [3]. Appendix A of this application note is an example of a flash BIOS update routine. In this section, we mainly discuss considerations of code segmentation and describe how the system handles the different pieces of code under various conditions.



Figure 6. ISA Sliding Window and Extended Memory Maps





Figure 7. 28F200BX-T/28F002BX-T in the 1 Mbyte DOS Memory Map



As explained in section 3, advanced notebook designs require a large ROM space to conserve valuable RAM space for applications. In addition to the boot kernel code and standard BIOS code, one may put the following code modules:

- APM code
- VGA BIOS
- ExCA socket services
- Operating Systems such as Microsoft MS-DOS 5.0 ROM version

When designing a 256 Kbyte BIOS system as described in this application note using Intel's 28F200BX/002BX, proper code segmentation is essential to achieve optimum system performance.

We can divide the system's operating environment into either:

**BOOT-TIME CONDITIONS** (when system powers-up or is rebooted)

or RUN-TIME CONDITIONS (after boot-up is complete)

The code modules described above are used at different times during normal system operation. Hence, a segregation of the code stored in the flash memory is necessary for proper system operation.

#### **BOOT-TIME EXECUTION**

The system requires the boot kernel to be present at the FFFFH segment during this portion of the cycle.

When using the 28F200BX/002BX flash memory, the first page present will be the top 128 Kbyte. The rest of the first page is used to store APM code, VGA BIOS code or ExCA socket services. These code modules are then copied from their location below the boot block to system RAM for later initialization after the standard BIOS has started.

Once all code modules are copied into RAM, this first 128 Kbyte page of flash can be swapped out or exchanged with the 2nd 128 Kbyte page which is required for run-time execution.

#### **RUN-TIME EXECUTION**

Standard BIOS code is required to be present from E0000H to FFFFFH segment during this time period to handle any BIOS calls and maintain proper system operation.

Microsoft MS-DOS 5.0 ROM version code is also required to be present so the BIOS can "SCAN" it in as an adapter.

## 5.1 16 Kbyte Recovery Code

The 16 Kbyte recovery code is critical when a BIOS update does not successfully complete. The reasons for this failure can be divided into two categories:

- 1. System power failure during BIOS update
- 2. System reset (soft boot) during BIOS update

The processor will execute recovery code out of the 16 Kbyte boot block when either power is restored or when the system boots up after the reset function.

The 16 Kbyte size recovery code allows the software designer to incorporate as many BIOS system checks as possible to implement basic system functionality.

For instance, these checks may include:

Cursor Positioning Keyboard services Time of day service Basic System services

## 5.2 28F200BX Reprogramming

Three basic algorithms allow the system designer to reprogram the Flash BIOS chip and perform the necessary tasks for a BIOS update. These algorithms are:

Automated Byte/Word-wide programming Automated Block erase Erase Suspend and Resume

For a description of these algorithms, the reader is encouraged to study reference [5]. Appendix B in this application note includes the four flowcharts associated with the algorithms.

To obtain the software drivers necessary to control the device reprogramming operations, consult your local Intel sales office.

# 5.3 Power Management

Power management is an essential part of any true portable PC design. The design of sophisticated power management techniques is becoming a key differentiator between different machines, and hence is a competitive advantage for the system integrator.

To help the system designer with this often difficult task of optimizing system performance and battery life, the 28F200BX family of products includes three distinct low power modes of operation. These are:

 Standby Current Mode, where the device typically consumes 50 μA



- Automatic Power Savings Feature, where the device typically consumes 1 mA
- Deep powerdown Mode, where the device typically consumes 0.2 μA

For a detailed description of these modes of operation, consult reference [8].

#### 6.0 DESIGNING A 3.3V SYSTEM

The ability to design 3.3V systems used to be a future consideration. Longer battery life and lighter weight portable computers are some of the key objectives for any portable design. Now, thanks to the increasing availability of low voltage components, true low power machines are possible to realize in practice.

#### 6.1 Low Voltage Chips

The list of 3.3V components available to build the essential parts of a portable computer is becoming longer every day. Semiconductor manufacturers have recognized the urgent need to supply low voltage chips to the portable marketplace.

The Intel 28F200BX/002BX Boot Block Flash Memories are available in 3.3V versions. These low voltage versions of the 28F200BX/002BX are functionally equivalent to their 5V counterparts and are 100% pinout compatible. So a system converting to 3.3V operation can substitute low voltage 2 Mbit chips (28F200BX-L/002BX-L) when desired without any circuit board modification.

# 6.2 Power Savings and Improved Battery Life

The 28F200BX/002BX 3.3V chips reduce the total power drawn during normal read operation to less than 25% of the total power in 5V mode. This is a substantial savings in current which translates to 25% less battery drain and hence longer battery life.

Similarly, low voltage version of the most popular microprocessors reduce the total power dissipated by a substantial amount.

The combination of these current savings plus the other system components current reductions improve battery life dramatically and allow the mobile PC user to benefit from weight reduction, longer operating time, lower system cost and higher performance.

#### 7.0 CONCLUSIONS

#### 7.1 Benefits of Extended Flash BIOS

This application note deals with the concepts of extended BIOS implementations in portable PC designs, but it can also be easily adapted to desktop PC systems for which BIOS code requirements can easily exceed 128 Kbytes.

We have attempted to explain the requirements and the needs of today's advanced portable BIOS designs which have to meet many difficult and often conflicting requirements.

Boot Block flash memory is the ideal storage solution to implement the above mentioned features. Furthermore, as the cost of solid state non-volatile flash memory keeps decreasing, the need to switch to these types of media for storing extended BIOS, operating system software, utilities, and in the future application code, becomes more evident and perhaps the only way a PC manufacturer can effectively compete by producing the best engineered, most optimally designed notebooks, palmtop PCs and pen-based computers.

#### REFERENCES

For more information on the concepts presented in this application note, the reader is encouraged to reference the following documents.

- [1] Technical Paper: "Flash: The Optimum BIOS Storage Device" by Brian Dipert, 1991 SVPC Order Number 297003
- [2] "ROM BIOS: The best place for portable PC Power-Management features" by Lance Hansche, 1991 SVPC
- [3] AP-341: "Designing an Updatable BIOS Using Flash Memory"—Order Number 292077
- [4] AP-357: "Power Supply Solutions for Flash Memory,"—Order Number 292092
- [5] Intel 28F200BX/002BX Datasheet—Order Number 290448
- [6] Intel 28F400BX/004BX Datasheet—Order Number 290451
- [7] Intel 28F200BX-L/002BX-L Datasheet—290449
- [8] Intel 28F400BX-L/004BX-L Datasheet—290450



# APPENDIX A

# Example of a Flash Update Utility Pseudo-Code

This example is for a standard BIOS code and APM code update using the 28F200BX/002BX flash device. Modify this utility, if required, to suit your particular system needs.

Initialize system (set-up user screen, check battery power, check device ID)

Get BIOS/APM file Options (from floppy or through modem)

If no file present Send error message to insert BIOS update floppy, or press ESC to exit

Display BIOS/APM update files, prompt user for choice and load to memory

If file is invalid Prompt for correct file or exit Inform user of upcoming event, provide option to continue or exit

If user continues, inform user not to turn off the power or soft-reboot system (CNTL-ALT-DEL)

Erase 28F200BX/002BX device 96-Kbyte main block

If system interrupt occurs Suspend erase operation if flash memory access is required

Resume erase operation of 96-Kbyte main block

Write new file(s) into flash memory 96-Kbyte main block

Indicate to user that flash reprogramming is complete

Prompt user to reboot the system to continue normal operation



# APPENDIX B 28F200BX-T/28F002BX-T Programming Flowcharts





| Bus<br>Operation | Command          | Comments                                                          |  |  |  |  |  |  |
|------------------|------------------|-------------------------------------------------------------------|--|--|--|--|--|--|
| Write            | Setup<br>Program | Data = 40H<br>Address = Byte to be<br>programmed                  |  |  |  |  |  |  |
| Write            | Program          | Data to be programmed<br>Address = Byte to be<br>programmed       |  |  |  |  |  |  |
| Read             |                  | Status Register Data. Toggle OE# or CE# to update Status Register |  |  |  |  |  |  |
| Standby          |                  | Check SR.7<br>1 = Ready, 0 = Busy                                 |  |  |  |  |  |  |

Repeat for subsequent bytes.

Full status check can be done after each byte or after a sequence of bytes.

Write FFH after the last byte programming operation to reset the device to Read Array Mode.

#### **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4<br>1 = Byte Program Error         |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple bytes are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

**Automated Byte Programming Flowchart** 





| Bus<br>Operation | Command          | Comments                                                          |
|------------------|------------------|-------------------------------------------------------------------|
| Write            | Setup<br>Program | Data = 40H<br>Address = Word to be<br>programmed                  |
| Write            | Program          | Data to be programmed<br>Address = Word to be<br>programmed       |
| Read             |                  | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          | ,                | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent words.

Full status check can be done after each word or after a sequence of words.

Write FFH after the last word programming operation to reset the device to Read Array Mode.

#### **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4<br>1 = Word Program Error         |

SR.3 MUST be cleared, if set during a program attempt, before further attempts are allowed by the Write State Machine.

SR.4 is only cleared by the Clear Status Register Command, in cases where multiple words are programmed before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.

**Automated Word Programming Flowchart** 





| Bus<br>Operation | Command        | Comments                                                          |
|------------------|----------------|-------------------------------------------------------------------|
| Write            | Setup<br>Erase | Data = 20H<br>Address = Within block to be<br>erased              |
| Write            | Erase          | Data = D0H<br>Address = Within block to be<br>erased              |
| Read             |                | Status Register Data. Toggle OE# or CE# to update Status Register |
| Standby          | ·              | Check SR.7<br>1 = Ready, 0 = Busy                                 |

Repeat for subsequent blocks.

Full status check can be done after each block or after a sequence of blocks.

Write FFH after the last block erase operation to reset the device to Read Array Mode.

#### **Full Status Check Procedure**



| Bus<br>Operation | Command | Comments                                     |
|------------------|---------|----------------------------------------------|
| Standby          |         | Check SR.3<br>1 = V <sub>PP</sub> Low Detect |
| Standby          |         | Check SR.4,5 Both 1 = Command Sequence Error |
| Standby          |         | Check SR.5<br>1 = Block Erase Error          |

SR.3 MUST be cleared, if set during an erase attempt, before further attempts are allowed by the Write State Machine.

SR.5 is only cleared by the Clear Status Register Command, in cases where multiple blocks are erased before full status is checked.

If error is detected, clear the Status Register before attempting retry or other error recovery.





**Erase Suspend/Resume Flowchart** 



# **APPENDIX C**

List of BIOS software vendors already supporting or announcing their future support for the 28F200BX/002BX flash BIOS chips:

SystemSoft Corporation Contact: Cliff Sharin 508-651-0088 313 Speen Street Natick, MA 01760

Phoenix Technologies Ltd. Contact: Howard Cohen 408-452-6529 40 Airport Parkway San Jose, CA 95110

Award Software, Inc. Contact: Jeffry Flink 408-370-7979 (ext. 214) 130 Knowles Drive Los Gatos, CA 95030-1832 American Megatrends, Incorporated Contact: Tom Rau 404-246-8612 1346 Oakbrook Drive, Suite 120 Norcross, GA 30093

Quadtel Contact: Dale Buscaino 714-754-4422 (ext. 250) 3190-J Airport Loop Costa Mesa, CA 92626



# ENGINEERING REPORT

# The Intel 28F001BX-T and 28F001BX-B Flash Memories

BRIAN DIPERT
OWEN JUNGROTH
MEMORY COMPONENTS DIVISION

October 1993

# 4

# The Intel 28F001BX-T and 28F001BX-B Flash Memories

| PAGE  | CONTENTS                         | PAGE                                                                                                                  |
|-------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| 4-424 | Programming                      | 4-428                                                                                                                 |
|       | Reset-Power Down                 | 4-428                                                                                                                 |
| 4-424 | DEVICE RELIABILITY               | 4-429                                                                                                                 |
| 4-425 | Cell Margining                   | 4-429                                                                                                                 |
| 4-425 | Erase/Program Cycling            |                                                                                                                       |
| 4-426 | SUMMARY                          | 4-430                                                                                                                 |
| 4-426 |                                  |                                                                                                                       |
|       | 4-424<br>4-424<br>4-425<br>4-425 | Programming 4-424 Reset-Power Down 4-424  DEVICE RELIABILITY Cell Margining Erase/Program Cycling 4-425 4-425 SUMMARY |



#### INTRODUCTION

Intel's 28F001BX ETOX (EPROM tunnel oxide) flash memories add selective block erasure, an integrated Write State Machine and powerdown capability to Intel's standard flash memory product line. Flash memory enhances EPROM non-volatility and ease of use through electrical erasure and reprogramming. Advances in tunnel oxides and photolithography have made it possible to develop a double-polysilicon single-transistor read/write random access nonvolatile memory, capable of greater than 100,000 reprogramming cycles. The 28F001BX flash memories electrically erase all bits in a block matrix via electron tunneling. The EPROM programming mechanism of hot electron injection is employed for electrical byte programming.

A Command Register/Status Register interface to a Write State Machine, internal margin voltage generation, power up/down protection and address/data latches augment standard EPROM circuitry to optimize Intel's 28F001BX family for microprocessor-controlled reprogramming.

Read timing parameters are equivalent to those of CMOS EPROMs, EEPROMs and SRAMs. The 120 ns access time results from a memory cell current of approximately 50  $\mu$ A, low resistance poly-silicide wordlines, advanced scaled periphery transistors and an optimized data-out buffer.

The dense one-transistor cell structure, coupled with high array efficiency, yields a one megabit die measuring 235 by 268 mils.

#### **TECHNOLOGY OVERVIEW**

Intel's ETOX flash memory technology is derived from its standard CMOS EPROM process base. Using

advanced 1.0  $\mu m$  double-polysilicon n-well CMOS technology, the 131,072 x 8 bit flash memories employ a 3.8  $\mu m$  x 4.0  $\mu m$  single transistor cell, affording equivalent array density as comparable EPROM technology. The flash memory cell structure is identical to the EPROM structure, except for the thinner gate (tunnel) oxide. Figure 1 compares the flash memory cell to the EPROM cell.



Figure 1. EPROM Cell vs. Flash Memory Cell



High quality tunnel oxide under the single floating polysilicon gate promotes electrical erasure. All cells of a given block are simultaneously erased via Fowler-Nordheim tunneling. Applying 12V on the block source junctions and grounding the select gates erases a given block. The internal Write State Machine (WSM) controls the erase algorithm, including block pre-programming before erasure. WSM-controlled erasure, including internal pre-programming, takes 2.1 seconds typical for each parameter block and the boot block, and 3.8 sec. typical for the main block.

Programming is accomplished with the standard EPROM mechanism of hot electron injection from the cell drain junction to the floating gate. Programming is initiated by bringing both the select gate and the cell drain to high voltage. The internal WSM regulates the

internal program algorithm after the correct command sequence is written to the 28F001BX. Typical program time is 18 µs per byte.

#### DEVICE ARCHITECTURE

### Write State Machine and Command/ Status Registers

Intel's 28F001BX flash memories contain an on-chip Write State Machine that automatically controls erase and program algorithms, dramatically simplifying user interface. Figure 2 shows the 28F001BX block diagram.



Figure 2. 28F001BX Block Diagram



The WSM simpifies microprocessor control of the erase, program, Status Register read/clear, ID read and array read operations, without the need for additional control pins or the multiplexing of high voltage with control functions. The WSM, with its integrated oscillator, performs a majority of the standard flash memory program and erase algorithms automatically. This makes system timers no longer necessary and frees the system to service interrupts or perform other functions during device erase or program. On-chip address and data latches minimize system interface logic and free the system bus. The Write State Machine accepts array read, ID read and Status Register read and clear commands whenever power is applied to the 28F001BX. High voltage (12V) on V<sub>PP</sub> additionally enables successful program and erase.

The WSM consists of a Command Register, Status Register, State Machine, oscillator, command decoder, data latch and address latch. The command decoder output feeds the State Machine, enabling the high voltage flash-erase switch, program voltage generator and erase/program verify voltage generator.

Functions are selected via the Command Register in a microprocessor write cycle controlled by the Chip Enable (CE#) and Write Enable (WE#) pins. The rising edge of WE# latches the address and data-in registers, and initiates an operation. Status Register contents are driven to the outputs on the falling edge of CE# or Output Enable (OE#), whichever occurs last in the read cycle.

#### Internal Oscillator

The Write State Machine is designed using clocked logic circuits. An on chip ring oscillator generates the clock signals. The frequency of a standard ring oscillator varies with processing, temperature and supply voltage. The improved design used on the 28F001BX minimizes these variations.

The switching current of each stage in the ring oscillator is set by a current reference. This reference current varies linearly with  $V_{CC}$ . The trip point of each ring oscillator inverter also varies linearly with  $V_{CC}$ . These two effects essentially cancel each other out and the resulting oscillator period is proportional to RC, with only a small dependence on  $V_{CC}$ .

The value of R is set by an on chip resistor. The value of C is set by the gate capacitance of the inverters in the ring oscillator. Process variations in the values are reduced by trimming the period of each oscillator during manufacturing. The resistor is the only source of temperature variation.

Figure 3 shows how the oscillator period varies with temperature and supply voltage. The circuit works for supply voltages outside the normal operating conditions and for military temperatures.



Figure 3. Internal Oscillator Frequency vs Supply Voltage and Temperature

## **Supply Voltage Sensing**

The circuit that generates LOWV<sub>CC</sub> and LOWV<sub>PP</sub> is shown in Figure 4. Power supply voltages V<sub>CC</sub> and V<sub>PP</sub> are divided down and compared to a reference voltage. If the reference voltage is greater than the divided power supply voltage, the LOWV<sub>CC</sub> or LOWV<sub>PP</sub> signal will be pulled high. The V<sub>REF</sub> level generated by the voltage reference is independent of the supply voltage to the first order.



**Figure 4. Low Power Detector Circuit** 



The positive power supply to the circuit is provided by M1 and M2. The source of M1 and M2 will be pulled up to the maximum of  $(V_{PP}-V_{TN})$  and  $(V_{CC}-V_{TW})$ .  $V_{TN}$  is the threshold of an implanted N channel device, about 0.9V.  $V_{TW}$  is the threshold of a native N channel device, about 0V. This scheme ensures that the circuit will work regardless of the applied supply voltages.

The LOWV<sub>CC</sub> signal not only goes to the erase circuits, but also to the programming circuits and to the control logic to prevent any accidental writes to the array. The LOWV<sub>PP</sub> signal goes to the Write State Machine. If V<sub>PP</sub> is detected as being low during a write, the low V<sub>PP</sub> bit will be set in the Status Register.

#### **Erasure**

Erasure is achieved through a two-step write sequence. The erase setup code is written to the Command Register in the first cycle. The erase confirm code is written in the second cycle. The block to be erased is specified by writing both commands to any address within the

block. The address is latched and decoded internally by the 28F001BX, and erase of the desired block is subsequently enabled. The rising edge of this second WE# pulse initiates the erase operation. The boot block will not erase unless the RP# or OE# signal is brought to high voltage V<sub>HH</sub>.

The State Machine triggers the high voltage flash-erase switch, connecting the 12V supply to the source of all bits in the specified block, while all wordlines are grounded. The organization of the block source switches is shown in Figure 5. Fowler-Nordheim tunnling results in the simultaneous erasure of all bits in the addressed block.

The block source switch controls the source voltage of the bits in a particular block. This circuit is shown in Figure 6. During erase, M2 is off and M1 pulls the source to Vpp. When not in erase, M1 is off and M2 pulls the source to ground. The high voltage latch formed by M4-M7 converts the low voltage ERASE signal to a high voltage signal that turns M1 off or on.



Figure 5. Array Erase Blocking



Figure 6. Block Source Switch



The tunneling that occurs during erase requires only a small amount of current. However, the grounded gate initial erase current that occurs on the source of every bit in the array is large. M1 is made large enough to supply this current and still keep the voltage on the source high enough for fast erase time.

The LOWV $_{\rm CC}$  signal protects the array from being erased when  $V_{\rm PP}$  is at a high voltage but  $V_{\rm CC}$  is a low voltage. When this occurs, M3 will pull the block source to ground. The high voltage latch will be forced into the state that turns M1 off by M8.

After receiving the erase command sequence, the WSM automatically controls block precondition (programming of all bytes to 00H within the chosen block), erase pulses and pulse repetition, timeout delays and byte-bybyte verification of all block addresses using the internally-generated erase margin voltage. The internal erase and verify operations continue until the entire block is erased. System software need only poll the Status Register to determine when the WSM has successfully completed the erase algorithm.

## **Programming**

Programming follows a similar flow. The program setup command is written to the Command Register on the first cycle. The second cycle loads the address and data latches. The rising edge of the second WE# pulse initiates programming by applying high voltage to the gates and drains of the bits to be programmed.

As with erasure, the WSM controls program pulses and pulse repetition, timeout delays and byte verification. Program and program verify (at the internally-generated verify voltage) continue until the byte is programmed. System software, polling the Status Register, is informed of programming state thru specific status bits.

#### **Reset-Power Down**

The 28F001BX has a deep power down mode that reduces  $I_{CC}$  and  $I_{PP}$  to typically 0.05  $\mu A$  and 0.8  $\mu A$ , respectively. When RP# is low, the part is in deep power down mode. When RP# is high, the part can be placed in an active or standby mode by state of the CE# pin.

The deep power down mode is similar to the standby mode except that more circuits are turned off. This means that much less power is consumed; it also means that it takes longer for the part to transition into the active mode.

A diagram of the power down circuit is shown in Figure 7. The TTL buffer formed by M1-M3 enables the low power detect circuits, the redundancy address flash bits and the CE# TTL buffer formed by M4-M6. In previous Intel flash chips these circuits were always enabled. The time for these circuits to turn on determines the RP# access time and write specifications.

RP# will function properly with TTL level inputs. However, to get the lowest possible power consumption, full CMOS levels should be used. If voltage on the gate of M3 raises above its threshold voltage of 0.9V, it will turn on and draw current. Input voltages in the 0.7-0.9 range could cause enough subthreshold conduction in M3 to exceed the deep power down current specification. This is why the input voltage for RP# is specified as GND  $\pm 0.2$ V.

The use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset it expects to read from the flash memory. Automated flash memories provide status information when accessed during write/erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input. In this application RP# is controlled by the same RESET# signal that resets the system CPU.





Figure 7. Power Down Circuits

## **DEVICE RELIABILITY**

## **Cell Margining**

Erase and program verification ensure the data retention of the newly altered memory bits. The cell margining performed by the WSM during the verify phase of the automated algorithms is more reliable than historical EEPROM schemes, as margining tests the amount of charge stored on the floating gate.

Intel's 28F001BX flash memories employ a unique circuit to internally generate the erase and program verify voltages. Figure 8 shows a simplified version of the circuit. The circuit consists of a high voltage switch and the verify voltage generator. Transistors M1 through M4 constitute the high voltage switch which disconnects Vpp from the resistor when the device is not in the verify mode. The verify voltage generator includes a resistor divider and a buffer. Internal margin voltage generation maintains microprocessor compatibility by eliminating the need for external reference voltages.



Figure 8. Erase/Program Verify Generator



## **Erase/Program Cycling**

One of the most significant aspects of 28F001BX flash memories is their capability for 100,000 erase/program cycles per block. Destructive oxide breakdown has been a limiting factor in extended cycling of thin oxide EEPROMs. Intel's ETOX flash memory technology extends cycling performance through:

- Improved tunnel oxide processing that increases charge carrying capability tenfold;
- Reduced oxide area under stress minimizing probability of oxide defects in the region; and
- Reduced oxide stress due to a lower peak electric field (lower erase voltage than EEPROM).

A typical cell erase/program margin (V<sub>t</sub>) is shown as a function of reprogramming cycles in Figure 9. After 100,000 reprograming cycles, a 2.5V program read margin exists, ensuring reliable data retention.

Reliable erase/program cycling also requires proper selection of the erase  $V_t$  maximum and maintenance of a tight  $V_t$  distribution. The maximum erased  $V_t$  is set to 3.2V via the internal erase algorithm and erase verify circuits. Superior oxide quality gives an erased  $V_t$  distribution width that improves slightly with cycling (Figure 10). The tight erase  $V_t$  distribution gives an order of magnitude of erase time margin to the fastest erasing cell.

#### SUMMARY

Intel's ETOX flash memory technology is a breakthrough in adding electrical chip-erasure to high-density EPROM technology. Intel's 28F001BX family enhances Intel's standard flash memory line by adding block erase capability, Write State Machine-controlled program and erase and deep powerdown mode. Microprocessor-compatible specifications, straightforward interfacing and in-circuit selective alterability using simple software command sequences allow designers to easily augment memory flexibility and satisfy the need for nonvolatile storage in today's designs.



Figure 9. Block Vt vs Cycles





Figure 10. Erase Vt Distribution vs Cycling



Figure 11. Block Erase Vt vs Erase Time





Figure 12. 28F001BX Die Photograph





Figure 13. 28F001BX Pinout Configurations



Figure 14. 28F001BX Pinout Configurations



Columns are number 0 through 511 beginning with the column nearest the X-decoder. Outputs are grouped as follows:

|                 |                 |                 | Organiz<br>in Block |                 |                |                | 100 101                           | lf Array<br>IO₂ IO₃<br>← BL <sub>64</sub> | Right Half Array<br>IO <sub>4</sub> IO <sub>5</sub> IO <sub>6</sub> IO <sub>7</sub><br>BL <sub>64</sub> → BL <sub>511</sub> |                   |  |
|-----------------|-----------------|-----------------|---------------------|-----------------|----------------|----------------|-----------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------|--|
|                 |                 | A               | ddress              |                 |                |                |                                   | Bitl                                      | ines                                                                                                                        |                   |  |
| A <sub>16</sub> | A <sub>15</sub> | A <sub>14</sub> | A <sub>13</sub>     | A <sub>12</sub> | A <sub>1</sub> | A <sub>0</sub> | IO <sub>0</sub> & IO <sub>7</sub> | IO <sub>2</sub> & IO <sub>5</sub>         | 1O <sub>3</sub> & 1O <sub>4</sub>                                                                                           |                   |  |
| 0               | . 0             | 0               | 0                   | 0               | 0              | 0 .            | BL <sub>400</sub>                 | BL <sub>288</sub>                         | BL <sub>176</sub>                                                                                                           | BL <sub>64</sub>  |  |
| 0               | 0               | 0               | 0                   | 0               | 0              | .1             | BL <sub>401</sub>                 | BL <sub>289</sub>                         | BL <sub>177</sub>                                                                                                           | BL <sub>65</sub>  |  |
| 0               | 0               | 0               | 0                   | 0               | 1              | 0              | BL <sub>402</sub>                 | BL <sub>290</sub>                         | BL <sub>178</sub>                                                                                                           | BL <sub>66</sub>  |  |
| 0               | 0               | 0               | 0                   | <b>∖</b> 0      | 1              | 1              | BL <sub>403</sub>                 | BL <sub>291</sub>                         | BL <sub>179</sub>                                                                                                           | BL <sub>67</sub>  |  |
| 0               | 0               | 0               | 0                   | 1               | 0              | 0              | BL <sub>404</sub>                 | BL <sub>292</sub>                         | BL <sub>180</sub>                                                                                                           | BL <sub>68</sub>  |  |
| 0               | 0               | 0               | 0                   | 1               | 0              | 1              | BL <sub>405</sub>                 | BL <sub>293</sub>                         | BL <sub>181</sub>                                                                                                           | BL <sub>69</sub>  |  |
| 0               | -0              | 0               | 0                   | 1               | 1              | 0              | BL <sub>406</sub>                 | BL <sub>294</sub>                         | BL <sub>182</sub>                                                                                                           | BL <sub>70</sub>  |  |
| 0               | 0               | 0               | 0                   | 1               | 1              | 1              | BL <sub>407</sub>                 | BL <sub>295</sub>                         | BL <sub>183</sub>                                                                                                           | BL <sub>71</sub>  |  |
| *               | *               | *               | * ,                 | *               | *              | *              | *                                 | *                                         | *                                                                                                                           | *                 |  |
| 1               | 1 1             | 0               | 1                   | 1               | 0              | 0              | BL <sub>508</sub>                 | BL <sub>396</sub>                         | BL <sub>284</sub>                                                                                                           | BL <sub>172</sub> |  |
| 1               | 1               | 0               | 1                   | 1               | 0              | 1              | BL <sub>509</sub>                 | BL <sub>397</sub>                         | BL <sub>285</sub>                                                                                                           | BL <sub>173</sub> |  |
| 1               | 1               | 0               | 1                   | 1               | 1              | 0              | BL <sub>510</sub>                 | BL398                                     | BL <sub>286</sub>                                                                                                           | BL <sub>174</sub> |  |
| 1               | 1 .             | 0               | 1                   | 1               | 1              | 1              | BL <sub>511</sub>                 | BL <sub>399</sub>                         | BL <sub>287</sub>                                                                                                           | BL <sub>175</sub> |  |

Figure 15. Bitline Decoding (Main Block, 28F001BX-T)

|                 | Array Organization (Parameter Block 1): |                 |                 |                 |                |                |                 |                 |                  | 100              | lalf Arra<br><sub>)</sub> −IO <sub>7</sub><br>→ BL <sub>31</sub> | y ,              |                  | . ;              |
|-----------------|-----------------------------------------|-----------------|-----------------|-----------------|----------------|----------------|-----------------|-----------------|------------------|------------------|------------------------------------------------------------------|------------------|------------------|------------------|
|                 | Address                                 |                 |                 |                 |                |                |                 |                 |                  | Bit              | lines                                                            |                  |                  |                  |
| A <sub>16</sub> | A <sub>15</sub>                         | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>1</sub> | A <sub>0</sub> | 100             | 101             | 102              | 103              | 104                                                              | 105              | 106              | 107              |
| 1               | 1                                       | 1               | 0               | 0               | 0              | 0              | BL <sub>0</sub> | BL <sub>4</sub> | BL <sub>8</sub>  | BL <sub>12</sub> | BL <sub>16</sub>                                                 | BL <sub>20</sub> | BL <sub>24</sub> | BL <sub>28</sub> |
| 1               | 1                                       | 1               | 0               | 0               | 0              | 1              | BL <sub>1</sub> | BL <sub>5</sub> | BL <sub>9</sub>  | BL <sub>13</sub> | BL <sub>17</sub>                                                 | BL <sub>21</sub> | BL <sub>25</sub> | BL <sub>29</sub> |
| 1               | 1                                       | 1               | .0              | 0               | 1              | 0              | BL <sub>2</sub> | BL <sub>6</sub> | BL <sub>10</sub> | BL <sub>14</sub> | BL <sub>18</sub>                                                 | BL <sub>22</sub> | BL <sub>26</sub> | BL <sub>30</sub> |
| 1               | 1                                       | 1               | 0               | 0               | 1              | 1              | BL <sub>3</sub> | BL <sub>7</sub> | BL <sub>11</sub> | BL <sub>15</sub> | BL <sub>19</sub>                                                 | BL <sub>23</sub> | BL <sub>27</sub> | BL <sub>31</sub> |

Figure 16. Bitline Decoding (Parameter Block 1, 28F001BX-T)

|                 | Array Organization<br>(Parameter Block 2): |                 |                 |                 |                |                |                  | Right Half Array<br>IO <sub>0</sub> −IO <sub>7</sub><br>BL <sub>32</sub> → BL <sub>63</sub> |                  |                  |                  |                  |                  |                  |
|-----------------|--------------------------------------------|-----------------|-----------------|-----------------|----------------|----------------|------------------|---------------------------------------------------------------------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|
|                 | Address                                    |                 |                 |                 |                |                | . 1              |                                                                                             |                  | Bitli            | nes              |                  |                  |                  |
| A <sub>16</sub> | A <sub>15</sub>                            | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>1</sub> | A <sub>0</sub> | 100              | 101                                                                                         | IO <sub>2</sub>  | 103              | 104              | 105              | 106              | 107              |
| 1               | 1                                          | 1               | 0               | 1               | 0              | 0              | BL <sub>32</sub> | BL <sub>36</sub>                                                                            | BL <sub>40</sub> | BL <sub>44</sub> | BL <sub>48</sub> | BL <sub>52</sub> | BL <sub>56</sub> | BL <sub>60</sub> |
| 1               | 1                                          | 1               | 0               | 1               | 0              | 1              | BL <sub>33</sub> | BL <sub>37</sub>                                                                            | BL <sub>41</sub> | BL <sub>45</sub> | BL <sub>49</sub> | BL <sub>53</sub> | BL <sub>57</sub> | BL <sub>61</sub> |
| 1               | 1                                          | 1               | 0               | 1               | 1              | 0              | BL <sub>34</sub> | BL <sub>38</sub>                                                                            | BL <sub>42</sub> | BL <sub>46</sub> | BL <sub>50</sub> | BL <sub>54</sub> | BL <sub>58</sub> | BL <sub>62</sub> |
| 1               | 1                                          | 1               | 0               | 1               | 1              | 1              | BL <sub>35</sub> | BL <sub>39</sub>                                                                            | BL <sub>43</sub> | BL <sub>47</sub> | BL <sub>51</sub> | BL <sub>55</sub> | BL <sub>59</sub> | BL <sub>63</sub> |

Figure 17. Bitline Decoding (Parameter Block 2, 28F001BX-T)

#### NOTES:

1. Bitline decoding listed is for 28F001BX-T. To convert to 28F001BX-B, invert polarity of addresses  $A_{16}$ - $A_{12}$  (i.e. 0000000 becomes 1111100).



|                 | Array Organization (Boot Block): Address |                 |                 |                 |                |                |                 | Left Half Array<br>IO <sub>7</sub> −IO <sub>0</sub><br>BL <sub>0</sub> → BL <sub>63</sub><br>Bitlines |                  |                  |                  |                  |                  |                  |
|-----------------|------------------------------------------|-----------------|-----------------|-----------------|----------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|
|                 |                                          |                 |                 |                 |                |                |                 |                                                                                                       |                  |                  |                  |                  |                  | ·                |
| A <sub>16</sub> | A <sub>15</sub>                          | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>1</sub> | A <sub>0</sub> | 107             | 106                                                                                                   | 105              | 104              | 103              | 102              | 101              | 100              |
| 1               | 1                                        | 1               | 1               | 0               | 0              | 0              | BL <sub>0</sub> | BL <sub>8</sub>                                                                                       | BL <sub>16</sub> | BL <sub>24</sub> | BL <sub>32</sub> | BL <sub>40</sub> | BL <sub>48</sub> | BL <sub>56</sub> |
| 1               | 1                                        | 1               | 1               | 0               | 0              | 1              | BL <sub>1</sub> | BL <sub>9</sub>                                                                                       | BL <sub>17</sub> | BL <sub>25</sub> | BL33             | BL <sub>41</sub> | BL <sub>49</sub> | BL <sub>57</sub> |
| 1               | 1                                        | 1               | 1               | 0               | 1              | 0              | BL <sub>2</sub> | BL <sub>10</sub>                                                                                      | BL <sub>18</sub> | BL <sub>26</sub> | BL <sub>34</sub> | BL <sub>42</sub> | BL <sub>50</sub> | BL <sub>58</sub> |
| 1               | 1                                        | 1               | 1               | 0               | 1              | 1              | BL <sub>3</sub> | BL <sub>11</sub>                                                                                      | BL <sub>19</sub> | BL <sub>27</sub> | BL <sub>35</sub> | BL <sub>43</sub> | BL <sub>51</sub> | BL <sub>59</sub> |
| 1               | 1                                        | 1               | 1               | 1               | 0              | 0              | BL <sub>4</sub> | BL <sub>12</sub>                                                                                      | BL <sub>20</sub> | BL <sub>28</sub> | BL <sub>36</sub> | BL <sub>44</sub> | BL <sub>52</sub> | BL <sub>60</sub> |
| 1               | 1                                        | 1               | 1               | 1               | 0              | 1              | BL <sub>5</sub> | BL <sub>13</sub>                                                                                      | BL <sub>21</sub> | BL <sub>29</sub> | BL <sub>37</sub> | BL <sub>45</sub> | BL <sub>53</sub> | BL <sub>61</sub> |
| 1               | 1                                        | 1               | 1               | 1               | 1              | 0              | BL <sub>6</sub> | BL <sub>14</sub>                                                                                      | BL <sub>22</sub> | BL30             | BL <sub>38</sub> | BL <sub>46</sub> | BL <sub>54</sub> | BL <sub>62</sub> |
| 1               | 1                                        | 1 .             | 1               | 1               | -1             | 1              | BL <sub>7</sub> | BL <sub>15</sub>                                                                                      | BL <sub>23</sub> | BL <sub>31</sub> | BL <sub>39</sub> | BL <sub>47</sub> | BL <sub>55</sub> | BL <sub>63</sub> |

Figure 18. Bitline Decoding (Boot Block, 28F001BX-T)

#### NOTE:

1. Bitline decoding listed is for 28F001BX-T. To convert to 28F001BX-B, invert polarity of addresses A<sub>16</sub>-A<sub>12</sub> (i.e. 0000000 becomes 1111100).

|                 |                 |    |                | X Add          | ress           |                |                |                | y              | Row              |
|-----------------|-----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------|
| A <sub>11</sub> | A <sub>10</sub> | Ag | A <sub>8</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>3</sub> | A <sub>2</sub> | WL               |
| 0               | 0               | 0  | 0              | 0              | 0              | 0              | 0              | 0              | 0              | XL <sub>0</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | 0              | 0              | 0              | 1              | XL <sub>1</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 0              | XL <sub>2</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | 0              | 0              | 1              | 1              | XL <sub>3</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | 0              | 1 '            | 0              | 0              | XL <sub>4</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | 0              | 1              | 0              | 1              | XL <sub>5</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | 0              | 1              | 1              | 0              | XL <sub>6</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | ۰0             | 1              | 1              | 1              | XL <sub>7</sub>  |
| 0               | 0               | 0  | 0              | 0              | 0              | 1              | 0              | 0              | 0              | XL <sub>8</sub>  |
| 0               | 0 .             | 0  | 0              | 0              | 0              | 1              | 0              | 0              | -1             | XLa              |
| 0               | 0               | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 0              | XL <sub>10</sub> |
| 0               | 0               | 0  | 0              | 0              | 0              | 1              | 0              | 1              | 1              | XL <sub>11</sub> |
| 0               | 0               | 0  | 0              | 0              | 0              | 1              | 1              | 0              | 0              | XL <sub>12</sub> |
| 0               | 0               | 0  | 0              | 0              | 0              | 1              | 1              | 0              | 1              | XL <sub>13</sub> |
| 0               | 0               | 0  | 0              | 0              | 0              | 1              | 1              | 1              | 0              | XL <sub>14</sub> |
| 0               | 0               | 0  | 0              | 0              | 0              | 1              | 1              | 1              | 1              | XL <sub>15</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 1              | 1              | 1              | 1              | XL <sub>16</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 1              | 1              | 1              | 0              | XL <sub>17</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 1              | 1              | 0              | 1              | XL <sub>18</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 1              | 1              | 0              | 0              | XL <sub>19</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 1              | 0              | 1              | 1              | XL <sub>20</sub> |
| 0               | 0               | 0  | 0              | 0.             | 1              | 1              | 0              | 1              | 0              | XL <sub>21</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 1              | 0              | 0              | 1              | XL22             |
| 0               | 0               | 0  | 0              | 0              | 1              | 1              | 0              | 0              | 0              | XL <sub>23</sub> |
| 0               | - 0             | 0  | 0              | 0              | 1              | 0              | 1              | 1              | 1              | XL <sub>24</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 0              | 1              | 1              | 0              | XL25             |
| 0               | 0               | .0 | 0              | 0              | 1              | 0              | 1              | 0              | 1              | XL <sub>26</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 0              | 1              | 0              | 0              | XL <sub>27</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 1              | XL <sub>28</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 0              | 0              | 1              | 0              | XL <sub>29</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 0              | 0              | 0              | 1              | XL <sub>30</sub> |
| 0               | 0               | 0  | 0              | 0              | 1              | 0              | 0              | 0              | 0              | XL <sub>31</sub> |

Figure 19. Wordline Decoding (28F001BX-T and 28F001BX-B)



| X Address       |                 |     |                |                |                |                |                |                |                | Row                     |
|-----------------|-----------------|-----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-------------------------|
| A <sub>11</sub> | A <sub>10</sub> | Ag  | A <sub>8</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>3</sub> | A <sub>2</sub> | WL                      |
| 0               | 0               | 0   | 0 *            | 1 *            | 0              | 0              | 0              | 0              | 0              | XL <sub>32</sub>        |
| 0               | 0               | 0   | 0              | . 1            | 0              | 1              | 1              | 1              | 1              | XL <sub>47</sub>        |
| 0               | 0               | *   | 0 *            | 1,             | 1              | . 1            | 1 *            | 1              | 1 *            | XL <sub>48</sub><br>*** |
| 0               | 0               | 0   | 0              | 1              | 1              | 0              | 0              | 0              | 0              | XL <sub>63</sub>        |
| 0               | 0               | 0   | 1              | 0              | 0              | 0              | 0              | 0              | 0              | XL <sub>64</sub><br>*** |
| 0               | 0               | 0   | -1             | 0              | .0             | . 1            | 1              | 1              | 1              | XL <sub>79</sub>        |
| 0               | 0               | 0   | 1 *            | 0              | 1              | 1 *            | 1 *            | 1              | 1 *            | XL <sub>80</sub>        |
| 0               | 0               | 0   | 1              | 0              | 1              | 0              | 0              | 0              | 0              | XL <sub>95</sub>        |
| 1 *             | 1               | 1 * | 1 *            | 1              | 0<br>*         | 0              | 0              | 0              | 0              | XL <sub>992</sub>       |
| 1               | 1               | 1   | 1              | 1              | 0              | 1              | 1              | 1              | . 1            | XL <sub>1007</sub>      |
| 1 *             | · 1             | 1 * | 1              | 1              | 1 *            | 1              | 1 *            | 1 *            | 1              | XL <sub>1008</sub>      |
| 1               | 1               | 1   | 1              | 1              | 1              | 0              | 0              | 0              | 0              | XL <sub>1023</sub>      |

Figure 19. Wordline Decoding (28F001BX-T and 28F001BX-B) (Continued)

|             |                                  |                                  | ,                                |                                  | Array                              | Org | ganizatio         | n                                     |                                  | /                                |                                  |                                  |
|-------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|------------------------------------|-----|-------------------|---------------------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|
| ROW SELECTS | Main<br>Block<br>IO <sub>0</sub> | Main<br>Block<br>IO <sub>1</sub> | Main<br>Block<br>IO <sub>2</sub> | Main<br>Block<br>IO <sub>3</sub> | Boot<br>Block<br>IO <sub>0-7</sub> |     | IO <sub>0-7</sub> | Param<br>2 Block<br>IO <sub>0-7</sub> | Main<br>Block<br>IO <sub>4</sub> | Main<br>Block<br>IO <sub>5</sub> | Main<br>Block<br>IO <sub>6</sub> | Main<br>Block<br>IO <sub>7</sub> |
|             |                                  |                                  |                                  |                                  | COLUI                              | MN  | SELECT            | S                                     |                                  |                                  |                                  |                                  |

Figure 20. Array Organization

# **REVISION HISTORY**

| Number | Description                                          |  |  |  |  |
|--------|------------------------------------------------------|--|--|--|--|
| 002    | Swapped Figures 9 and 10 Added Figure 11             |  |  |  |  |
| 003    | PWD changed to RP# for JEDEC standard compatibility. |  |  |  |  |



# ENGINEERING REPORT

# The Intel 2/4-Mbit Boot Block Flash Memory Family

ALAN BUCHECKER
PETER HAZEN
MEMORY COMPONENTS DIVISION

October 1993

# The Intel 2/4 Mbit Boot Block Flash Memory Family

| <b>CONTENTS</b> PA                                                                              | AGE  |
|-------------------------------------------------------------------------------------------------|------|
| INTRODUCTION       4         Word/Byte-Wide Versions       4         Byte-Wide Versions       4 | -439 |
| TECHNOLOGY OVERVIEW4                                                                            | -439 |
| DEVICE ARCHITECTURE 4                                                                           | -440 |
| Array Organization4                                                                             | -440 |
| Block Memory Maps4                                                                              | -441 |
| Write/Erase Automation 4                                                                        | -441 |
| Command User Interface (CUI) 4                                                                  | -441 |
| Write State Machine (WSM)4                                                                      | -444 |
| Status Register 4                                                                               | -445 |
| Internal Oscillator4                                                                            | -446 |
| Supply Voltage Sensing4                                                                         | -446 |
| Deep Power-Down and Device Reset 4                                                              | -446 |
| Automatic Power Savings4                                                                        | -447 |
| Block Erase4                                                                                    | -447 |
| Erase Suspend/Resume4                                                                           | -449 |
| Word/Byte Write4                                                                                | -449 |

| CONTENTS                                                | PAGE  |
|---------------------------------------------------------|-------|
| DEVICE CHARACTERIZATION                                 | 4-449 |
| A.C. and D.C. Parameters                                | 4-449 |
| Energy/Power Consumption                                | 4-450 |
| Word/Byte-Write and Block-Erase<br>Times                | 4-450 |
| DEVICE RELIABILITY                                      | 4-450 |
| Word/Byte-Write and Block-Erase Cycling Data Protection |       |
| SUMMARY                                                 | 4-451 |
| OTHER REFERENCES                                        | 4-451 |



#### INTRODUCTION

The ETOX III (EPROM tunnel oxide) 2/4-Mbit family of Intel boot block Flash Memories are a continuation of boot-top and boot-bottom architectures first introduced in the 1-Mbit 28F001BX-T and 28F001BX-B devices. Top (-T) and bottom (-B) boot block offerings provide compatibility for microprocessors that boot from high or low memory addresses.

All versions of this new family provide a 16-Kbyte hardware-protected boot block, two 8-Kbyte parameter blocks and a 96-Kbyte main block. The 2-Mbit products have an additional 128-Kbyte main block, while 4-Mbit offerings contain three additional 128-Kbyte main blocks.

Flash memories combine inherent non-volatility with in-system alterability of device contents. Selective block erasure allows manipulation of data contents within one of the seven (or five) mini-array segments without affecting data stored in the other six (or four). Advances in process control have allowed development of a double-polysilicon single-transistor flash memory capable of 100,000 write/erase cycles per block. The 2/4-Mbit boot block family electrically erases all bits in a block via electron tunneling. The EPROM programming mechanism of hot-electron injection is employed for high-performance electrical word/byte write as required for computing and embedded applications.

An integrated Command User Interface (CUI) simplifies microprocessor control of device operations (word/byte write, block erase, erase suspend/resume, Status Register read/clear, array read and device identifier read). The internal Write State Machine (WSM) controls all functions and circuits associated with word/byte-write and block-erase operations, including pulse widths and repetition, timeout delays, erase preconditioning and margined verifications. The WSM continually updates the internal Status Register during these functions. The Status Register is read via outputs DQ0-DQ7 providing feedback of WSM activities.

The CUI and Status Register interface to power-up/down-protection circuitry, address/data latches and the WSM. This interface augments first-generation flash memory circuitry to optimize Intel's 2/4-Mbit boot block family for microprocessor-controlled word/byte write and block erase.

A deep-power-down mode enables extremely low power consumption to augment reduced-power standby operation. An automatic power savings feature reduces I<sub>CC</sub> during read mode.

A 60 ns access time ( $t_{ACC}$ ) results from a memory cell current of approximately 70  $\mu$ A, low-resistance polysilicide wordlines strapped with metal, advanced scaled periphery transistors and improved circuit techniques.

The dense one-transistor cell structure, coupled with high array efficiency, yields a 4-Mbit die measuring 295 by 331 mils and a 2-Mbit die measuring 295 by 221 mils

## Word/Byte-Wide Versions

Intel's 28F400BX is a 4,194,304-bit non-volatile memory organized as either 262,144 words (256K x 16) or 524,288 bytes (512K x 8). A dedicated BYTE# control input provides selection of the desired input/output (I/O) configuration (either x16 or x8) for read operations and data writes.

Intel's 28F200BX is a 2,097,152-bit non-volatile memory organized as either 131,072 words (128K x 16) or 262,144 bytes (256K x 8). This device also provides BYTE# control of I/O configuration.

The 28F400BX and 28F200BX are available in the 44-lead Plastic Small Outline Package (PSOP) and the 56-lead Thin Small Outline Package (TSOP).

# **Byte-Wide Versions**

Intel's 28F004BX is a 4,194,304-bit non-volatile memory arranged as 524,288 bytes (512K x 8). Intel's 28F002BX is a 2,097,152-bit non-volatile memory arranged as 262,144 bytes (256K x 8).

With lower pin counts compared to their x8/x16 equivalents, the 28F004BX and 28F002BX allow housing in the smaller 40-lead TSOP.

#### TECHNOLOGY OVERVIEW

Intel's ETOX III Flash Memory technology incorporates advances from ETOX I and ETOX II processes, and leverages over two decades of EPROM manufacturing experience. Using advanced 0.8  $\mu$ m double-polysilicon N-well/P-well CMOS technology, the 2/4-Mbit boot block flash memories employ a 2.5  $\mu$ m x 2.9  $\mu$ m single-transistor cell affording array density equivalent to comparable EPROM technology, and twice that of Intel's ETOX II process. The ETOX III flash memory cell is identical to 0.8  $\mu$ m EPROM, except for an additional source implant which optimizes erase performance. Figure 1 shows a cross-section of the flash memory cell.





Figure 1. Flash Memory Cell

High-quality tunnel oxide under the single floating polysilicon gate promotes electrical erasure. All cells within the selected block are simultaneously erased via Fowler-Nordheim tunneling. Applying 12V to block source junctions and grounding the select gates erases all cells within that block. The internal WSM controls the automated block-erase algorithm, including preerase conditioning (i.e. pre-programming all block bits) and margin verification, in response to user requests relayed by the CUI. WSM-controlled block erasure, including pre-programming, typically ranges from 1.0 to 2.4 seconds depending on the size of the block selected.

Word/byte write is accomplished with the standard EPROM mechanism of channel hot-electron injection from the cell drain junction to the floating gate. Bringing both the select gate and the cell drain to high voltage initiates programming. The WSM regulates the internal word/byte-write algorithm, including margin verification, after the correct command sequence is written and decoded. Word/byte write typically requires 9 μs.

#### **DEVICE ARCHITECTURE**

#### **Array Organization**

Layout of the 2/4-Mbit boot block family is segmented as two array planes (see Figure 2). This organization allows improved access times via minimal internal busing, thus balancing the need for high speed with the requirement of small die size for cost-effective solutions. In the 4-Mbit family, each array plane is 1024 rows by 2048 columns. For the 2-Mbit family, each array plane is 1024 rows by 1024 columns. Access time

is reduced by limiting column length to 1024 cells. The polysilicon row is strapped in metal every 512 columns to reduce wordline delay. Two row decoders run vertically along the array plane sides, and column decoders run horizontally between array planes. Figure 36 shows a die photo of the 4-Mbit family.

Each array plane is divided into eight I/Os for the 28F400BX/200BX. The upper plane consists of the high-byte I/Os (DQ<sub>8</sub>-DQ<sub>15</sub>), while the lower plane consists of the low-byte I/Os (DQ<sub>0</sub>-DQ<sub>7</sub>). During byte-wide operation (BYTE# = "0") the high-byte I/Os are multiplexed through the low-byte I/Os via  $A_{-1}$  decoding. Data for I/O<sub>0</sub> is stored in the left-most 256 columns (or 128 columns for the 28F200BX) of the lower plane, with the next 256 columns (or 128) storing data for I/O<sub>1</sub>, etc. Data for I/O<sub>8</sub> is stored in the left-most 256 (or 128) columns of the upper plane, with the next 256 (or 128) columns storing data for I/O<sub>9</sub>, etc.

For the dedicated byte-wide products (28F004BX/002BX), data for a given I/O is divided between the upper and lower array planes as decoded by  $A_{10}$ . Data for I/O<sub>0</sub> is stored in the left-most 256 columns (or 128 columns for the 28F002BX) of both the upper and lower planes, with the next 256 columns (or 128) in each plane storing data for I/O<sub>1</sub>, etc.

Since each I/O is a grouping of adjacent columns (256 or 128), the independently-erasable blocks (seven or five) are segmented within each I/O. Each I/O in the 4-Mbit family is divided into seven blocks; including a 16-Kbyte boot block, two 8-Kbyte parameter blocks, one 96-Kbyte main block and three 128-Kbyte main blocks. Each I/O in the 2-Mbit family is divided into five blocks; including a 16-Kbyte boot block, two 8-Kbyte parameter blocks, one 96-Kbyte main block and one 128-Kbyte main block . Each block source is electrically isolated from the sources of the other six (or four) blocks. This allows individual block erase without altering data in the other blocks.

Addresses  $A_9$ - $A_0$  select one of 1024 rows. Row address lines are decoded sequentially for selection. Table 3 lists row address bitmaps.

Columns are decoded by  $A_{18}$ – $A_{10}$  for the 28F004BX,  $A_{17}$ – $A_{10}$  for the 28F400BX and 28F002BX, and  $A_{16}$ – $A_{10}$  for the 28F200BX. 4-Mbit family columns are numbered 0–255 for each I/O, and 2-Mbit columns are numbered 0–127 for each I/O. Table 4 and 5 lists column address bitmaps.



| ROW DECODER    | I/O 8<br>(I/O 0)* | I/O 9<br>(I/O 1)* | I/O 10<br>(I/O 2)* | I/O 11<br>(I/O 3)* | I/O 12<br>(I/O 4)* | I/O 13<br>(I/O 5)* | I/O 14<br>(I/O 6)* | I/O 15<br>(I/O 7)* |          |  |
|----------------|-------------------|-------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|----------|--|
| COLUMN DECODER |                   |                   |                    |                    |                    |                    |                    |                    |          |  |
| ROW DECODER    | 1/0 0<br>(1/0 0)* | I/O 1<br>(I/O 1)* | 1/0 2<br>(1/0 2)*  | 1/0 3<br>(1/0 3)*  | I/O 4<br>(I/O 4)*  | 1/0 5<br>(1/0 5)*  | 1/0 6<br>(1/0 6)*  | 1/0 7<br>(1/0 7)*  |          |  |
| •              |                   |                   |                    |                    |                    |                    |                    |                    | 294013-2 |  |

Figure 2. 2/4-Mbit Boot Block Family Array Organization ((I/O#)\* Denotes 28F004BX/002BX I/Os)

# **Block Memory Map**

Top (-T) and bottom (-B) boot block offerings have block address maps which are inverted from one another to provide compatibility for microprocessors that boot from high or low memory addresses. Figures 3, 4, 5 and 6 show 28F400BX-T/B, 28F200BX-T/B, 28F004BX-T/B and 28F002BX-T/B memory maps. The addresses shown in Figures 3 and 4 for the 28F400BX-T/B and 28F200BX-T/B, decode two bytes of data. A<sub>-1</sub> decodes between the two bytes when BYTE# is low.

#### Write/Erase Automation

Intel's 2/4-Mbit boot block Flash Memories contain an on-chip Command User Interface. Write State Machine, Status Register and address/data latches to dramatically simplify user interface. This combination of functional units reduces microprocessor control

complexity of word/byte-write block-erase, erase-suspend/resume, Status Register-read/clear, ID-read and array-read operations. Figures 7 and 8 show 28F400BX/200BX and 28F004BX/002BX block diagrams.

## Command User Interface (CUI)

The CUI consists of a command decoder and command register. User requests are decoded and latched in a microprocessor write cycle controlled by Chip Enable (CE#) and Write Enable (WE#). Status Register-read/clear, ID-read and array-read commands are directly handled by the CUI. The CUI also accepts word/byte-write, block-erase and erase-suspend/resume commands. WE#'s rising edge latches address, command and data-in registers, and requests WSM initiation of the selected operation. These on-chip address, command and data latches, controlled by the CUI, minimize system interface logic and free the system bus





Figure 3. 28F400BX-T/B Memory Maps



Figure 4. 28F200BX-T/B Memory Maps





Figure 5. 28F004BX-T/B Memory Maps



Figure 6. 28F002BX-T/B Memory Maps



#### Write State Machine (WSM)

The WSM processes word/byte-write, block-erase and erase-suspend/resume requests received from the CUI. The WSM rejects word/byte-write and block-erase requests if the WSM is currently busy, if Vpp is not at high voltage (12V) or if the Low Vpp Status Register flag is set (i.e. not cleared from a previous low-voltage condition).

The WSM consists of an integrated oscillator and control circuitry. It generates signals which control the word/byte-write, block-erase, erase-suspend/resume and verify circuits. It also receives feedback from these circuits, allowing Status Register updates. The WSM and associated circuits perform the equivalent of first-generation flash memory program and bulk-erase algorithms automatically.

This eliminates the need for system timers, and frees the microprocessor to service interrupts or perform other functions during device word/byte-write or block-erase operations.

The WSM provides feedback to the CUI to determine when a given command is valid. Although nearly all commands are available when the WSM is inactive, only status read is valid while the WSM performs a word/byte-write operation. During block erase, only the read-status and erase-suspend commands are available. Read-array, read-status, and erase-resume commands are valid with the WSM in an erase-suspended state. Invalid operations are interpreted as the read-array command when the WSM is inactive or erase suspended, and as the read-status command when the WSM is active in word/byte write or block erase.



Figure 7. 28F400BX/200BX Block Diagram



## **Status Register**

The internal Status Register contains a full complement of activity status bits. These bits and their meaning, "1/0" are:

SR.7: WSM status (READY/BUSY#)

SR.6: Erase-suspend status (ERASE SUSPENDED/ ERASE IN PROGRESS# or COMPLETED#)

SR.5: Block-erase status (ERROR/SUCCESS#)

SR.4: Word/byte-write status (ERROR/SUCCESS#)

SR.3: Vpp status (LOW/OK#)

All bits are set by the WSM, and read via the CUI. The WSM can only set SR.3, SR.4 and SR.5; it cannot clear them. They remain set until the CUI processes a clear Status Register command. There are two reasons for operating in this fashion. First is synchronization; the WSM does not know when the host CPU has read the Status Register, therefore does not know when to clear it.

Secondly, allowing system software to control reset adds flexibility to the way this device may be used. The CPU may write several words/bytes, or erase several blocks back-to-back, while polling SR.7 to determine when the next word/byte-write or block-erase command can be given. When all words/bytes are written, or all blocks erased, the system polls the other status flags to determine if all operations were successful, or if an error occurred. While other approaches require the controlling microprocessor to watch for non-completion of write or erase within a specified time to indicate an error, this implementation requires no external system can reduce its polling overhead while still identifying any potential error conditions.

Status Register contents are driven to device outputs on the falling edge of CE# or Output Enable (OE#), whichever occurs last in the read cycle. CE# or OE# must be toggled to update Status Register contents.



Figure 8. 28F004BX/002BX Block Diagram



#### **Internal Oscillator**

The WSM is designed using clocked logic circuits. An on-chip ring oscillator generates the clock signals. The frequency of a standard ring oscillator varies with processing, temperature and supply voltage. A proven design used on the 28F001BX-T/B, 28F008SA and 2/4-Mbit boot block family minimizes these variations.

The switching current of each stage in the ring oscillator is controlled by a current reference which varies linearly with  $V_{\rm CC}$ . The trip point of each ring oscillator inverter also varies linearly with  $V_{\rm CC}$ . These two effects offset each other, and the resulting oscillator period is proportional to RC with only a small dependence on  $V_{\rm CC}$ .

An on-chip resistor sets the value of R. The gate capacitance of the inverters in the ring oscillator sets the value of C. Process variations in these values are reduced by trimming the period of each oscillator during manufacturing. The resistor is the only source of temperature variation.

#### **Supply Voltage Sensing**

Figure 9 shows the LOWV $_{\rm CC}$  and LOWV $_{\rm PP}$  generation circuits. Power supply voltages (V $_{\rm CC}$  and V $_{\rm PP}$ ) are divided down and compared to a reference voltage. If V $_{\rm REF}$  is greater than the divided power supply voltage, the LOWV $_{\rm CC}$  or LOWV $_{\rm PP}$  signal is driven high. The generated V $_{\rm REF}$  level is supply-voltage independent to the first order.

Positive power to the circuit is supplied by M1 and M2. M1 and M2 sources are pulled up to the higher of  $(V_{PP}-V_{tn})$  or  $(V_{CC}-V_{tw})$ .  $V_{tn}$  is the threshold of an implanted N-channel device, about 0.9V.  $V_{tw}$  is the threshold of a native N-channel device, about 0V. This scheme ensures that the circuit works regardless of the applied supply voltages.

The  $LOWV_{CC}$  signal is used by the word/byte-write and block-erase circuits, as well as the CUI and WSM.



Figure 9. Low-Power Detector Circuit

If  $LOWV_{CC}$  is active, the CUI will not accept user writes and resets to an array-read condition. The WSM is similarly reset by  $LOWV_{CC}$ . The  $LOWV_{PP}$  signal is used by the WSM; if  $V_{PP}$  drops below the high-voltage detector trip point during word/byte write or block erase, the Status Register's low  $V_{PP}$  bit is set and WSM operation halts. The system must clear the Status Register before any subsequent word/byte-write or blockerase operations can succeed.

#### **Deep Power-Down and Device Reset**

The 2/4-Mbit boot block family incorporates a deeppower-down mode that reduces  $I_{CC}$  and  $I_{PP}$  to typically 0.20  $\mu$ A and 0.07  $\mu$ A respectively. RP# low selects deep power-down. When RP# is high, the device can be placed in an active or standby mode depending on CE# state.

Deep power-down is similar to standby except that all circuits excluding the RP# buffer are turned off. This mode greatly reduces power consumption, but requires more time to transition the device into an active mode. A read wake-up time (tpHQV) is required from RP# switching high until output and sense circuitry become fully functional and data can be read from the part. Similarly, a write wake-up time (tpHWL) is needed before the CUI recognizes writes. After this interval normal operation is restored; the CUI is reset to read-array mode and the Status Register is cleared to 80H.

Figure 10 shows a diagram of the power-down circuit. The TTL buffer formed by M1-M3 disables the low-power detect circuits, the redundancy-address flash bits and the CE# TTL buffer formed by M4-M6. These circuits were always enabled in first-generation Intel flash architectures. Turn-on delays of these circuits determine RP# access time and write specifications.



Figure 10. Power-Down and Reset Functions



RP# functions properly with TTL-level inputs. However, to attain lowest possible power consumption, full CMOS levels must be used. If the voltage on the gate of M3 rises above its 0.9V threshold, M3 will turn on and draw current. Input voltages in the 0.7V-0.9V range could cause enough current conduction in M3 to exceed the  $I_{CC}$  deep-power-down current ( $I_{CCD}$ ) specification. This is why RP#'s input voltage is specified as GND  $\pm$ 0.2V.

RP# also functions as a hardware reset to the WSM and CUI. If RP# is driven low ("0") during word/byte write, block erase, or erase suspend, that operation is aborted leaving the addressed memory locations in an unknown state. The Status Register is cleared, and CUI is set to array read. The aborted operation (word/byte write or block erase) must be repeated with RP# inactive to obtain a valid condition in the memory array.

RP# reset should be restricted to system reset only (as in the case of power supply failure), and should not be used as a standard means to terminate word/byte-write or block-erase operations. NOTE: Use the erase-suspend command to read another block (see the "Erase Suspend/Resume" section).

This use of RP# during system reset is important with automated write/erase devices. When the system comes out of reset it expects to read from the flash memory. Automated flash memories provide status information when accessed during write/erase modes. If a CPU reset occurs with no flash memory reset, proper CPU initialization would not occur because the flash memory would be providing the status information instead of array data. Intel's Flash Memories allow proper CPU initialization following a system reset through the use of the RP# input.

#### **Automatic Power Savings**

The 2/4-Mbit boot block flash memories include an automatic power-savings feature that reduces  $I_{CC}$  during read mode. Within one access time  $(t_{ACC} \text{ or } t_{CE})$  after an address or CE# switches,  $I_{CC}$  automatically powers down from the 60 mA  $I_{CC}$  CMOS specification (or 65 mA TTL specification) to less than 1 mA.  $I_{CC}$  remains below 1 mA until either CE# or an address is switched, or until the device is taken out of read mode. This feature provides significant power savings for applications that access the device slower than their specified read access times.

#### **Block Erase**

Block erasure is achieved by a two-step write sequence. The erase-setup code is written to the CUI in the first cycle. Erase confirm is written in the second cycle. The address supplied with the erase-confirm command is latched and decoded internally by the device; erase is subsequently enabled in that block. The second WE#rising edge initiates the operation (WE#-controlled write).

The WSM triggers the high-voltage flash-erase switch connecting the 12V supply to the source of all bits in the specified block, while all wordlines are grounded. Figure 12 shows organization of the block source switches. Fowler-Nordheim tunneling results in simultaneous erasure of all bits in the selected block.

The block source switch (shown in Figure 11) controls the source voltage of all bits in a particular block. During block erase, M2 is off and M1 pulls the source to V<sub>PP</sub>. When not in erase, M1 is off and M2 pulls the source to ground. The high-voltage latch formed by M4-M7 converts the low-voltage ERASE signal to a high-voltage signal that controls M1.



Figure 11. Block Source Switch





Figure 12. Array Erase Blocking

The tunneling that occurs during block erase requires only a small amount of current. However, the initial current required to charge the block's cumulative source capacitance to the erase voltage is large. Supply decoupling design practices minimize the system impact of the source charging.

The LOWV<sub>CC</sub> signal protects the array from erasure when  $V_{PP}$  is at a high voltage, but  $V_{CC}$  is below the write/erase lockout voltage ( $V_{LKO}$ ). When this occurs, M3 pulls the block source to ground. The high-voltage latch is forced by M8 into the state that turns MI off.

V<sub>PP</sub> is continually monitored during all phases of the block-erase operation. If V<sub>PP</sub> falls below the trip point of its high-voltage detect circuitry, erasure will not occur (or halts) and Status Register V<sub>PP</sub> status (SR.3), block-erase status (SR.5) and WSM status (SR.7) bits are set to "1".

If SR.3 is set (Low V<sub>PP</sub>), WSM operation is inhibited. The WSM will not execute further word/byte-write or block-erasure sequences until the Status Register has been reset by system software. Word/byte-write or block-erase requests with error flags SR.4 or SR.5 set are not inhibited, but the system loses the ability to determine success. The clear Status-Register command resets these bits.

After receiving the block-erase command sequence, the WSM automatically controls block pre-condition (programming all words to 0000H within the chosen block), erase pulses and pulse repetition, timeout delays, and word-by-word verification of all block addresses (sequentially checked via the address counter) using an alternative sensing reference to verify margin. The internal erase and verify operations continue until the entire block is erased. A read cycle applied to the part following the block-erase command sequence outputs Status Register contents; system software can poll the Status Register to determine when block erase has successfully completed. Following block erasure, the device remains in Status Register read block erasure, the device remains in Status Register read mode: a read-array command must be written to the device to access array data.

If the erase-setup command is followed with a command other than erase confirm, the device will not erase. The WSM sets both word/byte-write status and block-erase status bits in the Status Register to indicate an invalid sequence.



#### Erase Suspend/Resume

Erase suspend allows the system to interrupt block erase to read data from another array block. The ability to suspend erase and read data from another block offers the flexibility required for embedded applications. Upon receiving the erase-suspend command. the CUI requests that the WSM pause at one of several predetermined points in the algorithm. Upon reaching a suspend point, the WSM sets SR.6 (erase-suspend status) and SR.7 to "1". The system must poll the Status Register to determine if the suspend has been processed or the block erase has actually completed. Block-erase completion is indicated by SR.6 cleared to "0" and SR.7 set to "1". Read bus cycles default to Status Register read after issuing the erase-suspend command.

Once suspended, the WSM asserts a signal to the CUI which allows response to the read-array, read-status, and erase-resume commands. The system can write the read-array command allowing read access to blocks other than that which is suspended. The WSM continues to run, idling in a suspended state, regardless of all control inputs except RP#. RP# driven low immediately shuts down the WSM, aborting the suspended erase operation.

The erase-resume command must be issued upon completion of reads from other array blocks to continue block-erase operation. The WSM then clears SR.6 and SR.7, and resumes erase operation from the suspension point. Read cycles following the erase-resume command output Status Register data.

#### Word/Byte Write

Word/byte write follows a flow similar to block erase. The word/byte-write-setup command is first written to the CUI. A second write cycle loads address and data latches. The rising edge of the second WE# pulse requests that the WSM initiate activity, applying high voltage to the gates and drains of all bits to be written. Unlike block erase, word/byte write will proceed regardless of what data is applied on the second CUI write cycle; however writing data FFFFH (or FFH) does not modify memory contents.

Like block erase, the WSM controls program pulses and pulse repetition, timeout delays and word/byte verification. Word/byte write and verify (with alternate sensing reference and internally-generated verify voltage) continue until the word/byte is written. Internal word/byte-write verify checks that all bits written to zero have been correctly modified; it does not check

bits specified as one. Word/byte write cannot change existing zeros to ones; this can only be accomplished by erase.

Read bus cycles following word/byte-write operations output Status Register data. System software, polling the Status Register, is informed of status through bits SR.3, SR.4, and SR.7. The read-array command must be written to the CUI following word/byte write to access array data.

In a scenario similar to that described under block erasure, word/byte write does not occur (or halts) if V<sub>PP</sub> is detected low. In such a case SR.3, SR.4, and SR.7 are set high, and no further writes can take place until the Status Register is cleared by the Clear Status Register command.

#### **DEVICE CHARACTERIZATION**

#### **AC and DC Parameters**

Figures 14 through 35 show graphs of several device parameters as a function of temperature and supply voltage.

In particular, note Figure 14 which shows typical read performance  $t_{AVQV}$  ( $t_{ACC}$ ) of the 28F400BX, which is representative of the 2/4-MBit boot block flash memory family, as a function of  $V_{CC}$  and ambient temperature.  $t_{ELQV}$  ( $t_{CE}$ ) in Figure 15 and  $t_{GLQV}$  ( $t_{OE}$ ) in Figure 16 are also of particular interest. Access times  $t_{AVQV}$ ,  $t_{ELQV}$ , and  $t_{GLQV}$  are specified and tested with an output load of 100 pF; decreased output load capacitance improves device operation.

Table 1 shows typical supply currents for several operating modes.

**Table 1. RMS Current Values** 

| Mode            | (Vcc    | CC<br>= 5.0V,<br>Inputs) | l <sub>pp</sub><br>(V <sub>pp</sub> = 12V) |
|-----------------|---------|--------------------------|--------------------------------------------|
|                 | х8      | x16                      | (                                          |
| Read (6 MHz)    | 23 mA   | 25 mA                    | 100 μΑ                                     |
| Write           | 20 mA   | 22 mA                    | 10 mA                                      |
| Block Erase     | 15 mA   | 15 mA                    | 12 mA                                      |
| Standby         | 50 μΑ   | 50 μΑ                    | 100 μΑ                                     |
| Deep Power-Down | 0.20 μΑ | 0.20 μΑ                  | 0.07 μΑ                                    |



#### **Energy/Power Consumption**

The system designer may be concerned with power consumption during block erase and word/byte write. Figure 32 shows  $I_{\rm CC}$  and  $I_{\rm PP}$  during block erase. Figure 33 shows  $I_{\rm CC}$  and  $I_{\rm PP}$  during word/byte write.

### Word/Byte-Write and Block-Erase Times

The 2/4-Mbit boot block family and 28F008SA advance word/byte-write and block-erase performance compared to previous flash memories. The on-chip algorithm is improved over the 28F001BX to take advantage of process enhancements. This improvement is most apparent when compared to first-generation flash memory parts with externally controlled algorithms. First-generation device times shown in Table 2 assume optimal system overhead, and as such are absolute best case.

#### **DEVICE RELIABILITY**

# Word/Byte-Write and Block-Erase Cycling

One of the most important reliability aspects of the 2/4-Mbit boot block family is its capability of 100,000 write/erase cycles per block. Destructive oxide breakdown has been a limiting factor in extended cycling of thin-oxide EEPROMs. Intel's ETOX Flash Memory technology extends cycling performance through:

- Improved tunnel-oxide processing that increases charge-carrying capability tenfold.
- Significantly reduced oxide area under stress that minimizes probability of oxide defects in the region.
- Reduced oxide stress due to a lower peak electric field (lower erase voltage than EEPROM).

Table 2. Word/Byte-Write and Block-Erase
Performance vs Previous Devices

| Device    | evice Word/Byte- Bl                       |                | Erase Time per Kbyte |  |  |  |  |  |  |  |  |
|-----------|-------------------------------------------|----------------|----------------------|--|--|--|--|--|--|--|--|
| SECOND-G  | SECOND-GENERATION FLASH MEMORY DEVICES(1) |                |                      |  |  |  |  |  |  |  |  |
| 28F400BX  | 9 μs                                      | 2.4s/128KB     | 19 ms                |  |  |  |  |  |  |  |  |
| 28F004BX  | 9 μs                                      | 2.2s/96KB      | 23 ms                |  |  |  |  |  |  |  |  |
| 28F200BX  | 9 μs                                      | 1.0s/16KB      | 63 ms                |  |  |  |  |  |  |  |  |
| 28F002BX  | 9 μs                                      | 1.0s/8KB       | 125 ms               |  |  |  |  |  |  |  |  |
| 28F008SA  | 9 μs                                      | 1.5s/64KB      | 23 ms                |  |  |  |  |  |  |  |  |
| 28F001BX  | 18 μs 3.8s/112KB                          |                | 34 ms                |  |  |  |  |  |  |  |  |
|           | ' '                                       | 2.1s/8KB       | 256 ms               |  |  |  |  |  |  |  |  |
|           |                                           | 2.1s/4KB       | 513 ms               |  |  |  |  |  |  |  |  |
| FIRST-GEN | ERATION FLAS                              | H MEMORY DEVIC | CES(2)               |  |  |  |  |  |  |  |  |
| 28F020    | 16.5 μs                                   | 6.8s/256KB     | 27 ms                |  |  |  |  |  |  |  |  |
| 28F010    | 16.5 μs                                   | 3.9s/128KB     | 30 ms                |  |  |  |  |  |  |  |  |
| 28F512    | 16.5 μs                                   | 2.4s/64KB      | 37 ms                |  |  |  |  |  |  |  |  |
| 28F256A   | 16.5 μs                                   | 1.6s/32KB      | 51 ms                |  |  |  |  |  |  |  |  |

#### NOTES:

Typical measured time.

2. Times calculated based on typical erase and precondition pulse requirements, with minimum write timings. Calculations are described in Figure 13.



Reliable word/byte-write and block-erase cycling requires proper selection of the maximum erase threshold voltage  $(V_t)$ , and maintenance of a tight distribution. Maximum erase  $V_t$  is set to 3.4V via the internal block-erase algorithm and verify circuits. Tight erase  $V_t$  distribution gives an order of magnitude of erase-time margin to the fastest erasing cell, with virtually identical erase  $V_t$  distributions at 1 and 10,000 cycles (Figure 34). Program  $V_t$  distribution is similarly consistent over cycling (Figure 35).

#### **Data Protection**

The 2/4-Mbit boot block family offers protection against accidental block erasure or word/byte write during power transitions. Internal circuitry creates a device insensitive to V<sub>PP</sub>/V<sub>CC</sub> supply power-up/down sequencing.

 $V_{PP} \leq V_{PPLMAX}$  locks out word/byte-write and block-erase circuits.  $V_{CC} \leq V_{LKO}$  disables CUI command writes, resets the CUI to array-read mode, and holds the WSM inactive. The system designer must still guard against spurious command writes for  $V_{CC} > V_{LKO}$  when  $V_{PP} < V_{PPLMAX}$ .

Several strategies are available to prevent data modification in the 2/4-Mbit family. The CUI provides a degree of software write protection since memory alteration occurs only after successful completion of a two-step write sequence. WE# and CE# must both go active to perform this sequence; driving either high inhibits command/data writes. Secondly, the system can place the device in deep-power-down mode (RP# = V<sub>IL</sub>) to disable command writes, reset the CUI to array-read mode, and hold the WSM inactive, effectively protecting array data and providing a way to reset the flash memory during system reset conditions. Finally, the system designer may switch Vpp to VppH when memory updates are required.

#### SUMMARY

Intel's 2/4-Mbit boot block Flash Memory family contains features that optimize this product group for computing and embedded applications. These features include hardware-implemented write/erase protection of the boot block, specialized array blocking, dedicated x8 and x8/16 user-configurable versions, automation of word/byte write and block erase, erase suspend for data read, deep-power-down/automatic-power-savings modes, reset capability, and a write/erase Status Register. With simple microprocessor interfacing and software command sequences, this family is the non-volatile computing and embedded solution of choice for today's designs.

#### **OTHER REFERENCES**

Related documents of interest to readers of this engineering report:

28F400BX-T/B, 28F004BX-T/B; "4-Mbit Flash Memory Family" Data Sheet (Order #290450)

28F400BX-TL/BL, 28F004BX-TL/BL; "4-Mbit Flash Memory Family" Data Sheet (Order #290451)

28F200BX-T/B, 28F002BX-T/B; "2-Mbit Flash Memory Family" Data Sheet (Order #290448)

28F200BX-TL/BL, 28F002BX-TL/BL; "2-Mbit Flash Memory Family" Data Sheet (Order #290449)

ER-28 "ETOX III Flash Memory Technology" Engineering Report (Order #294012)

AP-341 "Designing an Updatable BIOS Using Flash Memory" (Order #292077)

AP-363 "Extended Flash BIOS for Portable Computers" (Order #292098)



#### SUPPLEMENTARY INFORMATION

#### FORMULA:

b = # bytes in a block (256K, 128K, 64K, 32K)

n = # of erase pulses required (90 pulses)

 $w = Time for a write cycle (150 ns, t_{AVAV})$ 

 $v = Time to verify (6055 ns, t_{WHGL} + t_{GLOV})$ 

p = Program pulse width (10 µs, twhwh1)

one pulse programming assumed

e = Erase pulse width (10 ms, t<sub>WHWH2</sub>)

Precondition and precondition verify time is: b (2w + p + v)

Erase/verify, each loop where some byte does not pass verify:

$$(n-1)(2w+e+v)$$

Last erase pulse:

$$(1) (2w + e)$$

Passing erase-verify, all bytes:

$$b(w + v)$$

Total time can be summarized as:

$$b (3w + p + 2v) + n (2w + e + v) - (v)$$

or substituting in times for write, verify, program and erase pulse widths:

b (22.56 
$$\times$$
 10<sup>-6</sup>) + n (10.006355  $\times$  10<sup>-3</sup>) - (6.055  $\times$  10<sup>-6</sup>) Seconds

Figure 13. Erase Time Calculations for First-Generation Flash Memories



Figure 15.  $t_{ELQV}$  ( $t_{CE}$ ) vs  $V_{CC}$  and Temperature



Figure 14.  $t_{AVQV}$  ( $t_{ACC}$ ) vs  $V_{CC}$  and Temperature



Figure 16. t<sub>GLQV</sub> (t<sub>OE</sub>) vs V<sub>CC</sub> and Temperature





Figure 17. t<sub>DVWH</sub> (t<sub>DS</sub> WE#) vs V<sub>CC</sub> and Temperature



Figure 19. t<sub>AVWH</sub> (t<sub>AS</sub> WE#) vs V<sub>CC</sub> and Temperature



Figure 18. t<sub>WHDX</sub> (t<sub>DH</sub> WE#) vs V<sub>CC</sub> and Temperature



Figure 20. t<sub>WHAX</sub> (t<sub>AH</sub> WE#) vs V<sub>CC</sub> and Temperature



Figure 21. t<sub>DVEH</sub> (t<sub>DS</sub> CE#) vs V<sub>CC</sub> and Temperature



Figure 23. t<sub>AVEH</sub> (t<sub>AS</sub> CE#) vs V<sub>CC</sub> and Temperature



Figure 22. t<sub>EHDX</sub> (t<sub>DH</sub> CE#) vs V<sub>CC</sub> and Temperature



Figure 24. t<sub>EHAX</sub> (t<sub>AH</sub> CE#) vs V<sub>CC</sub> and Temperature





Figure 25. t<sub>WLWH</sub> (t<sub>WP</sub>) vs V<sub>CC</sub> and Temperature



Figure 27.  $I_{OL}$  vs  $V_{CC}$  and Temperature  $(V_{OL} = 0.45V)$ 



Figure 26. I<sub>OH</sub> TTL vs V<sub>CC</sub> and Temperature



Figure 28.  $I_{\mbox{\scriptsize OH}}$  CMOS vs  $V_{\mbox{\scriptsize CC}}$  and Temperature





75 70 65 60 55 50 (mA) 45 40 ္မ 35 30 25 - 25°C **△** 70°C 20 15 10 FREQUENCY (MHz) 294013-25

Figure 29. I<sub>CC</sub> (RMS) vs Frequency x16 Operation

Figure 30. I<sub>CC</sub> (RMS) vs Frequency x8 Operation



Figure 31. Access Time vs Output Loading





Figure 32. I<sub>CC</sub> and I<sub>PP</sub> during Block-Erase Operation





Figure 33. I<sub>CC</sub> and I<sub>PP</sub> during Word-Write Operation





Figure 34. Typical Process Data for Erase Vt vs Cycles



Figure 35. Typical Process Data for Program Vt vs Cycles





Figure 36. 28F400BX/28F004BX Die Photograph



|   |                                  |                                   | Pin Names               |                                   |   |   |
|---|----------------------------------|-----------------------------------|-------------------------|-----------------------------------|---|---|
|   | ٠ [,                             | A <sub>0</sub> -A <sub>17</sub>   | Address Inputs          |                                   |   |   |
|   | 1                                | DQ <sub>0</sub> -DQ <sub>15</sub> | Data Inputs/Outputs     |                                   |   |   |
|   |                                  |                                   | Byte Enable             |                                   |   |   |
|   | [                                | CE#                               | Chip Enable             |                                   |   |   |
|   |                                  | ₹P#                               | Power-Down/Reset        |                                   |   |   |
|   |                                  | DE#                               | Output Enable           |                                   |   |   |
|   | •                                | NE#                               | Write Enable            |                                   |   |   |
|   | Ľ                                | √ <sub>PP</sub>                   | Write/Erase Power Suppl | у                                 |   |   |
| , |                                  | √cc                               | Device Power Supply     |                                   |   |   |
|   | (                                | GND                               | Ground                  |                                   |   |   |
|   | L                                | DU                                | Don't Use               |                                   |   |   |
|   | [_!                              | VC                                | No Internal Connection  |                                   |   |   |
|   |                                  |                                   |                         |                                   |   |   |
| , | 28F200BX                         | _                                 |                         | 28F200BX                          |   |   |
|   | V <sub>PP</sub>                  | V <sub>PP</sub> 🗖 1               | 44 🗖 RP#                | RP#                               |   |   |
|   | DU                               | DU 🗖 2                            |                         | WE#                               |   |   |
|   | NC ,                             | A <sub>17</sub> 🗖 3               |                         | A <sub>8</sub>                    |   |   |
|   | A <sub>7</sub>                   | A7 54                             |                         | A <sub>9</sub>                    |   | • |
|   | A <sub>6</sub><br>A <sub>5</sub> | A <sub>6</sub> □ 5                |                         | A <sub>10</sub>                   |   |   |
|   | A <sub>4</sub>                   | A4 0 7                            | 38 A <sub>12</sub>      | A <sub>11</sub>                   |   |   |
|   | A <sub>3</sub>                   | A <sub>3</sub> = 8                | 37 A <sub>13</sub>      | A <sub>12</sub>                   |   |   |
|   | A <sub>2</sub>                   | A <sub>2</sub> = 9                |                         | A <sub>13</sub>                   |   |   |
|   | A <sub>1</sub>                   | A <sub>1</sub> 🗖 1                |                         | A <sub>4</sub>                    |   |   |
|   | A <sub>0</sub>                   | 4₀ □1                             | 1 34 h                  | A <sub>5</sub>                    |   |   |
|   | CE#                              | CE# 🗖 1                           | 2 281400BX 33 BYTE#     | A <sub>6</sub><br>BYTE#           | i |   |
| · | GND                              | GND □ 1                           | 3 32 🗖 GND              | GND                               | , |   |
|   | OE#                              | OE# 🗖 1                           |                         | DQ <sub>15</sub> /A <sub>-1</sub> |   |   |
|   | $DQ_0$                           | □00 □ 1                           |                         | DQ157A=1                          |   |   |
|   | DQ <sub>8</sub>                  | DQ <sub>8</sub> 🗖 1               |                         | DQ <sub>14</sub>                  |   |   |
| _ | DQ <sub>1</sub>                  | DQ, 🗖 1                           |                         | DQ <sub>14</sub>                  |   |   |
|   | DQ <sub>9</sub>                  | DQ <sub>9</sub> 🗖 1               |                         | DQ <sub>13</sub>                  |   |   |
|   | DQ <sub>2</sub>                  | DQ <sub>2</sub>                   | _                       | DQ <sub>13</sub>                  |   |   |
|   | DQ <sub>10</sub>                 | DQ <sub>10</sub> 🗖 2              |                         | DQ <sub>5</sub>                   | ' |   |
|   | DQ <sub>3</sub>                  | DQ <sub>3</sub>                   |                         | DQ <sub>12</sub>                  |   |   |
|   | DQ <sub>11</sub>                 | DQ <sub>11</sub> 🗖 2              | i i                     | V <sub>CC</sub>                   |   |   |
|   |                                  | _                                 | 294013-34               |                                   |   |   |

Figure 37. PSOP Lead Configuration







Figure 38. TSOP Lead Configuration



Addresses  $A_9$ - $A_0$  sequentially decode wordlines. Wordlines 0–1023 serve the upper and lower array planes.

**Table 3. Row Address Bitmap** 

| A <sub>9</sub> | A <sub>8</sub> | <b>A</b> <sub>7</sub> | A <sub>6</sub> | <b>A</b> <sub>5</sub> | A <sub>4</sub> | <b>A</b> <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | Wordline |
|----------------|----------------|-----------------------|----------------|-----------------------|----------------|-----------------------|----------------|----------------|----------------|----------|
| 0              | 0              | 0                     | 0              | 0                     | 0              | 0                     | 0              | 0              | 0              | 0        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 0                     | 0              | 0              | 1              | 1        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 0                     | 0              | 1              | 0              | 2        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 0                     | 0              | 1              | 1              | 3        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 0                     | 1              | 0              | 0              | 4        |
| 0              | 0 .            | 0                     | 0              | 0                     | 0              | 0                     | 1              | 0              | 1              | 5        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 0                     | 1              | 1              | 0              | 6        |
| 0              | . 0            | 0                     | 0              | 0                     | 0              | 0                     | 1              | 1              | 1              | 7        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 1 .                   | 0              | 0              | 0              | 8        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 1                     | 0              | 0              | 1              | 9        |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 1                     | 0              | 1              | 0              | 10       |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 1                     | 0.             | 1              | 1              | 11 ,     |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 1                     | 1              | 0              | 0              | 12       |
| 0              | 0              | 0                     | 0              | 0                     | ,O             | 1                     | 1              | 0              | 1              | 13       |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 1                     | 1              | 1              | 0              | 14       |
| 0              | 0              | 0                     | 0              | 0                     | 0              | 1                     | 1              | 1              | 1.             | 15       |
| 0              | 0              | 0                     | 0              | 0                     | 1              | 0                     | 0              | 0              | 0              | 16       |
| 0              | 0              | 0                     | 0              | 0                     | 1              | •                     | •              | •              | •              | •        |
| 0              | 0              | 0                     | 0              | 0                     | 1              | 1                     | 1              | 1              | 1              | 31       |
| •              | •              | •                     | •              | •                     | •              | •                     | •              | •              | •              | •        |
| 1              | 1              | 1                     | 1              | 1                     | 1 .            | 0                     | 0              | 0              | 0              | 1008     |
| 1              | 1              | 1                     | 1              | 1                     | 1              | •                     | •              | •              | •              | •        |
| 1              | 1              | 1                     | 1              | 1                     | 1              | 1                     | 1              | 1              | 1              | 1023     |



Columns for each block are distributed throughout the array in each I/O. For the 28F400BX/200BX, each I/O contains 8 columns for the boot block, 4 columns each for parameter block 0 and parameter block 1, 48 columns for main block 0 and 64 columns for each of the remaining main blocks (main block 1 for the 28F200BX and main block 1-3 for the 28F400BX) for a total of 256 columns (28F400BX) or 128 columns (28F200BX) per output.

Table 4. 28F400BX/200BX Column Decoding

| A <sub>17</sub> | A <sub>16</sub> | A <sub>15</sub> | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>11</sub> | A <sub>10</sub> | Block       | Column |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------|--------|
| 0               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | Boot        | 0      |
| 0               | 0               | 0               | 0               | 0               | •               | •               | •               | Boot        | •      |
| 0               | 0               | 0               | 0               | 0               | 1               | 1               | 1               | Boot        | 7      |
| 0               | 0               | 0               | 0               | 1               | 0               | 0               | 0               | Parameter 0 | 8      |
| 0               | 0               | 0               | 0               | 1               | 0               | •               | •               | Parameter 0 | •      |
| 0               | 0               | 0               | 0               | 1               | 0               | 1               | 1               | Parameter 0 | 11     |
| 0               | 0               | 0               | 0               | 1               | 1               | 0               | 0               | Parameter 1 | 12     |
| 0               | 0               | 0               | 0               | 1               | 1               | •               | •               | Parameter 1 | •      |
| 0               | 0               | 0               | 0               | 1               | 1               | 1               | 1               | Parameter 1 | 15     |
| 0               | 0               | 0               | 1               | 0               | 0               | 0               | 0               | Main 0      | 16     |
| 0               | 0               | •               | •               | •               | •               | •               | •               | Main 0      | •      |
| 0               | 0               | 1               | 1               | 1               | 1               | 1               | 1               | Main 0      | 63     |
| 0               | 1               | 0               | 0               | 0               | 0               | 0               | 0               | Main 1      | 64     |
| 0               | 1               | •               | •               | •               | •               | •               | •               | Main 1      | •      |
| 0               | 1               | 1               | 1               | 1               | 1               | 1               | 1               | Main 1      | 127    |
| 1               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | Main 2      | 128    |
| 1               | 0               | •               | •               | •               | •               | •               | •               | Main 2      | •      |
| 1               | 0               | 1               | 1               | 1               | 1               | 1               | 1               | Main 2      | 191    |
| 1               | 1               | 0               | 0               | 0               | 0               | 0               | 0               | Main 3      | 192    |
| 1               | 1               | •               | •               | •               | •               | •               | . •             | Main 3      | •      |
| 1               | 1               | 1               | 1               | 1               | 1               | 1               | 1               | Main 3      | 255    |

NOTE: 28F400BX = Complete Table, 28F200BX = Shaded Area Only



Columns for each block are distributed throughout the array in each I/O. For the 28F004BX/002BX, each I/O contains 16 columns for the boot block, 8 columns each for parameter block 0 and parameter block 1, 96 columns for main block 0 and 128 columns for each of the remaining main blocks (main block 1 for the 28F002BX) and main block 1-3 for the 28F004BX for a total of 512 columns (28F004BX) or 256 columns (28F002BX) per output.

Table 5. 28F004BX/002BX Column Decoding

| A <sub>18</sub> | A <sub>17</sub> | A <sub>16</sub> | A <sub>15</sub> | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>11</sub> | A <sub>10</sub> | Block       | Column |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------|--------|
| 0               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | Boot        | 0      |
| 0               | 0               | 0               | 0               | 0               |                 | 3               | •               | <u></u> •       | Boot        |        |
| 0               | 0               | 0               | 0               | 0               | 1               | 1               | 1               | 1               | Boot        | 15     |
| 0               | 0               | 0               | 0               | 1               | 0               | 0               | 0               | 0               | Parameter 0 | 16     |
| 0               | 0               | 0               | 0               | 1               | 0               | •               | ø               |                 | Parameter 0 | •      |
| 0               | 0               | 0               | 0               | 1               | 0               | 1               | 1               | 1               | Parameter 0 | 23     |
| 0               | 0               | 0               | 0               | 1               | 1               | 0               | 0               | 0               | Parameter 1 | 24     |
| 0               | 0               | 0               | 0               | 1               | 1               | G               | 9               | G               | Parameter 1 |        |
| 0               | 0               | 0               | 0               | 1               | 1               | 1               | 1               | 1               | Parameter 1 | 31     |
| 0               | 0               | 0               | 1               | 0               | 0               | 0               | 0               | 0               | Main 0      | 32     |
| 0               | 0               | 0               | 9               | 0               | 6               | 8               | 0               | ્રક             | Main 0      | ٥      |
| 0               | 0               | 1               | 1               | 1               | 1               | 1               | 1               | 1               | Main 0      | 127    |
| 0               | 1               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | Main 1      | 128    |
| 0               | 1               | •               | 0               | e               | 9               | 9               | 0               | 0               | Wain 1      | 0      |
| 0               | 1               | 1               | 1               | 1               | 1               | 1               | 1               | 8. <b>1</b> ×   | Main 1      | 255    |
| 1               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | Main 2      | 256    |
| 1               | 0               | . •             | 9               | 0               | 0               | ۰               | 0               | 0               | Main 2      | •      |
| 1               | 0               | 1               | 1               | 1               | 1               | 1               | 1               | 1               | Main 2      | 383    |
| 1               | 1               | 0               | 0               | 0               | 0               | 0               | 0               | 0               | Main 3      | 384    |
| 1               | 1               | 6               | 0               | ۰               | •               | ۰               | •               | ٥               | Main 3      | 0      |
| 1 .             | 1               | 1               | 1               | 1               | 1               | 1               | 1               | 1               | Main 3      | 511    |

NOTE: 28F004BX = Complete Table, 28F002BX = Shaded Area Only



#### BOOT BLOCK FLASH: THE NEXT GENERATION

#### INTRODUCTION

Flash memory offers a whole new dimension to nonvolatile memory applications because of its high density and cost-effectiveness. Embedded systems, such as PC BIOS, hard disk drive controllers and laser printers, were among the first applications to utilize the easy update capability of Flash, allowing system differentiation and upgradeability. In 1992, Intel introduced a series of high-density Flash Memory Cards based on its 8-Mbit FlashFile<sup>TM</sup> component, products that are enabling truly portable computing capability with diskless, solid-state mass storage. Intel also added two flash memory products designed specifically to serve more traditional embedded and portable applications, offering both high performance and low power consumption options in an architecture specifically designed for these applications storage requirements.

#### MARKET GROWTH DATA

In the four years since Intel first introduced its 256-Kbit flash devices, the worldwide demand has quadrupled annually, with 1992 market demand forecasted to exceed \$270 million. Flash is expected to continue double-digit growth through the upcoming years while other memory technologies are relatively flat or increasing only slightly. By 1994, the flash market is expected to exceed \$1 billion (Figure 1). The primary reasons for this growth are well acknowledged by customers: flexibility, nonvolatility, low power and cost-effectiveness. As a result of this seemingly insatiable demand for flash, the memory density treadmill that allowed DRAMs and EPROMs to double every 18 months, has accelerated faster than ever before. Intel's introduction of an 8-Mbit component two years after its 2-Mbit product is evidence of the flash memory's rapid advancement.

Intel's first generation of flash devices, ranging in density from 256-Kbit through 2-Mbit densities, were rapidly adopted into code storage applications which formerly used EPROM or EEPROM. In 1991, Intel introduced the first 1-Mbit Boot Block flash memory in response to direct customer requests. As a result of continuing to improve and develop an innovative and broad product line, Intel held an 85% share of the \$130 million 1991 market.



Figure 1

## INTEL SERVING TWO PRIMARY APPLICATIONS

Today, Intel flash is serving two major application segments: updatable code storage and solid-state mass storage (Figure 2). Code and data storage comprise the updatable non-volatile memory applications that require high performance, high density and easy update capability. These applications are infrequently updated when compared to solid-state mass storage applications. In this case, erase/write performance is not as critical as integration and performance requirements. This application segment is served effectively with full chip-erase or boot block products.

The second major application segment is solid-state mass storage that requires very high density, automated programming and high performance erase/write capability at a very low cost per bit. Erasing and writing portions of the code or data is much more frequent in solid-state mass storage than in updatable firmware applications. In April of 1992, Intel introduced the 8-Mbit FlashFile component whose architecture is optimized for data file storage. Its symmetrically blocked architecture and automated write/erase features gave programming flexibility for a high-performance, solid-state memory system. The compactness of an 8-Mbit device in a TSOP package allows for high-density flash arrays to be included on a system motherboard as well





Figure 2

as in memory cards. Intel also offers a second generation of flash memory cards designed to serve the portable mass storage market that are based on the new 8-Mbit FlashFile component. Memory cards add the feature of removability and system upgradability in an industry-standard PCMCIA/ExCA<sup>TM</sup> format. While flash cards and FlashFile components serve solid-state mass storage applications directly, both can be used in updatable code storage applications as well.

By developing products to fit both of these application segments, Intel strives to serve the needs of a broader base of customer applications with the best nonvolatile memory solutions.

#### **BOOT BLOCK UPDATE**

The 28F001BX 1-Mbit Boot Block flash component introduced in June 1991 featured a sectored architecture that has been widely accepted in embedded code storage applications, particularly PC BIOS and cellular communications. Over 20 PC manufacturers use this device in their products, including Compaq, Dell and Zenith Data Systems. The Boot Block architecture gave the manufacturer added flexibility and the ability to differentiate. End users also benefit from the ability to upgrade BIOS software quickly and securely. It is possible for the manufacturer to upload BIOS updates to an electronic bulletin board where the end-user gets the

upgrade for the price of the call. The blocked architecture allows the OEM customer to store critical system code securely in the boot block of the device that can minimally bring up the system and download to other locations of the device to initialize the system. The hardware boot locking feature guarantees that even if the power is disrupted during a BIOS update, the system will be able to recover immediately.

The success of the 1-Mbit Boot Block device has resulted in over 150 designs with annual shipments to exceed 1.5 million units worldwide in 1992.

# EXTENDING THE BOOT BLOCK PRODUCT LINE: 2- AND 4-MEGABIT FLASH DEVICES

Once the Boot Block architecture became established in the marketplace, customers quickly began to ask for more features and enhancements: speed, density, low power, surface-mount options and an industry-standard upgrade path. These requests were based on the need to expand features in portable computing and communication products.

The 2-Mbit 28F200BX and 4-Mbit 28F400BX are Intel's newest additions to the flash Boot Block product line. These products offer 60 ns performance, two surface-mount packages, and a Boot Block architecture



similar to the 1-Mbit Boot Block device: one lockable Boot Block, two parameter blocks, and the balance of the device is divided into main blocks. The Boot Block securely stores the basic boot code required to initialize the system that can be protected by the hardware-locking feature, ensuring basic system operating code protection. The two parameter blocks can be used for a variety of purposes: manufacturing product code, setup parameters and storing frequently updated data such as system diagnostics. The 28F200BX contains one 16 Kbyte Boot Block, two 8 Kbyte parameter blocks, one 96 Kbyte and one 128 Kbyte main block (Figure 3a). The 28F400BX contains all of the blocks of the 28F200BX plus two additional 128 Kbyte main blocks (Figure 3b). Top and bottom Boot Block versions are available for both densities. Both devices are in the x16/x8 user-selectable organization of the industrystandard, ROM-compatible pin-out in 44-lead PSOP surface mount package. This pinout and package allow an easy upgrade from 2-Mbit to 4-Mbit since only one address is added at the top of the device package. Forty-lead TSOP x8-only versions are also available for both of these devices, providing high density in the smallest form factor. A 56-lead TSOP x16/x8 version will be available for applications requiring x16 organization in a TSOP package.

#### APPLICATION REQUIREMENTS—PCs

Notebook computer manufacturers today are competing to produce the lightest weight, slimmest and longest battery life products possible. Minimizing board size via reduced chip count is the first improvement the new flash devices provide. BIOS in portable systems has grown beyond the 1-Mbit density to accommodate more sophisticated power management and additional system features, such as PCMCIA card slots. For example, the i386<sup>TM</sup> SL architecture allows the expansion of BIOS beyond 128 Kbytes (1-Mbit) with internal registers for hardware paging. A new generation of BIOS support for low-power portable computers has been developed by SystemSoft and other vendors which supports the 28F200BX and the 28F400BX. In PC BIOS applications, the main blocks of the Boot Block devices are used for power management code, video drivers, and ROM-executable code, such as MS-DOS\*. The arrangement of the blocks for PC BIOS applications based on Intel i386 and i486<sup>TM</sup> microprocessors is with the Boot Block on top. Other microprocessors and microcontrollers, such as the Intel 80960KX/SX and the Motorola 68000 series, use the bottom Boot Block version of the memory map. Many PC manufacturers have also moved to a x16 organization of their BIOS for





higher performance and are using 2-Mbit flash components in parallel to accomplish x16 performance. Other manufacturers have decided to forego x16 and use the 1-Mbit Boot Block and a 1-Mbit bulk-erase 28F010 flash memory to contain their power management code. The 28F200BX solves both of these problems in a compact, single-chip solution. The 28F400BX provides a higher density solution for high performance systems today, as well as a future upgrade for systems currently requiring only 2 megabits.

# APPLICATION REQUIREMENTS— TELECOMMUNICATIONS/EMBEDDED

Similar to personal computers, cellular telephone applications use the hardware-lockable block to store basic initialization code to wake up the system and establish basic communication with the host base station. The small parameter blocks are ideal for frequently updated code such as the user's phone directory, re-dial and the activation code necessary to enable user-desired features. The main block contains the code for dynamically managing the cellular communications and executing the voice algorithms. The density requirement for the main code storage has increased significantly in recent years with the conversion to digital cellular transmission, particularly in Europe and Japan. Most cellular designs execute code directly from ROM rather than downloading to RAM. Typical microcontrollers used are: Intel 80C186, Zilog Z8080 and Siemens 80166, all operating in the 8 MHz-13 MHz range. The Motorola 68000 series 16-bit microcontrollers used in some digital cellular designs utilize the x16 and high speed capabilities of these new Boot Block devices. Flash access times ranging from 75 ns to 120 ns produce 0 to 1 waitstate performance. The high-performance 60 ns access time of the 2-Mbit and 4-Mbit Boot Block flash allows zero wait state performance in cellular telephones and other embedded control applications.

Low power has always been a strength of flash due to its inherent nonvolatility, a characteristic that eliminates battery drain required to maintain information stored in volatile RAM when the power is off. When flash is in use, its active power requirement is very low: typical  $I_{CC}=35~\text{mA}$ , and standby current is 0.1 mA. The hallmark of this newest generation of flash is low power and high performance. Formerly these features were mutually exclusive, but through advanced circuit development, an automated power saving feature in the device reduces  $I_{CC}$  to a low DC level within one access time; 5 mA typical. This significant reduction of the active current time relates directly to the extension of

battery life in systems which continuously execute code directly from flash, such as cellular telephones and portable instrumentation.

For optimum system power conservation, future systems are being designed today to operate at 3.3V rather than 5V. Intel will also offer 3.3V versions of the 2-Mbit and 4-Mbit Boot Block devices with  $I_{CC}$  active = 10 mA, and  $t_{ACC}$  performance = 150 ns.

An alternative design approach of a "5V-only" (programming voltage = operating voltage = 5V) flash memory has been proposed to eliminate the need for a 12V programming supply. While this proposal would eliminate the need for a 12V supply component in a 5Vonly environment, it would not provide a low power solution as every flash component would carry the die size cost and power overhead of on-chip voltage pumping. Intel's approach is to first bring the operating voltage to 3.3V, in line with what system designers requested as their first priority for the next generation of portable computers and cellular phones. The focus of lowering the read voltage is also congruent with the usage model for embedded applications of "read often, write few" operation. The 12V programming voltage requirement is more efficiently met with a voltage pump from a vendor such as Maxim. (Inexpensive voltage pumps for 3.3V to 12V are currently available.) The use of a separate voltage pump is significantly more cost-efficient in systems where more than one flash device is used, as cost and space is amortized over multiple devices.

#### CONCLUSION

Intel continues to serve both updatable non-volatile memory applications as well as the rapidly emerging solid-state mass storage market with solutions tailored to meet their particular needs. The new 2-Mbit and 4-Mbit Boot Block devices offer high performance and low power options for updatable code applications. The Boot Block architecture is compatible with all major microprocessors and microcontrollers. As with all Intel flash products, their low power consumption and small surface mount packaging make the 2-Mbit and 4-Mbit Boot Block flash memories ideal for a wide variety of handheld portable applications.

#### NOTE:

FlashFile, ExCA, i386 and i486 SL are trademarks of Intel Corporation.

\*MS-DOS is a registered trademark of Microsoft Corporation.



# **Bulk-Erase Components**





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

- Flash Electrical Chip-Erase - 2 Second Typical Chip-Erase
- Quick-Pulse Programming Algorithm
  - 10 μs Typical Byte-Program
  - 4 Second Chip-Program
- 100,000 Erase/Program Cycles
- 12.0V  $\pm 5\%$  Vpp
- **High-Performance Read** - 70 ns Maximum Access Time
- CMOS Low Power Consumption
  - 10 mA Typical Active Current
  - 50 µA Typical Standby Current
  - 0 Watts Data Retention Power
- Integrated Program/Erase Stop Timer

- **■** Command Register Architecture for Microprocessor/Microcontroller Compatible Write Interface
- Noise Immunity Features

  - ± 10% V<sub>CC</sub> Tolerance Maximum Latch-Up Immunity through EPI Processing
- ETOX Nonvolatile Flash Technology
  - EPROM-Compatible Process Base
  - High-Volume Manufacturing Experience
- **JEDEC-Standard Pinouts** 
  - 32-Pin Plastic Dip
  - 32-Lead PLCC
  - 32-Lead TSOP

(See Packaging Spec., Order #231369)

#### Extended Temperature Options

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

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

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

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

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





Figure 1. 28F020 Block Diagram

**Table 1. Pin Description** 

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





Figure 2. 28F020 Pin Configurations



#### **APPLICATIONS**

The 28F020 flash memory provides nonvolatility along with the capability to perform over 100,000 electrical chip-erasure/reprogram cycles. These features make the 28F020 an innovative alternative to disk, EEPROM, and battery-backed static RAM. Where periodic updates of code and data-tables are required, the 28F020's reprogrammability and nonvolatility make it the obvious and ideal replacement for EPROM.

Primary applications and operating systems stored in flash eliminate the slow disk-to-DRAM download process. This results in dramatic enhancement of performance and substantial reduction of power consumption — a consideration particularly important in portable equipment. Flash memory increases flexibility with electrical chip erasure and in-system update capability of operating systems and application code. With updatable code, system manufacturers can easily accommodate last-minute changes as revisions are made.

In diskless workstations and terminals, network traffic reduces to a minimum and systems are instanton. Reliability exceeds that of electromechanical media. Often in these environments, power interruptions force extended re-boot periods for all networked terminals. This mishap is no longer an issue if boot code, operating systems, communication protocols and primary applications are flash-resident in each terminal.

For embedded systems that rely on dynamic RAM/ disk for main system memory or nonvolatile backup storage, the 28F020 flash memory offers a solid state alternative in a minimal form factor. The 28F020 provides higher performance, lower power consumption, instant-on capability, and allows an "execute in place" memory hierarchy for code and data table reading. Additionally, the flash memory is more rugged and reliable in harsh environments where extreme temperatures and shock can cause disk-based systems to fail.

The need for code updates pervades all phases of a system's life — from prototyping to system manufacture to after-sale service. The electrical chip-erasure and reprogramming ability of the 28F020 allows incircuit alterability; this eliminates unnecessary handling and less-reliable socketed connections, while adding greater test, manufacture, and update flexibility.

Material and labor costs associated with code changes increases at higher levels of system integration — the most costly being code updates after sale. Code "bugs", or the desire to augment system functionality, prompt after-sale code updates. Field revisions to EPROM-based code requires the removal of EPROM components or entire boards. With the 28F020, code updates are implemented locally via an edge-connector, or remotely over a communcations link.

For systems currently using a high-density static RAM/battery configuration for data accumulation, flash memory's inherent nonvolatility eliminates the need for battery backup. The concern for battery failure no longer exists, an important consideration for portable equipment and medical instruments, both requiring continuous performance. In addition, flash memory offers a considerable cost advantage over static RAM.

Flash memory's electrical chip erasure, byte programmability and complete nonvolatility fit well with data accumulation and recording needs. Electrical chip-erasure gives the designer a "blank slate" in which to log or record data. Data can be periodically off-loaded for analysis and the flash memory erased producing a new "blank slate".

A high degree of on-chip feature integration simplifies memory-to-processor interfacing. Figure 4 depicts two 28F020s tied to the 80C186 system bus. The 28F020's architecture minimizes interface circuitry needed for complete in-circuit updates of memory contents.

The outstanding feature of the TSOP (Thin Small Outline Package) is the 1.2 mm thickness. With standard and reverse pin configurations, TSOP reduces the number of board layers and overall volume necessary to layout multiple 28F020s. TSOP is particularly suited for portable equipment and applications requiring large amounts of flash memory. Figure 3 illustrates the TSOP Serpentine layout.

With cost-effective in-system reprogramming, extended cycling capability, and true nonvolatility, the 28F020 offers advantages to the alternatives: EPROMs, EEPROMs, battery backed static RAM, or disk. EPROM-compatible read specifications, straight-forward interfacing, and in-circuit alterability offers designers unlimited flexibility to meet the high standards of today's designs.





Figure 3. TSOP Serpentine Layout





Figure 4. 28F020 in a 80C186 System

#### PRINCIPLES OF OPERATION

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

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

The same EPROM read, standby, and output disable operations are available when high voltage is applied to the Vpp pin. In addition, high voltage on Vpp enables erasure and programming of the device. All functions associated with altering memory contents—Intelligent Identifier, erase, erase verify, program, and program verify—are accessed via the command register.

Commands are written to the register using standard microprocessor write itimings. Register contents serve as input to an internal state-machine which controls the erase and programming circuitry. Write cycles also internally latch addresses and data needed for programming or erase operations. With the appropriate command written to the register,

standard microprocessor read timings output array data, access the Intelligent Identifier codes, or output data for erase and program verification.

#### **Integrated Stop Timer**

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

#### **Write Protection**

The command register is only active when  $V_{PP}$  is at high voltage. Depending upon the application, the system designer may choose to make the  $V_{PP}$  power supply switchable—available only when memory updates are desired. When  $V_{PP} = V_{PPL}$ , the contents of the register default to the read command, making the 28F020 a read-only memory. In this mode, the memory contents cannot be altered.



| Table  | 2. | 28F020  | Bus O | perations |
|--------|----|---------|-------|-----------|
| I abic |    | 201 020 | Dus O | peranons  |

| Pins           |                                    |                  | An              | Ag                  | CE#             | OE#             | WE#             | DQ <sub>0</sub> -DQ <sub>7</sub> |
|----------------|------------------------------------|------------------|-----------------|---------------------|-----------------|-----------------|-----------------|----------------------------------|
| Operation      |                                    |                  | 7.0             | 7.9                 |                 | <b>J</b>        |                 | 240 247                          |
|                | Read                               | V <sub>PPL</sub> | A <sub>0</sub>  | A <sub>9</sub>      | $V_{IL}$        | V <sub>IL</sub> | V <sub>IH</sub> | Data Out                         |
|                | Output Disable                     | V <sub>PPL</sub> | Х               | Х                   | $V_{IL}$        | $V_{IH}$        | V <sub>IH</sub> | Tri-State                        |
| READ-ONLY      | Standby                            | V <sub>PPL</sub> | Х               | Х                   | $V_{IH}$        | Х               | Х               | Tri-State                        |
|                | Intelligent Identifier (Mfr)(2)    | V <sub>PPL</sub> | VIL             | V <sub>ID</sub> (3) | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data = 89H                       |
| Ir             | Intelligent Identifier (Device)(2) | V <sub>PPL</sub> | V <sub>IH</sub> | V <sub>ID</sub> (3) | $V_{IL}$        | V <sub>IL</sub> | V <sub>IH</sub> | Data = BDH                       |
|                | Read                               | V <sub>PPH</sub> | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data Out(4)                      |
| READ/WRITE     | Output Disable                     | V <sub>PPH</sub> | Х               | Х                   | $V_{IL}$        | V <sub>IH</sub> | V <sub>IH</sub> | Tri-State                        |
| 112/12/14/11/2 | Standby <sup>(5)</sup>             | V <sub>PPH</sub> | Х               | Х                   | V <sub>IH</sub> | Х               | Х               | Tri-State                        |
|                | Write                              | V <sub>PPH</sub> | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Data In(6)                       |

#### NOTES

- 1. Refer to DC Characteristics. When V<sub>PP</sub> = V<sub>PPI</sub> memory contents can be read but not written or erased.
- 2. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 3. All other addresses low.
- 3. V<sub>ID</sub> is the Intelligent Identifier high voltage. Refer to DC Characteristics.
- 4. Read operations with VPP = VPPH may access array data or the Intelligent Identifier codes.
- 5. With VPP at high voltage, the standby current equals ICC + IPP (standby).
- 6. Refer to Table 3 for valid Data-In during a write operation.
- 7. X can be VIL or VIH.

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

The two step program/erase write sequence to the Command Register provides additional software write protection.

#### **BUS OPERATIONS**

#### Read

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

When V<sub>PP</sub> is high (V<sub>PPH</sub>), the read operation can be used to access array data, to output the Intelligent Identifier codes, and to access data for program/erase verification. When V<sub>PP</sub> is low (V<sub>PPL</sub>), the read operation can **only** access the array data.

#### **Output Disable**

With Output-Enable at a logic-high level ( $V_{IH}$ ), output from the device is disabled. Output pins are placed in a high-impedance state.

#### Standby

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



#### Intelligent Identifier Operation

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

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

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

#### Write

Device erasure and programming are accomplished via the command register, when high voltage is applied to the V<sub>PP</sub> pin. The contents of the register serve as input to the internal state-machine. The state-machine outputs dictate the function of the device.

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

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

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

#### **COMMAND DEFINITIONS**

When low voltage is applied to the  $V_{PP}$  pin, the contents of the command register default to 00H, enabling read-only operations.

Placing high voltage on the V<sub>PP</sub> pin enables read/write operations. Device operations are selected by writing specific data patterns into the command register. Table 3 defines these 28F020 register commands.

**Table 3. Command Definitions** 

| Command                                          | Bus<br>Cycles |              | t Bus Cycle |         | Second Bus Cycle |            |         |  |
|--------------------------------------------------|---------------|--------------|-------------|---------|------------------|------------|---------|--|
|                                                  | Req'd         | Operation(1) | Address(2)  | Data(3) | Operation(1)     | Address(2) | Data(3) |  |
| Read Memory                                      | 1             | Write        | Х           | 00H     |                  |            |         |  |
| Read Intelligent Identifier Codes <sup>(4)</sup> | 3             | Write        | X           | 90H     | Read             | (4)        | (4)     |  |
| Set-up Erase/Erase(5)                            | 2             | Write        | Х           | 20H     | Write            | Х          | 20H     |  |
| Erase Verify <sup>(5)</sup>                      | 2             | Write        | EA          | A0H     | Read             | Х          | EVD     |  |
| Set-up Program/Program(6)                        | 2             | Write        | х           | 40H     | Write            | PA         | PD      |  |
| Program Verify <sup>(6)</sup>                    | 2             | Write        | Х           | C0H     | Read             | Х          | PVD     |  |
| Reset <sup>(7)</sup>                             | 2             | Write        | . х         | FFH     | Write            | Х          | FFH     |  |

#### NOTES

- 1. Bus operations are defined in Table 2.
- 2. IA = Identifier address: 00H for manufacturer code, 01H for device code.
  - EA = Address of memory location to be read during erase verify.
  - PA = Address of memory location to be programmed.
  - Addresses are latched on the falling edge of the Write-Enable pulse.
- 3. ID = Data read from location IA during device identification (Mfr = 89H, Device = BDH).
  - EVD = Data read from location EA during erase verify.
  - PD = Data to be programmed at location PA. Data is latched on the rising edge of Write-Enable.
  - PVD = Data read from location PA during program verify. PA is latched on the Program command.
- Following the Read Intelligent ID command, two read operations access manufacturer and device codes.
- 5. Figure 6 illustrates the Quick-Erase Algorithm.
- 6. Figure 5 illustrates the Quick-Pulse Programming Algorithm.
- 7. The second bus cycle must be followed by the desired command register write.



#### **Read Command**

While V<sub>PP</sub> is high, for erasure and programming, memory contents can be accessed via the read command. The read operation is initiated by writing 00H into the command register. Microprocessor read cycles retrieve array data. The device remains enabled for reads until the command register contents are altered.

The default contents of the register upon  $V_{PP}$  power-up is 00H. This default value ensures that no spurious alteration of memory contents occurs during the  $V_{PP}$  power transition. Where the  $V_{PP}$  supply is hard-wired to the 28F020, the device powers-up and remains enabled for reads until the command-register contents are changed. Refer to the AC Read Characteristics and Waveforms for specific timing parameters.

#### Intelligent Identifier Command

Flash-memories are intended for use in applications where the local CPU alters memory contents. As such, manufacturer- and device-codes must be accessible while the device resides in the target system. PROM programmers typically access signature codes by raising A9 to a high voltage. However, multiplexing high voltage onto address lines is not a desired system-design practice.

The 28F020 contains an Intelligent Identifier operation to supplement traditional PROM-programming methodology. The operation is initiated by writing 90H into the command register. Following the command write, a read cycle from address 0000H retrieves the manufacturer code of 89H. A read cycle from address 0001H returns the device code of BDH. To terminate the operation, it is necessary to write another valid command into the register.

#### Set-up Erase/Erase Commands

Set-up Erase is a command-only operation that stages the device for electrical erasure of all bytes in the array. The set-up erase operation is performed by writing 20H to the command register.

To commence chip-erasure, the erase command (20H) must again be written to the register. The erase operation begins with the rising edge of the Write-Enable pulse and terminates with the rising edge of the next Write-Enable pulse (i.e., Erase-Verify Command).

This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, chip-erasure can only occur when high voltage is applied to the  $V_{PP}$  pin. In the absence

of this high voltage, memory contents are protected against erasure. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

#### **Erase-Verify Command**

The erase command erases all bytes of the array in parallel. After each erase operation, all bytes must be verified. The erase verify operation is initiated by writing A0H into the command register. The address for the byte to be verified must be supplied as it is latched on the falling edge of the Write-Enable pulse. The register write terminates the erase operation with the rising edge of its Write-Enable pulse.

The 28F020 applies an internally-generated margin voltage to the addressed byte. Reading FFH from the addressed byte indicates that all bits in the byte are erased.

The erase-verify command must be written to the command register prior to each byte verification to latch its address. The process continues for each byte in the array until a byte does not return FFH data, or the last address is accessed.

In the case where the data read is not FFH, another erase operation is performed. (Refer to Set-up Erase/Erase). Verification then resumes from the address of the last-verified byte. Once all bytes in the array have been verified, the erase step is complete. The device can be programmed. At this point, the verify operation is terminated by writing a valid command (e.g. Program Set-up) to the command register. Figure 6, the Quick-Erase algorithm, illustrates how commands and bus operations are combined to perform electrical erasure of the 28F020. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

#### Set-up Program/Program Commands

Set-up program is a command-only operation that stages the device for byte programming. Writing 40H into the command register performs the set-up operation.

Once the program set-up operation is performed, the next Write-Enable pulse causes a transition to an active programming operation. Addresses are internally latched on the falling edge of the Write-Enable pulse. Data is internally latched on the rising edge of the Write-Enable pulse. The rising edge of Write-Enable also begins the programming operation. The programming operation terminates with the next rising edge of Write-Enable, used to write the program-verify command. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.



## **Program-Verify Command**

The 28F020 is programmed on a byte-by-byte basis. Byte programming may occur sequentially or at random. Following each programming operation, the byte just programmed must be verified.

The program-verify operation is initiated by writing C0H into the command register. The register write terminates the programming operation with the rising edge of its Write-Enable pulse. The program-verify operation stages the device for verification of the byte last programmed. No new address information is latched.

The 28F020 applies an internally-generated margin voltage to the byte. A microprocessor read cycle outputs the data. A successful comparison between the programmed byte and true data means that the byte is successfully programmed. Programming then proceeds to the next desired byte location. Figure 5, the 28F020 Quick-Pulse Programming algorithm, illustrates how commands are combined with bus operations to perform byte programming. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.

## **Reset Command**

A reset command is provided as a means to safely abort the erase- or program-command sequences. Following either set-up command (erase or program) with two consecutive writes of FFH will safely abort the operation. Memory contents will not be altered. A valid command must then be written to place the device in the desired state.

#### **EXTENDED ERASE/PROGRAM CYCLING**

EEPROM cycling failures have always concerned users. The high electrical field required by thin oxide EEPROMs for tunneling can literally tear apart the oxide at defect regions. To combat this, some suppliers have implemented redundancy schemes, reducing cycling failures to insignificant levels. However, redundancy requires that cell size be doubled—an expensive solution.

Intel has designed extended cycling capability into its ETOX flash memory technology. Resulting improvements in cycling reliability come without increasing memory cell size or complexity. First, an advanced tunnel oxide increases the charge carrying ability ten-fold. Second, the oxide area per cell subjected to the tunneling electric field is one-tenth that of common EEPROMs, minimizing the probability of oxide defects in the region. Finally, the peak electric field during erasure is approximately 2 MV/cm lower than EEPROM. The lower electric

field greatly reduces oxide stress and the probability of failure—increasing time to wearout by a factor of 100,000,000.

The 28F020 is capable of 100,000 program/erase cycles. The device is programmed and erased using Intel's Quick-Pulse Programming and Quick-Erase algorithms. Intel's algorithmic approach uses a series of operations (pulses), along with byte verification, to completely and reliably erase and program the device.

For further information, see Reliability Report RR-60.

#### QUICK-PULSE PROGRAMMING ALGORITHM

The Quick-Pulse Programming algorithm uses programming operations of 10  $\mu s$  duration. Each operation is followed by a byte verification to determine when the addressed byte has been successfully programmed. The algorithm allows for up to 25 programming operations per byte, although most bytes verify on the first or second operation. The entire sequence of programming and byte verification is performed with  $V_{PP}$  at high voltage. Figure 5 illustrates the Quick-Pulse Programming algorithm.

#### QUICK-ERASE ALGORITHM

Intel's Quick-Erase algorithm yields fast and reliable electrical erasure of memory contents. The algorithm employs a closed-loop flow, similar to the Quick-Pulse Programming algorithm, to simultaneously remove charge from all bits in the array.

Erasure begins with a read of memory contents. The 28F020 is erased when shipped from the factory. Reading FFH data from the device would immediately be followed by device programming.

For devices being erased and reprogrammed, uniform and reliable erasure is ensured by first programming all bits in the device to their charged state (Data = 00H). This is accomplished, using the Quick-Pulse Programming algorithm, in approximately four seconds.

Erase execution then continues with an initial erase operation. Erase verification (data = FFH) begins at address 0000H and continues through the array to the last address, or until data other than FFH is encountered. With each erase operation, an increasing number of bytes verify to the erased state. Erase efficiency may be improved by storing the address of the last byte verified in a register. Following the next erase operation, verification starts at that stored address location. Erasure typically occurs in two seconds. Figure 6 illustrates the Quick-Erase algorithm.





Figure 5. 28F020 Quick-Pulse Programming Algorithm





| Bus<br>Operation | Command                        | Comments                                                                      |
|------------------|--------------------------------|-------------------------------------------------------------------------------|
|                  |                                | Entire Memory Must = 00H<br>Before Erasure                                    |
| Ot and the       | ,                              | Use Quick-Pulse<br>Programming Algorithm<br>(Figure 5)                        |
| Standby          |                                | Wait for V <sub>PP</sub> Ramp to V <sub>PPH</sub> (1)                         |
| ,                |                                | Initialize Addresses and Pulse-Count                                          |
| Write            | Set-up<br>Erase                | Data = 20H                                                                    |
| Write            | Erase                          | Data = 20H                                                                    |
| Standby          | ŧ                              | Duration of Erase Operation (twhwh2)                                          |
| Write            | Erase <sup>(2)</sup><br>Verify | Addr = Byte to Verify;<br>Data = A0H; Stops Erase<br>Operation <sup>(3)</sup> |
| Standby          |                                | twige                                                                         |
| neau             | ,                              | Read Byte to Verify Erasure                                                   |
| Standby          |                                | Compare Output to FFH Increment Pulse-Count                                   |
|                  | ,                              |                                                                               |
| Write            | Read                           | Data = 00H, Resets the<br>Register for Read Operations                        |
| Standby          |                                | Wait for V <sub>PP</sub> Ramp to V <sub>PPL</sub> (1)                         |

1. See DC Characteristics for the value of  $V_{PPH}$  and  $V_{PPH}$ .

2. Erase Verify is performed only after chip-erasure. A final read/compare may be performed (optional) after the register is written with the read command.

3. Refer to principles of operation.

4. CAUTION: The algorithm MUST BE FOLLOWED to ensure proper and reliable operation of the device.  $\,$ 

Figure 6. 28F020 Quick-Erase Algorithm



## **DESIGN CONSIDERATIONS**

## **Two-Line Output Control**

Flash-memories are often used in larger memory arrays. Intel provides two read-control inputs to accommodate multiple memory connections. Two-line control provides for:

- a. the lowest possible memory power dissipation and,
- b. complete assurance that output bus contention will not occur.

To efficiently use these two control inputs, an address-decoder output should drive chip-enable, while the system's read signal controls all flash-memories and other parallel memories. This assures that only enabled memory devices have active outputs, while deselected devices maintain the low power standby condition.

## **Power Supply Decoupling**

Flash-memory power-switching characteristics require careful device decoupling. System designers are interested in three supply current (I<sub>CC</sub>) issues—standby, active, and transient current peaks produced by falling and rising edges of chip-enable. The capacitive and inductive loads on the device outputs determine the magnitudes of these peaks.

Two-line control and proper decoupling capacitor selection will suppress transient voltage peaks. Each device should have a 0.1  $\mu F$  ceramic capacitor connected between  $V_{CC}$  and  $V_{SS}$ , and between  $V_{PP}$  and  $V_{SS}$ .

Place the high-frequency, low-inherent-inductance capacitors as close as possible to the devices. Also, for every eight devices, a 4.7  $\mu$ F electrolytic capacitor should be placed at the array's power supply connection, between V<sub>CC</sub> and V<sub>SS</sub>. The bulk capacitor will overcome voltage slumps caused by printed-circuit-board trace inductance, and will supply charge to the smaller capacitors as needed.

## **VPP Trace on Printed Circuit Boards**

Programming flash-memories, while they reside in the target system, requires that the printed circuit board designer pay attention to the  $V_{PP}$  power supply trace. The  $V_{PP}$  pin supplies the memory cell current for programming. Use similar trace widths and layout considerations given the  $V_{CC}$  power bus. Adequate  $V_{PP}$  supply traces and decoupling will decrease  $V_{PP}$  voltage spikes and overshoots.

## **Power Up/Down Protection**

The 28F020 is designed to offer protection against accidental erasure or programming during power transitions. Upon power-up, the 28F020 is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers up first. **Power supply sequencing is not required.** Internal circuitry in the 28F020 ensures that the command register is reset to the read mode on power up.

A system designer must guard against active writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either to  $V_{IH}$  will inhibit writes. The control register architecture provides an added level of protection since alteration of memory contents only occurs after successful completion of the two-step command sequences.

## 28F020 Power Dissipation

When designing portable systems, designers must consider battery power consumption not only during device operation, but also for data retention during system idle time. Flash nonvolatility increases the usable battery life of your system because the 28F020 does not consume any power to retain code or data when the system is off. Table 4 illustrates the power dissipated when updating the 28F020.

Table 4. 28F020 Typical Update Power Dissipation<sup>(4)</sup>

| Opuate i Over Dissipation    |       |                                  |  |  |  |  |  |  |
|------------------------------|-------|----------------------------------|--|--|--|--|--|--|
| Operation                    | Notes | Power Dissipation (Watt-Seconds) |  |  |  |  |  |  |
| Array Program/Program Verify | 1     | 0.34                             |  |  |  |  |  |  |
| Array Erase/Erase Verify     | 2     | 0.37                             |  |  |  |  |  |  |
| One Complete Cycle           | 3     | 1.05                             |  |  |  |  |  |  |

#### NOTES:

- 1. Formula to calculate typical Program/Program Verify Power =  $[V_{PP} \times \# \text{ Bytes} \times \text{ typical} \# \text{ Prog Pulse} \text{ } (t_{WHWH1} \times |_{PP2} \text{ typical} + t_{WHGL} \times |_{PP4} \text{ typical})] + [V_{CC} \times \# \text{ Bytes} \times \text{ typical} \# \text{ Prog Pulses} \text{ } (t_{WHWH1} \times |_{CC2} \text{ typical})] + t_{WHGL} \times |_{CC4} \text{ typical})].$
- 2. Formula to calculate typical Erase/Erase Verify Power = [Vpp (lpp3 typical  $\times$  terase typical + lpp5 typical  $\times$  twhgl  $\times$  # Bytes)] + [Vcc (lcc3 typical  $\times$  terase typical + lcc5 typical  $\times$  twhgl  $\times$  # Bytes)].
- 3. One Complete Cycle = Array Preprogram + Array Erase + Program.
- 4. "Typicals" are not guaranteed but based on a limited number of samples from 28F020-150 production lots.



## **ABSOLUTE MAXIMUM RATINGS\***

| Operating Temperature  During Read0°C to +70°C(1)  During Erase/Program0°C to +70°C(1)               |
|------------------------------------------------------------------------------------------------------|
| Operating Temperature During Read40°C to +85°C(2) During Erase/Program40°C to +85°C(2)               |
| Temperature Under Bias 10°C to +80°C(1)                                                              |
| Temperature Under Bias 50°C to + 95°C(2)                                                             |
| Storage Temperature65°C to +125°C                                                                    |
| Voltage on Any Pin with Respect to Ground2.0V to +7.0V <sup>(2)</sup>                                |
| Voltage on Pin A <sub>9</sub> with Respect to Ground $-2.0V$ to $+13.5V(2,3)$                        |
| V <sub>PP</sub> Supply Voltage with<br>Respect to Ground<br>During Erase/Program2.0V to +14.0V(2, 3) |
| V <sub>CC</sub> Supply Voltage with Respect to Ground2.0V to +7.0V(2)                                |

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

### NOTES:

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Operating temperature is for extended temperature product as defined by this specification.
- 3. Minimum DC input voltage is -0.5V. During transitions, inputs may undershoot to -2.0V for periods less than 20 ns. Maximum DC voltage on output pins is  $V_{CC}+0.5$ V, which may overshoot to  $V_{CC}+2.0$ V for periods less than 20 ns.
- 4. Maximum DC voltage on A<sub>9</sub> or V<sub>PP</sub> may overshoot to +14.0V for periods less than 20 ns.
- 5. Output shorted for no more than one second. No more than one output shorted at a time.
- 6. See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.
- 7. See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.

## **OPERATING CONDITIONS**

| Symbol          | Parameter                                           | Lin  | Unit |              |
|-----------------|-----------------------------------------------------|------|------|--------------|
| - Cymbol        | i urumetei                                          | Min  | Max  | ) June       |
| T <sub>A</sub>  | Operating Temperature(1)                            | . 0  | 70   | <b>°</b> C , |
| T <sub>A</sub>  | Operating Temperature <sup>(2)</sup>                | -40  | +85  | °C           |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (10%) <sup>(6)</sup> | 4.50 | 5.50 | V            |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (5%) <sup>(7)</sup>  | 4.75 | 5.25 | ٧            |

## DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Commercial Products

| Cumbal | Parameter              | Notes |     | Limits |      | Unit | Test Conditions                                       |  |
|--------|------------------------|-------|-----|--------|------|------|-------------------------------------------------------|--|
| Symbol | Parameter              | Notes | Min | Typ(4) | Max  | Unit | rest Conditions                                       |  |
| ել     | Input Leakage Current  | 1     |     |        | ±1.0 | μА   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$  |  |
| lo     | Output Leakage Current | 1 -   | ,   |        | ±10  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or V_{SS}$ |  |



## DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Commercial Products (Continued)

| 0                | B                                                |       |       | Limi   | ts             |      | Took Conditions                                                           |  |
|------------------|--------------------------------------------------|-------|-------|--------|----------------|------|---------------------------------------------------------------------------|--|
| Symbol           | Parameter                                        | Notes | Min   | Typ(4) | Max            | Unit | Test Conditions                                                           |  |
| Iccs             | V <sub>CC</sub> Standby Current                  | 1     |       | 0.3    | 1.0            | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = V <sub>IH</sub>            |  |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current              | 1     |       | 10     | 30             | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$       |  |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current              | 1, 2  |       | 1.0    | 10             | mΑ   | Programming in Progress                                                   |  |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                    | 1,,2  |       | 5.0    | 15             | mΑ   | Erasure in Progress                                                       |  |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current           | 1, 2  |       | 5.0    | 15             | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Program Verify in Progress        |  |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current             | 1, 2  |       | 5.0    | 15             | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress          |  |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                  | 1     |       |        | ±10            | μΑ   | $V_{PP} \leq V_{CC}$                                                      |  |
| l <sub>PP1</sub> | V <sub>PP</sub> Read Current, ID Current         | 1     |       | 90     | 200            | μΑ   | $V_{PP} > V_{CC}$                                                         |  |
|                  | or Standby Current                               |       |       |        | ±10            |      | $V_{PP} \leq V_{CC}$                                                      |  |
| lpp2             | V <sub>PP</sub> Programming Current              | 1, 2  |       | 8      | 30             | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress             |  |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                    | 1, 2  |       | 10     | 30             | mΑ   | $V_{PP} = V_{PPH}$                                                        |  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current           | 1, 2  |       | 2.0    | 5.0            | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Program Verify in Progress        |  |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current             | 1, 2  |       | 2.0    | 5.0            | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress          |  |
| V <sub>IL</sub>  | Input Low Voltage                                |       | -0.5  |        | 0.8            | >    |                                                                           |  |
| $V_{IH}$         | Input High Voltage                               |       | 2.0   |        | $V_{CC} + 0.5$ | ٧    |                                                                           |  |
| V <sub>OL</sub>  | Output Low Voltage                               |       | -     |        | 0.45           | ٧    | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$                |  |
| V <sub>OH1</sub> | Output High Voltage                              |       | 2.4   |        |                | ٧    | $I_{OH} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$               |  |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifer<br>Voltage  |       | 11.50 | ,      | 13.00          | >    |                                                                           |  |
| l <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |       | 90     | 200            | μΑ   | $A_9 = V_{ID}$                                                            |  |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations   |       | 0.00  |        | 6.5            | >    | NOTE: Erase/Program are Inhibited when V <sub>PP</sub> = V <sub>PPL</sub> |  |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations  |       | 11.40 |        | 12.60          | >    |                                                                           |  |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage         |       | 2.5   |        |                | ٧    |                                                                           |  |



## DC CHARACTERISTICS—CMOS COMPATIBLE—Commercial Products

|                   |                                                  |       | Limits                |        |                       |      | T10                                                                                            |  |
|-------------------|--------------------------------------------------|-------|-----------------------|--------|-----------------------|------|------------------------------------------------------------------------------------------------|--|
| Symbol            | Parameter                                        | Notes | Min                   | Typ(4) |                       | Unit | Test Conditions                                                                                |  |
| l <sub>Li</sub> . | Input Leakage Current                            | 1     |                       |        | ±1.0                  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$                                           |  |
| lo                | Output Leakage Current                           | 1     |                       |        | ±10                   | μΑ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>OUT</sub> = V <sub>CC</sub> or V <sub>SS</sub> |  |
| Iccs              | V <sub>CC</sub> Standby Current                  | 1     |                       | 50     | 100                   | μΑ   | $V_{CC} = V_{CC} Max$ $CE \# = V_{CC} \pm 0.2V$                                                |  |
| I <sub>CC1</sub>  | V <sub>CC</sub> Active Read Current              | 1     |                       | 10     | 30                    | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$                            |  |
| I <sub>CC2</sub>  | V <sub>CC</sub> Programming Current              | 1, 2  |                       | 1.0    | 10                    | mΑ   | Programming in Progress                                                                        |  |
| I <sub>CC3</sub>  | V <sub>CC</sub> Erase Current                    | 1, 2  |                       | 5.0    | 15                    | mΑ   | Erasure in Progress                                                                            |  |
| I <sub>CC4</sub>  | V <sub>CC</sub> Program Verify Current           | 1, 2  |                       | 5.0    | 15                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress                             |  |
| I <sub>CC5</sub>  | V <sub>CC</sub> Erase Verify<br>Current          | 1, 2  |                       | 5.0    | 15                    | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress                               |  |
| I <sub>PPS</sub>  | V <sub>PP</sub> Leakage Current                  | 1     |                       |        | ±10                   | μΑ   | $V_{PP} \leq V_{CC}$                                                                           |  |
| I <sub>PP1</sub>  | V <sub>PP</sub> Read Current,                    | - 1   |                       | 90     | 200                   | μΑ   | $V_{PP} > V_{CC}$                                                                              |  |
|                   | ID Current or<br>Standby Current                 |       |                       |        | ±10                   |      | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                              |  |
| I <sub>PP2</sub>  | V <sub>PP</sub> Programming<br>Current           | 1, 2  | `                     | -8     | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Programming in Progress                                |  |
| I <sub>PP3</sub>  | V <sub>PP</sub> Erase Current                    | 1, 2  |                       | 10     | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erasure in Progress                                    |  |
| I <sub>PP4</sub>  | V <sub>PP</sub> Program Verify<br>Current        | 1, 2  |                       | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Program Verify in Progress                             |  |
| I <sub>PP5</sub>  | V <sub>PP</sub> Erase Verify<br>Current          | 1, 2  |                       | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress                               |  |
| $V_{IL}$          | Input Low Voltage                                |       | -0.5                  |        | 0.8                   | ٧    |                                                                                                |  |
| VIH               | Input High Voltage                               |       | 0.7 V <sub>CC</sub>   |        | V <sub>CC</sub> + 0.5 | ٧    |                                                                                                |  |
| V <sub>OL</sub>   | Output Low Voltage                               |       |                       |        | 0.45                  | ٧    | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$                                     |  |
| V <sub>OH1</sub>  | Output High Voltage                              |       | 0.85 V <sub>CC</sub>  |        |                       | v    | $I_{OH} = -2.5 \text{ mA},$<br>$V_{CC} = V_{CC} \text{ Min}$                                   |  |
| V <sub>OH2</sub>  | - Voltago                                        | -     | V <sub>CC</sub> - 0.4 |        |                       | •    | $I_{OH} = -100 \mu A,$ $V_{CC} = V_{CC} Min$                                                   |  |
| V <sub>ID</sub>   | A <sub>9</sub> Intelligent Identifer<br>Voltage  |       | 11.50                 |        | 13.00                 | ٧    |                                                                                                |  |
| l <sub>ID</sub>   | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |                       | 90     | 200                   | μΑ   | $A_9 = V_{ID}$                                                                                 |  |
| V <sub>PPL</sub>  | V <sub>PP</sub> during Read-Only<br>Operations   |       | 0.00                  |        | 6.5                   | ٧    | <b>NOTE:</b> Erase/Programs are Inhibited when V <sub>PP</sub> = V <sub>PPL</sub>              |  |
| V <sub>PPH</sub>  | V <sub>PP</sub> during Read/Write<br>Operations  |       | 11.40                 |        | 12.60                 | ٧    |                                                                                                |  |
| V <sub>LKO</sub>  | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.5                   |        |                       | ٧    |                                                                                                |  |



# DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Extended Temperature Products

| O                | D                                                |       |       | Limi   | ts                    |      | T10                                                                                           |
|------------------|--------------------------------------------------|-------|-------|--------|-----------------------|------|-----------------------------------------------------------------------------------------------|
| Symbol           | Parameter                                        | Notes | Min   | Typ(4) | Max                   | Unit | Test Conditions                                                                               |
| Щ                | Input Leakage Current                            | 1     |       |        | ±1.0                  | μΑ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>IN</sub> = V <sub>CC</sub> or V <sub>SS</sub> |
| lo               | Output Leakage Current                           | 1     |       |        | ±10                   | μΑ   |                                                                                               |
| lccs             | V <sub>CC</sub> Standby Current                  | 1     |       | 0.3    | 1.0                   | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = V <sub>IH</sub>                                |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current              | 1     |       | 10     | 30                    | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$                           |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current              | 1, 2  |       | 1.0    | 30                    | mΑ   | Programming in Progress                                                                       |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                    | 1, 2  |       | 5.0    | 30                    | mΑ   | Erasure in Progress                                                                           |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current           | 1, 2  |       | 5.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Program Verify in Progress                            |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current             | 1, 2  |       | 5.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress,                             |
| IPPS             | V <sub>PP</sub> Leakage Current                  | 1     |       |        | ±10                   | μΑ   | $V_{PP} \leq V_{CC}$                                                                          |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, ID Current         | 1     |       | 90     | 200                   | μΑ   | $V_{PP} > V_{CC}$                                                                             |
|                  | or Standby Current                               |       |       |        | ±10                   |      | $V_{PP} \leq V_{CC}$                                                                          |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current              | 1, 2  |       | 8      | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress                                 |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                    | 1, 2  |       | 10     | - 30                  | mΑ   | $V_{PP} = V_{PPH}$                                                                            |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current           | 1, 2  |       | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Program Verify in Progress                            |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current             | 1, 2  |       | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress                              |
| $V_{IL}$         | Input Low Voltage                                |       | -0.5  |        | 0.8                   | ٧    |                                                                                               |
| V <sub>IH</sub>  | Input High Voltage                               |       | 2.0   |        | V <sub>CC</sub> + 0.5 | ٧    |                                                                                               |
| V <sub>OL</sub>  | Output Low Voltage                               |       |       |        | 0.45                  | ٧    | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$                                    |
| V <sub>OH1</sub> | Output High Voltage                              |       | 2.4   |        |                       | ٧    | $I_{OH} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$                                   |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifer<br>Voltage  |       | 11.50 |        | 13.00                 | ٧    |                                                                                               |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |       | 90     | 500                   | μΑ   | $A_9 = V_{ID}$                                                                                |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations   |       | 0.00  |        | 6.5                   | ٧    | NOTE: Erase/Program are Inhibited when V <sub>PP</sub> = V <sub>PPL</sub>                     |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations  |       | 11.40 | ı      | 12.60                 | ٧    |                                                                                               |
| $V_{LKO}$        | V <sub>CC</sub> Erase/Write Lock Voltage         |       | 2.5   |        |                       | ٧    |                                                                                               |



## DC CHARACTERISTICS—CMOS COMPATIBLE—Extended Temperature Products

| 0                |                                                  |       |                       | Limits |                       |      | Took Conditions                                                                                |  |
|------------------|--------------------------------------------------|-------|-----------------------|--------|-----------------------|------|------------------------------------------------------------------------------------------------|--|
| Symbol           | Parameter                                        | Notes | Min                   | Typ(4) | Max                   | Unit | Test Conditions                                                                                |  |
| l <sub>Ll</sub>  | Input Leakage Current                            | 1     |                       |        | ± 1.0                 | μΑ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>IN</sub> = V <sub>CC</sub> or V <sub>SS</sub>  |  |
| I <sub>LO</sub>  | Output Leakage Current                           | 1     |                       |        | ±10                   | μΑ   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>OUT</sub> = V <sub>CC</sub> or V <sub>SS</sub> |  |
| Iccs             | V <sub>CC</sub> Standby Current                  | 1     |                       | 50     | 100                   | μΑ   | $V_{CC} = V_{CC} Max$ $CE\# = V_{CC} \pm 0.2V$                                                 |  |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current              | 1     |                       | 10     | 50                    | mΑ   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$                            |  |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current              | 1, 2  |                       | 1.0    | 10                    | mΑ   | Programming in Progress                                                                        |  |
| Іссз             | V <sub>CC</sub> Erase Current                    | 1, 2  |                       | 5.0    | 30                    | mΑ   | Erasure in Progress                                                                            |  |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current           | 1, 2  |                       | 5.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress                             |  |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify<br>Current          | 1, 2  |                       | 5.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress                               |  |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                  | 1     |                       |        | ±10                   | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                              |  |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current,                    | 1     |                       | 90     | 200                   | μΑ   | $V_{PP} > V_{CC}$                                                                              |  |
| **               | ID Current or<br>Standby Current                 |       |                       |        | ±10                   |      | V <sub>PP</sub> ≤ V <sub>CC</sub>                                                              |  |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming<br>Current           | 1, 2  | ·                     | 8      | <b>30</b> :           | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Programming in Progress                                |  |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                    | 1, 2  |                       | 10     | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erasure in Progress                                    |  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify<br>Current        | 1, 2  |                       | 2.0    | 5.0                   | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Program Verify in Progress                             |  |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify<br>Current          | 1, 2  |                       | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> ,<br>Erase Verify in Progress                               |  |
| V <sub>IL</sub>  | Input Low Voltage                                |       | -0.5                  |        | 0.8                   | ٧    |                                                                                                |  |
| V <sub>IH</sub>  | Input High Voltage                               |       | 0.7 V <sub>CC</sub>   |        | V <sub>CC</sub> + 0.5 | ٧    |                                                                                                |  |
| V <sub>OL</sub>  | Output Low Voltage                               |       |                       |        | 0.45                  | ٧    | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$                                     |  |
| V <sub>OH1</sub> | Output High Voltage                              |       | 0.85 V <sub>CC</sub>  |        |                       | v    | $I_{OH} = -2.5 \text{ mA},$<br>$V_{CC} = V_{CC} \text{ Min}$                                   |  |
| V <sub>OH2</sub> | Output Flight Voltage                            |       | V <sub>CC</sub> - 0.4 |        |                       | ľ    | $I_{OH} = -100 \mu A,$ $V_{CC} = V_{CC} Min$                                                   |  |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifer<br>Voltage  |       | 11.50                 |        | 13.00                 | ٧    |                                                                                                |  |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |                       | 90     | 500                   | μΑ   | $A_9 = V_{ID}$                                                                                 |  |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations   |       | 0.00                  |        | 6.5                   | ٧    | NOTE: Erase/Programs are Inhibited when V <sub>PP</sub> = V <sub>PPL</sub>                     |  |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations  |       | 11.40                 |        | 12.60                 | ٧    |                                                                                                |  |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.5                   |        |                       | ٧    |                                                                                                |  |



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

| Symbol           | Parameter                   | Notes | Lir | nits | Unit | Conditions            |  |
|------------------|-----------------------------|-------|-----|------|------|-----------------------|--|
| Symbol           | Parameter                   | Notes | Min | Max  | Onit | Conditions            |  |
| C <sub>IN</sub>  | Address/Control Capacitance | 3     |     | 8    | pF   | $V_{IN} = 0V$         |  |
| C <sub>OUT</sub> | Output Capacitance          | 3     |     | 12   | pF   | V <sub>OUT</sub> = 0V |  |

## NOTES for DC Characteristics and Capacitance:

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (packages and speeds).
- 2. Not 100% tested: Characterization data available.
- 3. Sampled, not 100% tested.
- 4. "Typicals" are not guaranteed, but based on a limited number of samples from production lots.

#### TESTING INPUT/OUTPUT WAVEFORM(1)



AC test inputs are driven at  $V_{OH}$  (2.4  $V_{TTL}$ ) for a Logic "1" and V $_{OL}$  (0.45 V $_{TTL}$ ) for a Logic "0". Input timing begins at V $_{IH}$  (2.0 V $_{TTL}$ ) and V $_{IL}$  (0.8 V $_{TTL}$ ). Output timing ends at VIH and VIL. Input rise and fall times (10% to 90%) ≤10 ns.

## HIGH SPEED AC TESTING INPUT/OUTPUT WAVEFORMS(2)



AC test inputs are driven at 3.0V for a Logic "1" and 0.0V for a Logic "0". Input timing begins, and output timing ends, at 1.5V. Input rise and fall times (10% to 90%) ≤10 ns.

#### AC TESTING LOAD CIRCUIT(1)



#### HIGH SPEED AC TESTING LOAD CIRCUIT(2)



HIGH SPEED AC TEST CONDITIONS(2)

Input Rise and Fall Times (10% to 90%) . . . . . 10 ns Input Pulse Levels . . . . . . . . . . . . . . . . . . 0.0 and 3.0 Capacitive Load C<sub>I</sub> ......30 pF

## AC TEST CONDITIONS(1)

| Input Rise and Fall Times (10% to 90 | 0%)10 ns     |
|--------------------------------------|--------------|
| Input Pulse Levels                   | 0.45 and 2.4 |
| Input Timing Reference Level         | 0.8 and 2.0  |
| Output Timing Reference Level        | 0.8 and 2.0  |
| Capacitive LoadC <sub>1</sub>        | 100 pF       |

## NOTES:

- 1. Testing characteristics for 28F020-70 in standard configuration, and 28F020-90 and 28F020-150.
- 2. Testing characteristics for 28F020-70 in high speed configuration.

## AC CHARACTERISTICS—Read Only Operations—Commercial and Extended Temperature Products

|                                     | Versions                                           | V <sub>CC</sub> + 5%  | 28F02 | 0-70(4) |                          |     |                          |     |                           |     |      |
|-------------------------------------|----------------------------------------------------|-----------------------|-------|---------|--------------------------|-----|--------------------------|-----|---------------------------|-----|------|
| 1.                                  | Versions                                           | V <sub>CC</sub> + 10% |       |         | 28F020-70 <sup>(5)</sup> |     | 28F020-90 <sup>(5)</sup> |     | 28F020-150 <sup>(5)</sup> |     | Unit |
| Symbol                              | Characteristics                                    | Notes                 | Min   | Max     | Min                      | Max | Min                      | Max | Min                       | Max | 1    |
| t <sub>AVAV</sub> /t <sub>RC</sub>  | Read Cycle Time                                    |                       | 70    |         | 80                       |     | 90                       |     | 150                       |     | ns   |
| t <sub>ELQV</sub> /t <sub>CE</sub>  | Chip Enable<br>Access Time                         |                       |       | 70      |                          | 80  |                          | 90  |                           | 120 | ns   |
| tavqv/tacc                          | Address Access Time                                |                       |       | 70      |                          | 80  |                          | 90  |                           | 120 | ns   |
| t <sub>GLQV</sub> /t <sub>OE</sub>  | Output Enable<br>Access Time                       |                       |       | 28      |                          | 30  |                          | 35  |                           | 50  | ns   |
| t <sub>ELQX</sub> /t <sub>LZ</sub>  | Chip Enable to<br>Output in Low Z                  | 2, 3                  | 0     |         | 0                        |     | ٠.                       |     |                           |     | ns   |
| t <sub>EHQZ</sub>                   | Chip Disable to<br>Output in High Z                | 2                     |       | 35      |                          | 40  |                          | 45  |                           | 55  | ns   |
| t <sub>GLQX</sub> /t <sub>OLZ</sub> | Output Enable to<br>Output in Low Z                | 2, 3                  | 0     |         | 0                        |     |                          | 0   | 2                         |     | ns   |
| t <sub>GHQZ</sub> /t <sub>DF</sub>  | Output Disable to<br>Output in High Z              | 2                     |       | 30      |                          | 30  |                          | 30  |                           | 30  | ns   |
| t <sub>OH</sub>                     | Output Hold from<br>Address, CE#, or<br>OE# Change | 1, 2                  | 0     |         | 0                        |     |                          | 0   |                           |     | ns   |
| twHGL                               | Write Recovery Time before Read                    |                       | 6     |         | 6                        | -   |                          | 6   |                           | 6   | μs   |

## NOTES:

- 1. Whichever occurs first.
- 2. Sampled, not 100% tested.
- 3. Guaranteed by design.
- See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
   See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.



5-21



## AC CHARACTERISTICS—Write/Erase/Program Only Operations<sup>(1)</sup>—Commercial and Extended Temperature Products

|                                         | Versions                                          | V <sub>CC</sub> +5%   | 28F020                   | )-70(2, 4) |                          |     |                           |     |      |     |      |
|-----------------------------------------|---------------------------------------------------|-----------------------|--------------------------|------------|--------------------------|-----|---------------------------|-----|------|-----|------|
| . 3.310113                              |                                                   | V <sub>CC</sub> + 10% | 28F020-70 <sup>(5)</sup> |            | 28F020-90 <sup>(5)</sup> |     | 28F020-150 <sup>(5)</sup> |     | Unit |     |      |
| Symbol                                  | Characteristics                                   | Notes                 | Min                      | Max        | Min                      | Max | Min                       | Max | Min  | Max |      |
| t <sub>AVAV</sub> /t <sub>WC</sub>      | Write Cycle Time                                  |                       | 70                       |            | 80                       |     | 90                        |     | 150  |     | ns   |
| t <sub>AVWL</sub> /t <sub>AS</sub>      | Address Set-Up Time                               |                       | 0                        |            | 0                        |     | ` 0                       | ·   | 0    |     | ns   |
| twLAX/tAH                               | Address Hold Time                                 |                       | 40                       |            | 40                       |     | 40                        |     | 40   |     | ns   |
|                                         |                                                   | 6                     |                          |            |                          |     | 55                        |     |      |     | 115  |
| t <sub>DVWH</sub> /t <sub>DS</sub>      | Data Set-Up Time                                  |                       | 40                       |            | 40                       |     | 40                        |     | 40   |     | ns   |
|                                         | • .                                               | 6                     |                          |            |                          |     | 55                        |     |      | · · | 113  |
| t <sub>WHDX</sub> /t <sub>DH</sub>      | Data Hold Time                                    |                       | 10                       |            | 10                       |     | 10                        |     | 10   |     | ns   |
| twHGL                                   | Write Recovery Time before Read                   |                       | 6                        |            | 6                        |     | 6                         |     | 6    |     | μs   |
| t <sub>GHWL</sub>                       | Read Recovery Time before Write                   | 2                     | 0                        |            | 0                        |     | 0                         |     | 0    |     | ns   |
| t <sub>ELWL</sub> /                     | Chip Enable Set-Up<br>Time before Write           |                       | 15                       |            | 15                       |     | 15                        |     | 15   |     | ns   |
| t <sub>WHEH</sub> /                     | Chip Enable Hold Time                             |                       | 0 .                      |            | 0                        |     | .0                        |     | 0    | -   | ns   |
| t <sub>WLWH</sub> /t <sub>WP</sub>      | Write Pulse Width                                 |                       | 40                       |            | 40                       |     | 40                        |     | 60   |     | ns   |
|                                         |                                                   | 6                     |                          |            |                          |     | -55                       |     |      |     | 1115 |
| t <sub>WHWL</sub> /<br>t <sub>WPH</sub> | Write Pulse Width High                            | -                     | 20                       |            | 20                       |     | 20                        |     | 20   |     | ns   |
| twhwh1                                  | Duration of Programming<br>Operation              | 3                     | 10                       |            | 10                       |     | 10                        |     | 10   |     | μs   |
| twhwh2                                  | Duration of Erase<br>Operation                    | 3                     | 9.5                      |            | 9.5                      |     | 9.5                       |     | 9.5  |     | ms   |
| t <sub>VPEL</sub>                       | V <sub>PP</sub> Set-Up Time to<br>Chip Enable Low | 2                     | 1                        |            | 1                        |     | 1                         |     | 1    |     | μs   |

#### NOTES

- 1. Read timing characteristics during read/write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Guaranteed by design.
- 3. The integrated stop timer terminates the programming/erase operations, thus eliminating the need for a maximum specification.
- 4. See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 5. See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.
- 6. Minimum Specification for Extended Temperature product.





#### **ERASE AND PROGRAMMING PERFORMANCE**

| Parameter         | Notes   |     | Unit |     |      |  |
|-------------------|---------|-----|------|-----|------|--|
| Parameter         | Notes   | Min |      | Max | Oint |  |
| Chip Erase Time   | 1, 3, 4 |     | 2    | 30  | Sec  |  |
| Chip Program Time | 1, 2, 4 |     | 4    | 25  | Sec  |  |

#### NOTES

- 1. "Typicals" are not guaranteed, but based on a limited number of samples from production lots. Data taken at 25°C, 12.0V V<sub>PP</sub> at 0 cycles.
- 2. Minimum byte programming time excluding system overhead is 16  $\mu$ sec (10  $\mu$ sec program + 6  $\mu$ sec write recovery), while maximum is 400  $\mu$ sec/byte (16  $\mu$ sec x 25 loops allowed by algorithm). Max chip programming time is specified lower than the worst case allowed by the programming algorithm since most bytes program significantly faster than the worst case byte.
- 3. Excludes 00H Programming prior to Erasure.
- 4. Excludes System-Level Overhead.
- 5. Refer to RR-60, 69 "ETOX Flash Memory Reliability Data Summaries" for typical cycling data and failure rate calculations.





Figure 8. 28F020 Typical Programming Capability





Figure 9. 28F020 Typical Program Time at 12V





Figure 10. 28F020 Typical Erase Capability





Figure 11. 28F020 Typical Erase Time at 12.0V





æ

5-29



5

## AC CHARACTERISTICS—Alternate CE# Controlled Writes—Commercial and Extended Temperature Products

| Versions           |                                                   | V <sub>CC</sub> +5%   | 28F020 | )-70(2, 4) |       |                      |       |         |        |                      |      |
|--------------------|---------------------------------------------------|-----------------------|--------|------------|-------|----------------------|-------|---------|--------|----------------------|------|
| 10101010           |                                                   | V <sub>CC</sub> + 10% |        |            | 28F02 | .0-70 <sup>(5)</sup> | 28F02 | 0-90(5) | 28F020 | )-150 <sup>(5)</sup> | Unit |
| Symbol             | Characteristics                                   | Notes                 | Min    | Max        | Min   | Max                  | Min   | Max     | Min    | Max                  | 7    |
| t <sub>AVAV</sub>  | Write Cycle Time                                  |                       | 70     |            | 80    |                      | 90    |         | 150    |                      | ns   |
| t <sub>AVEL</sub>  | Address Set-Up Time                               |                       | 0      |            | 0     |                      | 0     |         | 0      |                      | ns   |
| t <sub>ELAX</sub>  | Address Hold Time                                 |                       | 50     |            | 50    |                      | 50    |         | 55     |                      |      |
|                    | ·                                                 | 6                     |        |            |       |                      | 60    |         |        |                      | ns   |
| t <sub>DVEH</sub>  | Data Set-Up Time                                  |                       | 40     |            | 40    |                      | 40    |         | 45     |                      | ns   |
|                    |                                                   | 6                     |        |            |       |                      | 50    |         |        |                      | 1    |
| t <sub>EHDX</sub>  | Data Hold Time                                    |                       | 10     |            | 10    |                      | 10    |         | 10     |                      | ns   |
| t <sub>EHGL</sub>  | Write Recovery Time before Read                   |                       | 6      |            | 6     |                      | 6     |         | 6 .    |                      | μs   |
| t <sub>GHWL</sub>  | Read Recovery Time before Write                   | 2                     | 0      |            | 0     |                      | 0     |         | 0      |                      | ns   |
| t <sub>WLEL</sub>  | Write Enable Set-Up Time before Chip Enable       |                       | 0      |            | 0     |                      | 0     |         | 0      | -                    | ns   |
| tEHWH              | Write Enable Hold Time                            |                       | 0      |            | 0     |                      | 0     |         | 0      |                      | ns   |
| tELEH              | Write Pulse Width                                 |                       | 50     |            | 50    |                      | 50    |         | 70     |                      | ns   |
|                    | ,                                                 | 6                     |        |            |       |                      | 60    |         |        |                      | 1    |
| tEHEL              | Write Pulse Width High                            |                       | 20     |            | 20    |                      | 20    |         | 20     |                      | ns   |
| t <sub>EHEH1</sub> | Duration of Programming<br>Operation              | 3                     | 10     |            | 10    |                      | 10    |         | 10     |                      | μs   |
| t <sub>EHEH2</sub> | Duration of Erase Operation                       | 3                     | 9.5    |            | 9.5   |                      | 9.5   |         | 9.5    |                      | ms   |
| t <sub>VPEL</sub>  | V <sub>PP</sub> Set-Up Time to<br>Chip Enable Low | 2                     | 1      |            | 1     |                      | 1     |         | 1      |                      | μs   |

#### NOTES:

- 1. Read timing characteristics during read/write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Guaranteed by design.
- 3. The integrated stop timer terminates the programming/erase operations, thus eliminating the need for a maximum specification.
- 4. See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteritics.
- 5. See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.
- 6. Minimum specification for Extended Temperature product.



STANDBY/ V<sub>CC</sub> POWER-DOWN

PROGRAM

VERIFICATION

tAVAV (tRC)

28F020

**NOTE:**Alternative CE-Controlled Write Timings also apply to erase operations.

V<sub>CC</sub> POWER-UP & STANDBY

ADDRESSES

SET-UP PROGRAM

COMMAND

<sup>t</sup>EHWH

tWLEL

PROGRAM COMMAND

- t<sub>AVAV</sub> (t<sub>WC</sub>)

twLEL

+ tavel --

LATCH ADDRESS & DATA

t<sub>ELAX</sub>

t<sub>EHWH</sub>

PROGRAMMING

PROGRAM

VERIFY COMMAND

teHWH



## ORDERING INFORMATION



## **ADDITIONAL INFORMATION**

|         |                                                                              | Order<br>Number |
|---------|------------------------------------------------------------------------------|-----------------|
| ER-20,  | "ETOX Flash Memory<br>Technology"                                            | 294005          |
| ER-24,  | "Intel Flash Memory"                                                         | 294008          |
| ER-28,  | "ETOX III Flash Memory<br>Technology"                                        | 294012          |
| RR-60,  | "ETOX Flash Memory<br>Reliability Data Summary"                              | 293002          |
| AP-316, | "Using Flash Memory for In-<br>System Reprogrammable<br>Nonvolatile Storage" | 292046          |
| AP-325  | "Guide to Flash Memory Reprogramming"                                        | 292059          |

## **REVISION HISTORY**

| Number | Description                                                                                                                                    |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------|
| -004   | Removed <b>Preliminary</b> Classification. Clarified AC and DC test conditions. Added "dimple" to F TSOP package. Corrected serpentine layout. |
| -005   | Added -80V05, -90 ns speed grades.<br>Added extended temperature<br>devices. Corrected AC Waveforms.                                           |
| -006   | Added -70 ns speed.  Deleted -80V05 speed.  Revised symbols, i.e., $\overline{CE}$ , $\overline{OE}$ , etc. to $CE\#$ , $OE\#$ , etc.          |



## 28F010 1024K (128K x 8) CMOS FLASH MEMORY

- Flash Electrical Chip-Erase— 1 Second Typical Chip-Erase
- **Quick Pulse Programming Algorithm** 
  - 10 μs Typical Byte-Program
  - 2 Second Chip-Program
- 100,000 Erase/Program Cycles
- 12.0V ±5% Vpp
- High-Performance Read
  - 65 ns Maximum Access Time
- **CMOS Low Power Consumption** 
  - 10 mA Typical Active Current
  - 50 μA Typical Standby Current
  - 0 Watts Data Retention Power
- Integrated Program/Erase Stop Timer

- Command Register Architecture for Microprocessor/Microcontroller Compatible Write Interface
- Noise Immunity Features
  - ± 10% V<sub>CC</sub> Tolerance
  - Maximum Latch-Up Immunity through EPI Processing
- **ETOX Nonvolatile Flash Technology** 
  - EPROM-Compatible Process Base
  - High-Volume Manufacturing Experience
- JEDEC-Standard Pinouts
  - 32-Pin Plastic Dip
  - 32-Lead PLCC
  - 32-Lead TSOP
  - (See Packaging Spec., Order #231369)

■ Extended Temperature Options

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

The 28F010 is a 1024 kilobit nonvolatile memory organized as 131,072 bytes of 8 bits. Intel's 28F010 is offered in 32-pin plastic dip or 32-lead PLCC and TSOP packages. Pin assignments conform to JEDEC standards for byte-wide EPROMs.

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

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

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





Figure 1. 28F010 Block Diagram

**Table 1. Pin Description** 

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





Figure 2. 28F010 Pin Configurations



## **APPLICATIONS**

The 28F010 flash memory provides nonvolatility along with the capability to perform over 100,000 electrical chip-erasure/reprogram cycles. These features make the 28F010 an innovative alternative to disk, EEPROM, and battery-backed static RAM. Where periodic updates of code and data-tables are required, the 28F010's reprogrammability and nonvolatility make it the obvious and ideal replacement for EPROM.

Primary applications and operating systems stored in flash eliminate the slow disk-to-DRAM download process. This results in dramatic enhancement of performance and substantial reduction of power consumption — a consideration particularly important in portable equipment. Flash memory increases flexibility with electrical chip erasure and in-system update capability of operating systems and application code. With updatable code, system manufacturers can easily accommodate last-minute changes as revisions are made.

In diskless workstations and terminals, network traffic reduces to a minimum and systems are instanton. Reliability exceeds that of electromechanical media. Often in these environments, power interruptions force extended re-boot periods for all networked terminals. This mishap is no longer an issue if boot code, operating systems, communication protocols and primary applications are flash-resident in each terminal.

For embedded systems that rely on dynamic RAM/ disk for main system memory or nonvolatile backup storage, the 28F010 flash memory offers a solid state alternative in a minimal form factor. The 28F010 provides higher performance, lower power consumption, instant-on capability, and allows an "execute in place" memory hierarchy for code and data table reading. Additionally, the flash memory is more rugged and reliable in harsh environments where extreme temperatures and shock can cause disk-based systems to fail.

The need for code updates pervades all phases of a system's life — from prototyping to system manufacture to after-sale service. The electrical chip-erasure and reprogramming ability of the 28F010 allows incircuit alterability; this eliminates unnecessary handling and less-reliable socketed connections, while adding greater test, manufacture, and update flexibility.

Material and labor costs associated with code changes increases at higher levels of system integration — the most costly being code updates after sale. Code "bugs", or the desire to augment system functionality, prompt after-sale code updates. Field revisions to EPROM components or entire boards. With the 28F010, code updates are implemented locally via an edge-connector, or remotely over a communcation link.

For systems currently using a high-density static RAM/battery configuration for data accumulation, flash memory's inherent nonvolatility eliminates the need for battery backup. The concern for battery failure no longer exists, an important consideration for portable equipment and medical instruments, both requiring continuous performance. In addition, flash memory offers a considerable cost advantage over static RAM.

Flash memory's electrical chip erasure, byte programmability and complete nonvolatility fit well with data accumulation and recording needs. Electrical chip-erasure gives the designer a "blank slate" in which to log or record data. Data can be periodically off-loaded for analysis and the flash memory erased producing a new "blank slate".

A high degree of on-chip feature integration simplifies memory-to-processor interfacing. Figure 4 depicts two 28F010s tied to the 80C186 system bus. The 28F010's architecture minimizes interface circuitry needed for complete in-circuit updates of memory contents.

The outstanding feature of the TSOP (Thin Small Outline Package) is the 1.2 mm thickness. With standard and reverse pin configurations, TSOP reduces the number of board layers and overall volume necessary to layout multiple 28F010s. TSOP is particularly suited for portable equipment and applications requiring large amounts of flash memory. Figure 3 illustrates the TSOP Serpentine layout.

With cost-effective in-system reprogramming, extended cycling capability, and true nonvolatility, the 28F010 offers advantages to the alternatives: EPROMs, EEPROMs, battery backed static RAM, or disk. EPROM-compatible read specifications, straight-forward interfacing, and in-circuit alterability offers designers unlimited flexibility to meet the high standards of today's designs.





Figure 3. TSOP Serpentine Layout





Figure 4. 28F010 in a 80C186 System

## PRINCIPLES OF OPERATION

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

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

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

Commands are written to the register using standard microprocessor write timings. Register contents serve as input to an internal state-machine which controls the erase and programming circuitry. Write cycles also internally latch addresses and data

needed for programming or erase operations. With the appropriate command written to the register, standard microprocessor read timings output array data, access the Intelligent Identifier codes, or output data for erase and program verification.

## **Integrated Stop Timer**

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

## Write Protection

The command register is only active when V<sub>PP</sub> is at high voltage. Depending upon the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable—available only when memory updates are desired. When V<sub>PP</sub> = V<sub>PPI</sub>, the con-



| Table | 2. | 28F0 | 10 | Bus | 0 | peration | าร |
|-------|----|------|----|-----|---|----------|----|
|-------|----|------|----|-----|---|----------|----|

|                 | V <sub>PP</sub> (1)                | Ao               | Ag              | CE#                 | OE#               | WE#             | DQ <sub>0</sub> -DQ <sub>7</sub> |             |
|-----------------|------------------------------------|------------------|-----------------|---------------------|-------------------|-----------------|----------------------------------|-------------|
|                 | Operation                          | · PP·            | VPP(") AU       |                     |                   | <u> </u>        |                                  | 240 247     |
|                 | Read                               | V <sub>PPL</sub> | A <sub>0</sub>  | A <sub>9</sub>      | $V_{IL}$          | V <sub>IL</sub> | V <sub>IH</sub>                  | Data Out    |
|                 | Output Disable                     | V <sub>PPL</sub> | Х               | Х                   | V <sub>IL</sub>   | V <sub>IH</sub> | V <sub>IH</sub>                  | Tri-State   |
| READ-ONLY       | Standby                            | V <sub>PPL</sub> | Х               | Х                   | V <sub>IH</sub>   | Х               | Х                                | Tri-State   |
|                 | Intelligent Identifier (Mfr)(2)    | V <sub>PPL</sub> | V <sub>IL</sub> | V <sub>ID</sub> (3) | V <sub>IL</sub>   | V <sub>IL</sub> | V <sub>IH</sub>                  | Data = 89H  |
|                 | Intelligent Identifier (Device)(2) | V <sub>PPL</sub> | V <sub>IH</sub> | V <sub>ID</sub> (3) | $V_{IL}$          | V <sub>IL</sub> | V <sub>IH</sub>                  | Data = B4H  |
|                 | Read                               | V <sub>PPH</sub> | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub>   | V <sub>IL</sub> | V <sub>IH</sub>                  | Data Out(4) |
| READ/WRITE      | Output Disable                     | V <sub>PPH</sub> | Х               | Х                   | V <sub>IL</sub>   | V <sub>IH</sub> | V <sub>IH</sub>                  | Tri-State   |
| TIE/IE/ WITHITE | Standby <sup>(5)</sup>             | V <sub>PPH</sub> | Х               | Х                   | V <sub>IH</sub> . | Х               | Х                                | Tri-State   |
|                 | Write                              | V <sub>PPH</sub> | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub>   | V <sub>IH</sub> | V <sub>IL</sub>                  | Data In(6)  |

#### NOTES:

- 1. Refer to DC Characteristics. When V<sub>PP</sub> = V<sub>PPI</sub> memory contents can be read but not written or erased.
- 2. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 3. All other addresses low.
- 3. V<sub>ID</sub> is the Intelligent Identifier high voltage. Refer to DC Characteristics.
- 4. Read operations with V<sub>PP</sub> = V<sub>PPH</sub> may access array data or the Intelligent Identifier codes.
- 5. With  $V_{PP}$  at high voltage, the standby current equals  $I_{CC} + I_{PP}$  (standby).
- 6. Refer to Table 3 for valid Data-In during a write operation.

7. X can be V<sub>IL</sub> or V<sub>IH</sub>.

tents of the register default to the read command, making the 28F010 a read-only memory. In this mode, the memory contents cannot be altered.

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

The two-step program/erase write sequence to the Command Register provides additional software write protections.

#### **BUS OPERATIONS**

#### Read

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

When V<sub>PP</sub> is high (V<sub>PPH</sub>), the read operation can be used to access array data, to output the Intelligent Identifier codes, and to access data for program/

erase verification. When  $V_{PP}$  is low  $(V_{PPL})$ , the read operation can **only** access the array data.

## **Output Disable**

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

#### Standby

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

#### Intelligent Identifier Operation

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



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

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

## Write

Device erasure and programming are accomplished via the command register, when high voltage is applied to the V<sub>PP</sub> pin. The contents of the register serve as input to the internal state-machine. The state-machine outputs dictate the function of the device.

The command register itself does not occupy an addressable memory location. The register is a latch

used to store the command, along with address and data information needed to execute the command.

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

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

### **COMMAND DEFINITIONS**

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

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

**Table 3. Command Definitions** 

| Command                                          | Bus<br>Cycles | Firs                     | t Bus Cycle |         | Second Bus Cycle |            |         |  |
|--------------------------------------------------|---------------|--------------------------|-------------|---------|------------------|------------|---------|--|
|                                                  | Req'd         | Operation <sup>(1)</sup> | Address(2)  | Data(3) | Operation(1)     | Address(2) | Data(3) |  |
| Read Memory                                      | 1             | Write                    | Х           | 00H     |                  |            |         |  |
| Read Intelligent Identifier Codes <sup>(4)</sup> | 3             | Write                    | Х           | 90H     | Read             | (4)        | (4)     |  |
| Set-up Erase/Erase(5)                            | 2             | Write                    | Х           | 20H     | Write            | Х          | 20H     |  |
| Erase Verify <sup>(5)</sup>                      | 2             | Write                    | EA          | A0H     | Read             | Х          | EVD     |  |
| Set-up Program/Program(6)                        | 2             | Write                    | Х           | 40H     | Write            | PA         | PD      |  |
| Program Verify <sup>(6)</sup>                    | 2             | Write                    | Х           | COH     | Read             | . X        | PVD     |  |
| Reset <sup>(7)</sup>                             | 2             | Write                    | Х           | FFH     | Write            | Х          | FFH     |  |

#### NOTES:

- 1. Bus operations are defined in Table 2.
- 2. IA = Identifier address: 00H for manufacturer code, 01H for device code.
  - EA = Address of memory location to be read during erase verify.
  - PA = Address of memory location to be programmed.

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

- 3. ID = Data read from location IA during device identification (Mfr = 89H, Device = B4H).
  - EVD = Data read from location EA during erase verify.
  - PD = Data to be programmed at location PA. Data is latched on the rising edge of Write Enable.
  - PVD = Data read from location PA during program verify. PA is latched on the Program command.
- 4. Following the Read inteligent ID command, two read operations access manufacturer and device codes.
- 5. Figure 6 illustrates the Quick Erase Algorithm.
- 6. Figure 5 illustrates the Quick Pulse Programming Algorithm.
- 7. The second bus cycle must be followed by the desired command register write.



#### Read Command

While V<sub>PP</sub> is high, for erasure and programming, memory contents can be accessed via the read command. The read operation is initiated by writing 00H into the command register. Microprocessor read cycles retrieve array data. The device remains enabled for reads until the command register contents are altered.

The default contents of the register upon  $V_{PP}$  power-up is 00H. This default value ensures that no spurious alteration of memory contents occurs during the  $V_{PP}$  power transition. Where the  $V_{PP}$  supply is hard-wired to the 28F010, the device powers-up and remains enabled for reads until the command-register contents are changed. Refer to the AC Read Characteristics and Waveforms for specific timing parameters.

## Intelligent Identifier Command

Flash memories are intended for use in applications where the local CPU alters memory contents. As such, manufacturer- and device-codes must be accessible while the device resides in the target system. PROM programmers typically access signature codes by raising A9 to a high voltage. However, multiplexing high voltage onto address lines is not a desired system-design practice.

The 28F010 contains an Intelligent Identifier operation to supplement traditional PROM-programming methodology. The operation is initiated by writing 90H into the command register. Following the command write, a read cycle from address 0000H retrieves the manufacturer code of 89H. A read cycle from address 0001H returns the device code of B4H. To terminate the operation, it is necessary to write another valid command into the register.

## Set-up Erase/Erase Commands

Set-up Erase is a command-only operation that stages the device for electrical erasure of all bytes in the array. The set-up erase operation is performed by writing 20H to the command register.

To commence chip-erasure, the erase command (20H) must again be written to the register. The erase operation begins with the rising edge of the Write-Enable pulse and terminates with the rising edge of the next Write-Enable pulse (i.e., Erase-Verify Command).

This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, chip-erasure can only occur when high voltage is applied to the  $V_{PP}$  pin. In the absence

of this high voltage, memory contents are protected against erasure. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

## **Erase-Verify Command**

The erase command erases all bytes of the array in parallel. After each erase operation, all bytes must be verified. The erase verify operation is initiated by writing A0H into the command register. The address for the byte to be verified must be supplied as it is latched on the falling edge of the Write-Enable pulse. The register write terminates the erase operation with the rising edge of its Write-Enable pulse.

The 28F010 applies an internally-generated margin voltage to the addressed byte. Reading FFH from the addressed byte indicates that all bits in the byte are erased.

The erase-verify command must be written to the command register prior to each byte verification to latch its address. The process continues for each byte in the array until a byte does not return FFH data, or the last address is accessed.

In the case where the data read is not FFH, another erase operation is performed. (Refer to Set-up Erase/Erase). Verification then resumes from the address of the last-verified byte. Once all bytes in the array have been verified, the erase step is complete. The device can be programmed. At this point, the verify operation is terminated by writing a valid command (e.g. Program Set-up) to the command register. Figure 6, the Quick Erase algorithm, illustrates how commands and bus operations are combined to perform electrical erasure of the 28F010. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

## Set-up Program/Program Commands

Set-up program is a command-only operation that stages the device for byte programming. Writing 40H into the command register performs the set-up operation.

Once the program set-up operation is performed, the next Write-Enable pulse causes a transition to an active programming operation. Addresses are internally latched on the falling edge of the Write-Enable pulse. Data is internally latched on the rising edge of the Write-Enable pulse. The rising edge of Write-Enable also begins the programming operation. The programming operation. The programming operation terminates with the next rising edge of Write-Enable, used to write the program-verify command. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.



## **Program-Verify Command**

The 28F010 is programmed on a byte-by-byte basis. Byte programming may occur sequentially or at random. Following each programming operation, the byte just programmed must be verified.

The program-verify operation is initiated by writing C0H into the command register. The register write terminates the programming operation with the rising edge of its Write-Enable pulse. The program-verify operation stages the device for verification of the byte last programmed. No new address information is latched.

The 28F010 applies an internally-generated margin voltage to the byte. A microprocessor read cycle outputs the data. A successful comparison between the programmed byte and true data means that the byte is successfully programmed. Programming then proceeds to the next desired byte location. Figure 5, the 28F010 Quick Pulse Programming algorithm, illustrates how commands are combined with bus operations to perform byte programming. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.

#### **Reset Command**

A reset command is provided as a means to safely abort the erase- or program-command sequences. Following either set-up command (erase or program) with two consecutive writes of FFH will safely abort the operation. Memory contents will not be altered. A valid command must then be written to place the device in the desired state.

### EXTENDED ERASE/PROGRAM CYCLING

EEPROM cycling failures have always concerned users. The high electrical field required by thin oxide EEPROMs for tunneling can literally tear apart the oxide at defect regions. To combat this, some suppliers have implemented redundancy schemes, reducing cycling failures to insignificant levels. However, redundancy requires that cell size be doubled—an expensive solution.

Intel has designed extended cycling capability into its ETOX flash memory technology. Resulting improvements in cycling reliability come without increasing memory cell size or complexity. First, an advanced tunnel oxide increases the charge carrying ability ten-fold. Second, the oxide area per cell subjected to the tunneling electric field is one-tenth that of common EEPROMs, minimizing the probability of oxide defects in the region. Finally, the peak electric field during erasure is approximately 2 MV/cm lower than EEPROM. The lower electric

field greatly reduces oxide stress and the probability of failure—increasing time to wearout by a factor of 100,000,000.

The 28F010 is capable or 100,000 program/erase cycles. The device is programmed and erased using Intel's Quick Pulse Programming and Quick Erase algorithms. Intel's algorithmic approach uses a series of operations (pulses), along with byte verification, to completely and reliably erase and program the device.

For further information, see Reliability Report RR-60.

#### QUICK PULSE PROGRAMMING ALGORITHM

The Quick Pulse Programming algorithm uses programming operations of 10  $\mu s$  duration. Each operation is followed by a byte verification to determine when the addressed byte has been successfully programmed. The algorithm allows for up to 25 programming operations per byte, although most bytes verify on the first or second operation. The entire sequence of programming and byte verification is performed with  $V_{PP}$  at high voltage. Figure 5 illustrates the Quick Pulse Programming algorithm.

## QUICK ERASE ALGORITHM

Intel's Quick Erase algorithm yields fast and reliable electrical erasure of memory contents. The algorithm employs a closed-loop flow, similar to the Quick Pulse Programming algorithm, to simultaneously remove charge from all bits in the array.

Erasure begins with a read of memory contents. The 28F010 is erased when shipped from the factory. Reading FFH data from the device would immediately be followed by device programming.

For devices being erased and reprogrammed, uniform and reliable erasure is ensured by first programming all bits in the device to their charged state (Data = 00H). This is accomplished, using the Quick Pulse Programming algorithm, in approximately two seconds.

Erase execution then continues with an initial erase operation. Erase verification (data = FFH) begins at address 0000H and continues through the array to the last address, or until data other than FFH is encountered. With each erase operation, an increasing number of bytes verify to the erased state. Erase efficiency may be improved by storing the address of the last byte verified in a register. Following the next erase operation, verification starts at that stored address location. Erasure typically occurs in one second. Figure 6 illustrates the Quick Erase algorithm.





Figure 5. 28F010 Quick Pulse Programming Algorithm





Figure 6. 28F010 Quick Erase Algorithm

vice.

4. CAUTION: The algorithm MUST BE FOLLOWED

to ensure proper and reliable operation of the de-

2. Erase Verify is performed only after chip-erasure. A

final read/compare may be performed (optional) after

the register is written with the read command.



## **DESIGN CONSIDERATIONS**

## **Two-Line Output Control**

Flash-memories are often used in larger memory arrays. Intel provides two read-control inputs to accommodate multiple memory connections. Two-line control provides for:

- a. the lowest possible memory power dissipation and.
- b. complete assurance that output bus contention will not occur.

To efficiently use these two control inputs, an address-decoder output should drive chip-enable, while the system's read signal controls all flash-memories and other parallel memories. This assures that only enabled memory devices have active outputs, while deselected devices maintain the low power standby condition.

## **Power Supply Decoupling**

Flash-memory power-switching characteristics require careful device decoupling. System designers are interested in three supply current (I<sub>CC</sub>) issues—standby, active, and transient current peaks produced by falling and rising edges of chip-enable. The capacitive and inductive loads on the device outputs determine the magnitudes of these peaks.

Two-line control and proper decoupling capacitor selection will suppress transient voltage peaks. Each device should have a 0.1  $\mu F$  ceramic capacitor connected between  $V_{CC}$  and  $V_{SS}$ , and between  $V_{PP}$  and  $V_{SS}$ .

Place the high-frequency, low-inherent-inductance capacitors as close as possible to the devices. Also, for every eight devices, a 4.7  $\mu\text{F}$  electrolytic capacitor should be placed at the array's power supply connection, between VCC and VSS. The bulk capacitor will overcome voltage slumps caused by printed-

circuit-board trace inductance, and will supply charge to the smaller capacitors as needed.

## **Vpp Trace on Printed Circuit Boards**

Programming flash-memories, while they reside in the target system, requires that the printed circuit board designer pay attention to the  $V_{PP}$  power supply trace. The  $V_{PP}$  pin supplies the memory cell current for programming. Use similar trace widths and layout considerations given the  $V_{CC}$  power bus. Adequate  $V_{PP}$  supply traces and decoupling will decrease  $V_{PP}$  voltage spikes and overshoots.

## **Power Up/Down Protection**

The 28F010 is designed to offer protection against accidental erasure or programming during power transitions. Upon power-up, the 28F010 is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers up first. Power supply sequencing is not required. Internal circuitry in the 28F010 ensures that the command register is reset to the read mode on power up.

A system designer must guard against active writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either to  $V_{IH}$  will inhibit writes. The control register architecture provides an added level of protection since alteration of memory contents only occurs after successful completion of the two-step command sequences.

## 28F010 Power Dissipation

When designing portable systems, designers must consider battery power consumption not only during device operation, but also for data retention during system idle time. Flash nonvolatility increases the usable battery life of your system because the 28F010 does not consume any power to retain code or data when the system is off. Table 4 illustrates the power dissipated when updating the 28F010.

Table 4. 28F010 Typical Update Power Dissipation(4)

| · · · · · · · · · · · · · · · · · · · | •     | •                                |  |  |
|---------------------------------------|-------|----------------------------------|--|--|
| Operation                             | Notes | Power Dissipation (Watt-Seconds) |  |  |
| Array Program/Program Verify          | 1     | 0.171                            |  |  |
| Array Erase/Erase Verify              | 2 .   | 0.136                            |  |  |
| One Complete Cycle                    | 3     | 0.478                            |  |  |

#### NOTES:

- 1. Formula to calculate typical Program/Program Verify Power = [V<sub>PP</sub>  $\times$  # Bytes  $\times$  typical # Prog Pulses (t<sub>WHWH1</sub>  $\times$  I<sub>PP2</sub> typical + t<sub>WHGL</sub>  $\times$  I<sub>PP4</sub> typical)] + [V<sub>CC</sub>  $\times$  # Bytes  $\times$  typical # Prog Pulses (t<sub>WHWH1</sub>  $\times$  I<sub>CC2</sub> typical + t<sub>WHGL</sub>  $\times$  I<sub>CC4</sub> typical].
- 2. Formula to calculate typical Erase/Erase Verify Power = [V<sub>PP</sub> (V<sub>PP3</sub> typical × t<sub>ERASE</sub> typical + l<sub>PP5</sub> typical × t<sub>WHGL</sub> × # Bytes)] + [V<sub>CC</sub> (l<sub>CC3</sub> typical ×
- $t_{ERASE}$  typical +  $t_{CC5}$  typical  $\times$   $t_{WHGL}$   $\times$  # Bytes)]. 3. One Complete Cycle = Array Preprogram + Array Erase + Program.
- 4. "Typicals" are not guaranteed, but based on a limited number of samples from production lots.



#### **ABSOLUTE MAXIMUM RATINGS\***

| Operating Temperature                                                    |
|--------------------------------------------------------------------------|
| During Read0°C to +70°C(1)                                               |
| During Erase/Program0°C to +70°C(1)                                      |
| Operating Temperature                                                    |
| During Read40°C to +85°C(2)                                              |
| During Erase/Program40°C to +85°C(2)                                     |
| Temperature Under Bias $-10^{\circ}$ C to $+80^{\circ}$ C <sup>(1)</sup> |
| Temperature Under Bias $-50^{\circ}$ C to $+95^{\circ}$ C <sup>(2)</sup> |
| Storage Temperature65°C to +125°C                                        |
| Voltage on Any Pin with                                                  |
| Respect to Ground $-2.0V$ to $+7.0V^{(3)}$                               |
| Voltage on Pin A <sub>9</sub> with                                       |
| Respect to Ground $-2.0V$ to $+13.5V^{(3, 4)}$                           |
| V <sub>PP</sub> Supply Voltage with                                      |
| Respect to Ground                                                        |
| During Erase/Program $-2.0V$ to $+14.0V^{(3, 4)}$                        |
| V <sub>CC</sub> Supply Voltage with                                      |
| Respect to Ground $-2.0V$ to $+7.0V$ <sup>(3)</sup>                      |
| Output Short Circuit Current                                             |

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

- 1. Operating Temperature is for commercial product as defined by this specification.
- 2. Operating Temperature is for extended temperature products as defined by this specification.
- 3. Minimum DC input voltage is -0.5V. During transitions, inputs may undershoot to -2.0V for periods less than 20 ns. Maximum DC voltage on output pins is  $V_{CC} + 0.5$ V, which may overshoot to  $V_{CC} + 2.0$ V for periods less than 20 ns.
- 4. Maximum DC voltage on A<sub>9</sub> or V<sub>PP</sub> may overshoot to +14.0V for periods less than 20 ns.
- 5. Output shorted for no more than one second. No more than one output shorted at a time.
- 6. See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 7. See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.

#### **OPERATING CONDITIONS**

| Symbol          | Parameter                            | Lin  | Unit |    |
|-----------------|--------------------------------------|------|------|----|
| - Cylliddi      | i didilictor                         | Min  | Max  |    |
| T <sub>A</sub>  | Operating Temperature                | 0    | 70   | °C |
| T <sub>A</sub>  | Operating Temperature                | -40  | + 85 | °C |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (10%) | 4.50 | 5.50 | V  |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage (5%)  | 4.75 | 5.25 | V  |

### DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Commercial Products

| Symbol           | Parameter                           | Notes | Limits |     | Notes |                 | Unit                                                                  | Test Conditions |
|------------------|-------------------------------------|-------|--------|-----|-------|-----------------|-----------------------------------------------------------------------|-----------------|
| Cymbol           | rarameter                           |       |        | Max | 0     | rest conditions |                                                                       |                 |
| lu               | Input Leakage Current               | 1     |        |     | ±1.0  | μА              | $V_{CC} = V_{CC} Max$ $V_{IN} = V_{CC} or V_{SS}$                     |                 |
| llo              | Output Leakage Current              | . 1   |        |     | ±10   | μΑ              | $V_{CC} = V_{CC} Max$ $V_{OUT} = V_{CC} \text{ or } V_{SS}$           |                 |
| Iccs             | V <sub>CC</sub> Standby Current     | 1     |        | 0.3 | 1.0   | mA              | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = V <sub>IH</sub>        |                 |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current | 1     |        | 10  | 30    | mA              | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0$ mA |                 |



# DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Commercial Products

(Continued)

| Svmbol           | Parameter                                       | Notes |       | Limits                 | SUI                   |          | Test Conditions                                                          |  |
|------------------|-------------------------------------------------|-------|-------|------------------------|-----------------------|----------|--------------------------------------------------------------------------|--|
| oyboi            | i diametei                                      | Notes | Min   | Typical <sup>(4)</sup> | Max                   | Oint     | Tool conditions                                                          |  |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current             | 1, 2  |       | 1.0                    | 10                    | mΑ       | Programming in Progress                                                  |  |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                   | 1, 2  |       | 5.0                    | 15                    | mΑ       | Erasure in Progress                                                      |  |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current          | 1, 2  |       | 5.0                    | 15                    | mA       | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress       |  |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current            | 1, 2  |       | 5.0                    | 15                    | mA       | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress         |  |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                 | 1     |       |                        | ±10                   | μΑ       | V <sub>PP</sub> ≤ V <sub>CC</sub>                                        |  |
| l <sub>PP1</sub> | V <sub>PP</sub> Read Current                    | 1     |       | 90                     | 200                   | μΑ       | $V_{PP} > V_{CC}$                                                        |  |
|                  | or Standby Current                              |       |       |                        | ±10.0                 |          | $V_{PP} \leq V_{CC}$                                                     |  |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current             | 1, 2  |       | 8.0                    | 30                    | mA       | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress            |  |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                   | 1, 2  |       | 6.0                    | 30                    | mΑ       | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress                |  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current          | 1, 2  |       | 2.0                    | 5.0                   | mΑ       | V <sub>PP</sub> = V <sub>PPH</sub> , Program Verify in Progress          |  |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current            | 1, 2  |       | 2.0                    | 5.0                   | mA       | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress         |  |
| V <sub>I</sub> L | Input Low Voltage                               |       | -0.5  |                        | 0.8                   | ٧        |                                                                          |  |
| $V_{IH}$         | Input High Voltage                              |       | 2.0   |                        | V <sub>CC</sub> + 0.5 | ٧        |                                                                          |  |
| V <sub>OL</sub>  | Output Low Voltage                              |       |       |                        | 0.45                  | <b>V</b> | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$               |  |
| V <sub>OH1</sub> | Output High Voltage                             |       | 2.4   |                        |                       | <b>V</b> | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                 |  |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifer Voltage    |       | 11.50 |                        | 13.00                 | ٧        |                                                                          |  |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current   | 1, 2  |       | 90                     | 200                   | μΑ       | $A_9 = V_{ID}$                                                           |  |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations  |       | 0.00  |                        | 6.5                   | >_       | NOTE: Erase/Program are Inhibited when V <sub>PP</sub> = V <sub>PP</sub> |  |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations |       | 11.40 |                        | 12.60                 | ٧        |                                                                          |  |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage        |       | 2.5   |                        |                       | ٧        |                                                                          |  |

# DC CHARACTERISTICS—CMOS COMPATIBLE—Commercial Products

| Symbol           | Parameter                           | Notes  | Limits |                        |      | Unit | Test Conditions                                                     |
|------------------|-------------------------------------|--------|--------|------------------------|------|------|---------------------------------------------------------------------|
| Cymino.          | r aramotor                          | 110100 | Min    | Typical <sup>(4)</sup> | Max  | 0    | 7001001141110110                                                    |
| ILI              | Input Leakage Current               | 1      |        | ·                      | ±1.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$                |
| I <sub>LO</sub>  | Output Leakage Current              | 1      |        |                        | ± 10 | μΑ   | $V_{CC} = V_{CC} Max$ $V_{OUT} = V_{CC} or V_{SS}$                  |
| Iccs             | V <sub>CC</sub> Standby Current     | 1      |        | 50                     | 100  | μΑ   | $V_{CC} = V_{CC} Max$ $CE \# = V_{CC} \pm 0.2V$                     |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current | 1      |        | 10                     | 30   | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$ |



# DC CHARACTERISTICS—CMOS COMPATIBLE—Commercial Products (Continued)

| Symbol           | Parameter                                        | Notes |                       | Limits     |                       | Unit | Test Conditions                                                            |
|------------------|--------------------------------------------------|-------|-----------------------|------------|-----------------------|------|----------------------------------------------------------------------------|
| Зушьог           | raiailletei                                      | Notes | Min                   | Typical(4) | Max                   | Oint | rest conditions                                                            |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current              | 1, 2  |                       | 1.0        | 10                    | mA   | Programming in Progress                                                    |
| ICC3             | V <sub>CC</sub> Erase Current                    | 1, 2  | 1                     | 5.0        | 15                    | mA   | Erasure in Progress                                                        |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current           | 1, 2  |                       | 5.0        | 15                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress         |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current             | 1, 2  |                       | 5.0        | 15                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress           |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                  | 1     |                       |            | ±10                   | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                          |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, ID                 | 1     |                       | 90         | 200                   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                          |
|                  | Current or Standby Current                       |       |                       |            | . ±10                 |      | V <sub>PP</sub> ≤ V <sub>CC</sub>                                          |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming<br>Current           | 1, 2  |                       | 8.0        | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress              |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                    | 1, 2  |                       | 6.0        | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress                  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify<br>Current        | 1, 2  |                       | 2.0        | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress         |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify<br>Current          | 1, 2  |                       | 2.0        | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress           |
| V <sub>IL</sub>  | Input Low Voltage                                |       | -0.5                  |            | 0.8                   | ٧    |                                                                            |
| V <sub>IH</sub>  | Input High Voltage                               |       | 0.7 V <sub>CC</sub>   |            | V <sub>CC</sub> + 0.5 | ٧    |                                                                            |
| V <sub>OL</sub>  | Output Low Voltage                               |       |                       |            | 0.45                  | V    | $I_{OL} = 5.8 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                    |
| V <sub>OH1</sub> | Output High Voltage                              |       | 0.85 V <sub>CC</sub>  |            |                       | v    | $I_{OH} = -2.5$ mA, $V_{CC} = V_{CC}$ Min                                  |
| V <sub>OH2</sub> | , output riight voltage                          |       | V <sub>CC</sub> - 0.4 |            |                       |      | $I_{OH} = -100 \mu\text{A}, V_{CC} = V_{CC} \text{Mir}$                    |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifer<br>Voltage  | ,     | 11.50                 |            | 13.00                 | ٧    |                                                                            |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |                       | 90         | 200                   | μΑ   | $A_9 = V_{ID}$                                                             |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations   | ,     | 0.00                  |            | 6.5                   | ٧    | NOTE: Erase/Programs are Inhibited when V <sub>PP</sub> = V <sub>PPL</sub> |
| Уррн             | V <sub>PP</sub> during Read/Write<br>Operations  |       | 11.40                 |            | 12.60                 | ٧    |                                                                            |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.5                   |            |                       | ٧    |                                                                            |



# DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Extended Temperature Products

| Symbol           | Parameter                                       | Notes  |       | Limits                 | 3              | Unit  | Test Conditions                                                    |  |
|------------------|-------------------------------------------------|--------|-------|------------------------|----------------|-------|--------------------------------------------------------------------|--|
| Cymbol           | i arameter                                      | 110103 | Min   | Typical <sup>(4)</sup> | Max            | 01111 | 7001001141110110                                                   |  |
| lu               | Input Leakage Current                           | 1      |       | ı                      | ±1.0           | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$               |  |
| ILO              | Output Leakage Current                          | 1      |       |                        | ±10            | μΑ    | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or V_{SS}$              |  |
| Iccs             | V <sub>CC</sub> Standby Current                 | 1 .    |       | 0.3                    | 1.0            | mA    | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = V <sub>IH</sub>     |  |
| l <sub>CC1</sub> | V <sub>CC</sub> Active Read Current             | 1      |       | 10                     | 30             | mA    | $V_{CC} = V_{CC} Max, CE # = V_{IL}$ f = 6 MHz, $I_{OUT} = 0 mA$   |  |
| lcc2             | V <sub>CC</sub> Programming Current             | 1, 2   |       | 1.0                    | 30             | mΑ    | Programming in Progress                                            |  |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                   | 1, 2   |       | 5.0                    | 30             | mΑ    | Erasure in Progress                                                |  |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current          | 1, 2   |       | 5.0                    | 30             | mA    | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress |  |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current            | 1, 2   |       | 5.0                    | 30             | mA    | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress   |  |
| IPPS             | V <sub>PP</sub> Leakage Current                 | 1      |       |                        | ±10            | μΑ    | $V_{PP} \leq V_{CC}$                                               |  |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current                    | 1      |       | 90                     | 200            | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                  |  |
|                  | or Standby Current                              |        |       |                        | ±10.0          |       | V <sub>PP</sub> ≤ V <sub>CC</sub>                                  |  |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current             | 1, 2   |       | 8.0                    | 30             | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress      |  |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                   | 1, 2   |       | 6.0                    | 30             | mΑ    | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress          |  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current          | 1, 2   |       | 2.0                    | 5.0            | mA    | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress |  |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current            | 1, 2   |       | 2.0                    | 5.0            | mA    | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress   |  |
| ٧ <sub>L</sub>   | Input Low Voltage                               |        | -0.5  |                        | 0.8            | ٧     | <u>'</u>                                                           |  |
| V <sub>IH</sub>  | Input High Voltage                              |        | 2.0   |                        | $V_{CC} + 0.5$ | ٧     |                                                                    |  |
| V <sub>OL</sub>  | Output Low Voltage                              |        |       |                        | 0.45           | ٧     | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$         |  |
| V <sub>OH1</sub> | Output High Voltage                             |        | 2.4   |                        |                | ٧     | $I_{OH} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$        |  |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifer Voltage    |        | 11.50 |                        | 13.00          | ٧     | ,                                                                  |  |
| اوا              | A <sub>9</sub> Intelligent Identifier Current   | 1, 2   |       | 90                     | 500            | μΑ    | $A_9 = V_{ID}$                                                     |  |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations  |        | 0.00  |                        | 6.5            | ٧     | <b>NOTE:</b> Erase/Program are Inhibited when $V_{PP} = V_{PPL}$   |  |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations |        | 11.40 |                        | 12.60          | ٧     |                                                                    |  |
| $V_{LKO}$        | V <sub>CC</sub> Erase/Write Lock Voltage        |        | 2.5   |                        |                | ٧     |                                                                    |  |



# DC CHARACTERISTICS—CMOS COMPATIBLE—Extended Temperature Products

| Symbol           | Parameter                                        | Notes | Limits                | Unit                   | Test Conditions       |      |                                                                        |
|------------------|--------------------------------------------------|-------|-----------------------|------------------------|-----------------------|------|------------------------------------------------------------------------|
| Symbol           | raiailletei                                      | Notes | Min                   | Typical <sup>(4)</sup> | Max                   | Oint | rest conditions                                                        |
| l <sub>LI</sub>  | Input Leakage<br>Current                         | 1     | .*                    |                        | ± 1.0                 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$                   |
| I <sub>LO</sub>  | Output Leakage<br>Current                        | 1     |                       |                        | ± 10                  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or V_{SS}$                  |
| Iccs             | V <sub>CC</sub> Standby<br>Current               | 1     |                       | 50                     | 100                   | μΑ   | $V_{CC} = V_{CC} Max$<br>$CE \# = V_{CC} \pm 0.2V$                     |
| lcc1             | V <sub>CC</sub> Active Read<br>Current           | 1     |                       | 10                     | 30                    | mA   | $V_{CC} = V_{CC}$ Max, $CE\# = V_{IL}$<br>f = 10 MHz, $I_{OUT} = 0$ mA |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming<br>Current           | 1, 2  |                       | 1.0                    | 10                    | mA   | Programming in Progress                                                |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                    | 1, 2  |                       | 5.0                    | 30                    | mΑ   | Erasure in Progress                                                    |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify<br>Current        | 1, 2  |                       | 5.0                    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress     |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify<br>Current          | 1, 2  |                       | 5.0                    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress       |
| IPPS             | V <sub>PP</sub> Leakage Current                  | 1     |                       | ,                      | ±10                   | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                      |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current,                    | 1     |                       | 90                     | 200                   | μΑ   | $V_{PP} > V_{CC}$                                                      |
|                  | ID Current or<br>Standby Current                 |       |                       |                        | ±10                   |      | V <sub>PP</sub> ≤ V <sub>CC</sub>                                      |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming<br>Current           | 1, 2  | ,                     | 8.0                    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress          |
| Ірр3             | V <sub>PP</sub> Erase Current                    | 1, 2  |                       | 6.0                    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress              |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify<br>Current        | 1, 2  |                       | 2.0                    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Program<br>Verify in Progress     |
| Ірр5             | V <sub>PP</sub> Erase Verify<br>Current          | 1, 2  |                       | 2.0                    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub> , Erase<br>Verify in Progress       |
| V <sub>IL</sub>  | Input Low Voltage                                |       | -0.5                  |                        | 0.8                   | ٧    |                                                                        |
| VIH              | Input High Voltage                               |       | 0.7 V <sub>CC</sub>   |                        | V <sub>CC</sub> + 0.5 | ٧    |                                                                        |
| V <sub>OL</sub>  | Output Low Voltage                               |       |                       |                        | 0.45                  | ٧    | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$             |
| V <sub>OH1</sub> | Output High Voltage                              |       | 0.85 V <sub>CC</sub>  |                        |                       |      | $I_{OH} = -2.5 \text{ mA},$<br>$V_{CC} = V_{CC} \text{ Min}$           |
| V <sub>OH2</sub> |                                                  |       | V <sub>CC</sub> - 0.4 | ,                      |                       | V    | $I_{OH} = -100 \mu A,$ $V_{CC} = V_{CC} Min$                           |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifer<br>Voltage  |       | 11.50                 |                        | 13.00                 | ٧    | , .                                                                    |
| l <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |                       | 90                     | 500                   | μΑ   | $A_9 = V_{ID}$                                                         |



# DC CHARACTERISTICS—CMOS COMPATIBLE—Extended Temperature Products (Continued)

| Symbol           | Parameter                                       | Notes |       | Limits                 |       | Unit | Test Conditions                                                                   |
|------------------|-------------------------------------------------|-------|-------|------------------------|-------|------|-----------------------------------------------------------------------------------|
| Oybo.            | , arameter                                      | Notes | Min   | Typical <sup>(4)</sup> | Max   | 0    | Tool oonalions                                                                    |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations  |       | 0.00  |                        | 6.5   | ٧    | <b>NOTE:</b> Erase/Programs are Inhibited when V <sub>PP</sub> = V <sub>PPL</sub> |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations |       | 11.40 |                        | 12.60 | ٧    |                                                                                   |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock<br>Voltage     |       | 2.5   |                        |       | ٧    |                                                                                   |

# CAPACITANCE $T_A = 25$ °C, f = 1.0 MHz

| Symbol           | Parameter                   | Notes  | Lir | nits | Unit | Conditions            |
|------------------|-----------------------------|--------|-----|------|------|-----------------------|
| Cymbol           | , aramotor                  | 110100 | Min | Max  |      | Conditions            |
| C <sub>IN</sub>  | Address/Control Capacitance | 3      |     | 8    | pF   | $V_{IN} = 0V$         |
| C <sub>OUT</sub> | Output Capacitance          | 3      |     | 12   | pF   | V <sub>OUT</sub> = 0V |

#### NOTES

2. Not 100% tested: characterization data available.

<sup>1.</sup> All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T = 25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).

<sup>3.</sup> Sampled, not 100% tested.

<sup>4. &</sup>quot;Typicals" are not guaranteed, but based on a limited number of samples from production lots.



# AC TESTING INPUT/OUTPUT WAVEFORM(1)



AC test inputs are driven at V $_{OH}$  (2.4 V $_{TTL}$ ) for a Logic "1" and V $_{OL}$  (0.45 V $_{TTL}$ ) for a Logic "0". Input timing begins at V $_{IH}$  (2.0 V $_{TTL}$ ) and V $_{IL}$  (0.8 V $_{TTL}$ ). Output timing ends at V $_{IH}$  and V $_{IL}$ . Input rise and fall times (10% to 90%) <10 ns.

# HIGH SPEED AC TESTING INPUT/OUTPUT WAVEFORM(2)



AC test inputs are driven at 3.0V for a Logic "1" and 0.0V for a Logic "0". Input timing begins, and output timing ends, at 1.5V. Input rise and fall times (10% to 90%) <10 ns.

#### AC TESTING LOAD CIRCUIT(1)



#### HIGH SPEED AC TESTING LOAD CIRCUIT(2)



#### AC TEST CONDITIONS(1)

| Input Rise and Fall Times (10% | to 90%) 10 ns  |
|--------------------------------|----------------|
| Input Pulse Levels             | 0.45V and 2.4V |
| Input Timing Reference Level . | 0.8V and 2.0V  |
| Output Timing Reference Level  | 0.8V and 2.0V  |
| Capacitive Load                | 100 pF         |

#### HIGH-SPEED AC TEST CONDITIONS(2)

| Input Rise and Fall Times (10% to 90 | )%) 10 ns     |
|--------------------------------------|---------------|
| Input Pulse Levels                   | 0.0V and 3.0V |
| Input Timing Reference Level         | 1.5V          |
| Output Timing Reference Level        | 1.5V          |
| Capacitive Load                      | 30 pF         |

#### NOTES

- 1. Testing characteristics for 28F010-65 in standard configuration, and 28F010-90, 28F010-120, and 28F010-150.
- 2. Testing characteristics for 28F010-65 in high speed configuration.

AC CHARACTERISTICS-Temperature Products

Read Only Operations—Commercial and Extended

|                                     | Versions                                        | V <sub>CC</sub> ± 5%  | 28F01 | 0-65(4) |       |                     |       |         |        |                      |        |                      |      |
|-------------------------------------|-------------------------------------------------|-----------------------|-------|---------|-------|---------------------|-------|---------|--------|----------------------|--------|----------------------|------|
|                                     |                                                 | V <sub>CC</sub> ± 10% |       |         | 28F01 | 0-65 <sup>(5)</sup> | 28F01 | 0-90(5) | 28F010 | )-120 <sup>(5)</sup> | 28F010 | )-150 <sup>(5)</sup> | Unit |
| Symbol                              | Characteristic                                  | Notes                 | Min   | Max     | Min   | Max                 | Min   | Max     | Min    | Max                  | Min    | Max                  |      |
| t <sub>AVAV</sub> /t <sub>RC</sub>  | Read Cycle Time                                 |                       | 65    |         | 70    |                     | 90    |         | 120    |                      | 150    |                      | ns   |
| t <sub>ELQV</sub> /t <sub>CE</sub>  | Chip Enable Access Time                         |                       |       | 65      |       | 70                  |       | 90      |        | 120                  |        | 150                  | ns   |
| tAVQV/tACC                          | Address Access Time                             |                       |       | 65      |       | 70                  |       | 90      |        | 120                  |        | 150                  | ns   |
| tGLQV/tOE                           | Output Enable Access Time                       |                       |       | 25      |       | 28                  |       | 35      |        | 50                   |        | 55                   | ns   |
| t <sub>ELQX</sub> /t <sub>LZ</sub>  | Chip Enable to Low Z                            | 2, 3                  | 0     |         | 0     |                     |       |         |        |                      |        |                      | ns   |
| t <sub>EHQZ</sub>                   | Chip Disable to Output in High Z                | 2                     |       | 35      |       | 40                  | -     | 45      |        | 55                   |        | 55                   | ns   |
| t <sub>GLQX</sub> /t <sub>OLZ</sub> | Output Enable to Output in Low Z                | 2, 3                  | 0     |         | 0     |                     |       | 0       |        |                      |        |                      | ns   |
| t <sub>GHQZ</sub> /t <sub>DF</sub>  | Output Disable to Output in High Z              | 2                     |       | 30      |       | 30                  |       | 30      |        | 30                   |        | 35                   | ns   |
| t <sub>OH</sub>                     | Output Hold from Address,<br>CE#, or OE# Change | 1, 2                  | 0     |         | 0     |                     |       | 0       |        |                      |        |                      | ns   |
| twHGL                               | Write Recovery Time<br>before Read              | -                     | 6     |         | 6     |                     |       | 6       |        | 6                    |        | 6                    | μs   |

#### NOTES:

- 1. Whichever occurs first.

- Willchever occurs inst.
   Sampled, not 100% tested.
   Guaranteed by design.
   See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
   See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.





AC CHARACTERISTICS—Write/Erase/Program Only Operations(1)—Commercial and Extended Temperature Products

|                                     | Versions                                          | V <sub>CC</sub> ± 5%  | 28F01 | 0-65(4)                  |     |                          |     |                           |     |                           |     |      |      |
|-------------------------------------|---------------------------------------------------|-----------------------|-------|--------------------------|-----|--------------------------|-----|---------------------------|-----|---------------------------|-----|------|------|
|                                     |                                                   | V <sub>CC</sub> ± 10% |       | 28F010-65 <sup>(5)</sup> |     | 28F010-90 <sup>(5)</sup> |     | 28F010-120 <sup>(5)</sup> |     | 28F010-150 <sup>(5)</sup> |     | Unit |      |
| Symbol                              | Characteristic                                    | Notes                 | Min   | Max                      | Min | Max                      | Min | Max                       | Min | Max                       | Min | Max  | ]    |
| t <sub>AVAV</sub> /t <sub>WC</sub>  | Write Cycle Time                                  |                       | 65    |                          | 70  |                          | 90  |                           | 120 |                           | 150 |      | ns   |
| t <sub>AVWL</sub> /t <sub>AS</sub>  | Address Set-Up Time                               |                       | 0     |                          | 0   |                          | . 0 |                           | 0   |                           | 0   |      | ns   |
| t <sub>WLAX</sub> /t <sub>AH</sub>  | Address Hold Time                                 |                       | 40    |                          | 40  |                          | 40  |                           | 40  |                           | 40  |      |      |
|                                     |                                                   | 6                     |       |                          |     |                          | 55  |                           |     |                           |     |      | ns   |
| t <sub>DVWH</sub> /t <sub>DS</sub>  | Data Set-Up Time                                  |                       | 40    |                          | 40  |                          | 40  |                           | 40  |                           | 40  |      | ns l |
|                                     |                                                   | 6                     |       |                          |     |                          | 55  |                           |     |                           |     |      | 113  |
| t <sub>WHDX</sub> /t <sub>DH</sub>  | Data Hold Time                                    |                       | 10    |                          | 10  |                          | 10  |                           | 10  |                           | 10  |      | ns   |
| t <sub>WHGL</sub>                   | Write Recovery Time before Read                   | ·                     | 6     |                          | 6   |                          | 6   |                           | 6   |                           | 6   |      | μs   |
| tGHWL                               | Read Recovery Time before Write                   | 2                     | 0     |                          | 0   |                          | 0   |                           | 0   |                           | 0   |      | ns   |
| t <sub>ELWL</sub> /t <sub>CS</sub>  | Chip Enable Set-Up Time before Write              |                       | 15    |                          | 15  |                          | 15  |                           | 15  |                           | 15  |      | ns   |
| t <sub>WHEH</sub> /t <sub>CH</sub>  | Chip Enable Hold Time                             |                       | 0     |                          | 0   |                          | 0   |                           | 0   |                           | 0   |      | ns   |
| t <sub>WLWH</sub> /t <sub>WP</sub>  | Write Pulse Width                                 |                       | 40    |                          | 40  |                          | 40  |                           | 60  |                           | 60  |      |      |
|                                     | '                                                 | 6                     |       |                          |     |                          | 55  |                           |     |                           |     |      | ns   |
| t <sub>WHWL</sub> /t <sub>WPH</sub> | Write Pulse Width High                            |                       | 20    |                          | 20  |                          | 20  |                           | 20  |                           | 20  |      | ns   |
| t <sub>WHWH1</sub>                  | Duration of Programming<br>Operation              | 3                     | 10    |                          | 10  |                          | 10  | -                         | 10  |                           | 10  |      | μs   |
| t <sub>WHWH2</sub>                  | Duration of Erase<br>Operation                    | 3                     | 9.5   |                          | 9.5 |                          | 9.5 | ,                         | 9.5 |                           | 9.5 |      | ms   |
| t <sub>VPEL</sub>                   | V <sub>PP</sub> Set-Up Time to<br>Chip Enable Low | 2                     | 1     |                          | 1   |                          | 1   |                           | 1   |                           | 1   |      | μs   |

#### NOTES:

- 1. Read timing characteristics during read/write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Guaranteed by design.
- 3. The integrated stop timer terminates the programming/erase operations, thus eliminating the need for a maximum specification.

  4. See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.

  5. See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.
- 6. Minimum specification for Extended Temperature product.





Figure 8. Typical Programming Capability



Figure 9. Typical Program Time at 12V





Figure 10. Typical Erase Capability



Figure 11. Typical Erase Time at 12V







|                       | Versions                                          | V <sub>CC</sub> ± 5% | 28F010  | )-65(2, 4) |       |         |       |         |       |          |       |                      |      |
|-----------------------|---------------------------------------------------|----------------------|---------|------------|-------|---------|-------|---------|-------|----------|-------|----------------------|------|
|                       | 7 57 51 61 16                                     |                      |         |            | 28F01 | 0-65(5) | 28F01 | 0-90(5) | 28F01 | 0-120(5) | 28F01 | 0-150 <sup>(5)</sup> | Unit |
| Symbol Characteristic |                                                   | Notes                | Min Max | Max        | Min   | Max     | Min   | Max     | Min   | Max      | Min   | Max                  | ]    |
| t <sub>AVAV</sub>     | Write Cycle Time                                  |                      | 65      |            | 70    |         | 90    |         | 120   |          | 150   |                      | ns   |
| tAVEL                 | Address Set-Up Time                               |                      | 0       | !          | 0     |         | 0     |         | 0     |          | 0     |                      | ns   |
| tELAX                 | Address Hold Time                                 |                      | 45      |            | 45    |         | 45    |         | 55    |          | 55    |                      |      |
|                       |                                                   | 6                    |         |            |       |         | 60    |         |       |          |       |                      | ns   |
| t <sub>DVEH</sub>     | Data Set-Up Time                                  |                      | 35      |            | 35    |         | 35    |         | 45    |          | 45    |                      |      |
|                       |                                                   | 6                    |         |            |       |         | 50    |         |       |          |       |                      | ns   |
| t <sub>EHDX</sub>     | Data Hold Time                                    |                      | 10      |            | 10    |         | 10    |         | 10    |          | 10    |                      | ns   |
| t <sub>EHGL</sub>     | Write Recovery Time before Read                   |                      | 6       |            | 6     |         | 6     |         | 6     |          | 6     |                      | μs   |
| tGHWL                 | Read Recovery Time before Write                   | 2                    | 0       |            | 0     |         | 0     |         | 0     |          | 0     |                      | ns   |
| tWLEL                 | Write Enable Set-Up Time before Chip Enable       |                      | 0       |            | 0     |         | 0     | -       | 0     |          | 0     | ·                    | ns   |
| tEHWH                 | Write Enable Hold Time                            |                      | 0       |            | 0     |         | 0     |         | 0     |          | . 0   |                      | ns   |
| t <sub>ELEH</sub>     | Write Pulse Width                                 | ·                    | 45      |            | 45    |         | 45    |         | 70    |          | 70    |                      |      |
|                       |                                                   | 6                    |         |            |       |         | 60    |         |       |          |       |                      | ns   |
| t <sub>EHEL</sub>     | Write Pulse Width High                            |                      | 20      |            | 20    |         | 20    |         | 20    |          | 20    |                      | ns   |
| t <sub>EHEH1</sub>    | Duration of Programming Operation                 | 3                    | 10      |            | 10    |         | 10    | -       | 10    |          | 10    |                      | μs   |
| t <sub>EHEH2</sub>    | Duration of Erase<br>Operation                    | 3                    | 9.5     |            | 9.5   |         | 9.5   |         | 9.5   |          | 9.5   | -                    | ms   |
| t <sub>VPEL</sub>     | V <sub>PP</sub> Set-Up Time to Chip<br>Enable Low | - 2                  | 1       | -          | 1     |         | 1 .   |         | 1     |          | 1     |                      | μs   |

### NOTE:

- 1. Read timing characteristics during read/write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Guaranteed by design.
- 3. The integrated stop timer terminates the programming/erase operations, thus eliminating the need for a maximum specification.

  4. See High Speed AC Input/Output reference Waveforms and High Speed AC Testing Load Circuits for testing characteristics.
- 5. See AC Input/Output reference Waveforms and AC Testing Load Circuits for testing characteristics.
- 6. Minimum specification for Extended Temperature product.





#### **ERASE AND PROGRAMMING PERFORMANCE**

| Parameter       | Notes   | Min | Typical | Max | Unit |
|-----------------|---------|-----|---------|-----|------|
| Chip Erase Time | 1, 3, 4 |     | 2       | 30  | Sec  |
|                 | 1, 2, 4 |     | 4       | 25  | Sec  |

#### NOTES:

- 1. "Typicals" are not guaranteed, but based on samples from production lots. Data taken at 25°C, 12.0V Vpp.
- 2. Minimum byte programming time excluding system overhead is 16  $\mu$ sec (10  $\mu$ sec program + 6  $\mu$ sec write recovery), while maximum is 400  $\mu$ sec/byte (16  $\mu$ sec x 25 loops allowed by algorithm). Max chip programming time is specified lower than the worst case allowed by the programming algorithm since most bytes program significantly faster than the worst case byte.
- 3. Excludes 00H programming prior to erasure.
- 4. Excludes system level overhead.







## ORDERING INFORMATION



Order

## ADDITIONAL INFORMATION

|         |                                                                                | Number |
|---------|--------------------------------------------------------------------------------|--------|
| ER-20,  | "ETOX Flash Memory<br>Technology"                                              | 294005 |
| ER-24,  | "Intel Flash Memory"                                                           | 294008 |
| ER-28,  | "ETOX III Flash Memory<br>Technology"                                          | 294012 |
| RR-60,  | "ETOX Flash Memory<br>Reliability Data Summary"                                | 293002 |
| AP-316, | "Using Flash Memory for<br>In-System<br>Reprogrammable<br>Nonvolatile Storage" | 292046 |
| AP-325  | "Guide to Flash Memory Reprogramming"                                          | 292059 |

## **REVISION HISTORY**

| Number | Description                                                                                                                                                                                                     |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 007    | Removed <b>200 ns</b> Speed Bin Revised Erase Maximum Pulse Count for Figure 5 from <b>3000</b> to <b>1000</b> Clarified AC and DC Test Conditions Added "dimple" to F TSOP Package Corrected Serpentine Layout |
| 008    | Corrected AC Waveforms Added Extended Temperature Options                                                                                                                                                       |
| 009    | Added 28F010-65 and 28F010-90 speeds<br>Revised Symbols, i.e., $\overline{\text{CE}}$ , $\overline{\text{OE}}$ , etc. to $\text{CE\#}$ , $\text{OE\#}$ , etc.                                                   |



# 28F512 512K (64K x 8) CMOS FLASH MEMORY

- Flash Electrical Chip-Erase— 1 Second Typical Chip-Erase
- Quick-Pulse Programming Algorithm
   10 µs Typical Byte-Program
  - 1 Second Chip-Program
- 100,000 Erase/Program Cycles
- 12.0V ±5% Vpp
- High-Performance Read
   120 ns Maximum Access Time
- **CMOS Low Power Consumption** 
  - 10 mA Typical Active Current
  - 50 μA Typical Standby Current
  - 0W Data Retention Power
- Integrated Program/Erase Stop Timers

- Command Register Architecture for Microprocessor/Microcontroller Compatible Write Interface
- Noise Immunity Features
  - ± 10% V<sub>CC</sub> Tolerance
  - Maximum Latch-Up Immunity through EPI Processing
- **ETOX II Nonvolatile Flash Technology** 
  - EPROM-Compatible Process Base
  - High-Volume Manufacturing Experience
- **JEDEC-Standard Pinouts** 
  - 32-Pin Plastic Dip
  - 32-Lead PLCC

(See Packaging Spec., Order #231369)

Extended Temperature Options

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

The 28F512 is a 512-kilobit nonvolatile memory organized as 65,536 bytes of 8 bits. Intel's 28F512 is offered in 32-pin plastic dip or 32-lead PLCC packages. Pin assignments conform to JEDEC standards for byte-wide EPROMs.

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

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

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





Figure 1. 28F512 Block Diagram





Figure 2. 28F512 Pin Configurations

**Table 1. Pin Description** 

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



#### APPLICATIONS

The 28F512 flash memory provides nonvolatility along with the capability to perform over 100,000 electrical chip-erasure/reprogram cycles. These features make the 28F512 an innovative alternative to disk, EEPROM, and battery-backed static RAM. Where periodic updates of code and data-tables are required, the 28F512's reprogrammability and nonvolatility make it the obvious and ideal replacement for EPROM.

Primary applications and operating systems stored in flash eliminate the slow disk-to-DRAM download process. This results in dramatic enhancement of performance and substantial reduction of power consumption — a consideration particularly important in portable equipment. Flash memory increases flexibility with electrical chip erasure and in-system update capability of operating systems and application code. With updatable BIOS, system manufacturers can easily accommodate last-minute changes as revisions are made.

In diskless workstations and terminals, network traffic reduces to a minimum and systems are instanton. Reliability exceeds that of electromechanical media. Often in these environments, power interruptions force extended re-boot periods for all networked terminals. This mishap is no longer an issue if boot code, operating systems, communication protocols and primary applications are flash-resident in each terminal.

For embedded systems that rely on dynamic RAM/ disk for main system memory or nonvolatile backup storage, the 28F512 flash memory offers a solid state alternative in a minimal form factor. The 28F512 provides higher performance, lower power consumption, instant-on capability, and allows an "execute in place" memory hierarchy for code and data table reading. Additionally, the flash memory is more rugged and reliable in harsh environments where extreme temperatures and shock can cause disk-based systems to fail.

The need for code updates pervades all phases of a system's life — from prototyping to system manufacture to after-sale service. The electrical chip-erasure and reprogramming ability of the 28F512 allows in-

circuit alterability; this eliminates unnecessary handling and less-reliable socketed connections, while adding greater test, manufacture, and update flexibility.

Material and labor costs associated with code changes increases at higher levels of system integration — the most costly being code updates after sale. Code "bugs", or the desire to augment system functionality, prompt after-sale code updates. Field revisions to EPROM-based code requires the removal of EPROM components or entire boards. With the 28F512, code updates are implemented locally via an edge-connector, or remotely over a communcation link.

For systems currently using a high-density static RAM/battery configuration for data accumulation, flash memory's inherent nonvolatility eliminates the need for battery backup. The concern for battery failure no longer exists, an important consideration for portable equipment and medical instruments, both requiring continuous performance. In addition, flash memory offers a considerable cost advantage over static RAM.

Flash memory's electrical chip erasure, byte programmability and complete nonvolatility fit well with data accumulation and recording needs. Electrical chip-erasure gives the designer a "blank slate" in which to log or record data. Data can be periodically off-loaded for analysis and the flash memory erased producing a new "blank slate".

A high degree of on-chip feature integration simplifies memory-to-processor interfacing. Figure 3 depicts two 28F512s tied to the 80C186 system bus. The 28F512's architecture minimizes interface circuitry needed for complete in-circuit updates of memory contents.

With cost-effective in-system reprogramming, extended cycling capability, and true nonvolatility, the 28F512 offers advantages to the alternatives: EPROMs, EEPROMs, battery backed static RAM, or disk. EPROM-compatible read specifications, straight-forward interfacing, and in-circuit alterability offers designers unlimited flexibility to meet the high standards of today's designs.





Figure 3, 28F512 in a 80C186 System

#### PRINCIPLES OF OPERATION

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

In the absence of high voltage on the  $V_{PP}$  pin, the 28F512 is a read-only memory. Manipulation of the external memory-control pins yields the standard EPROM read, standby, output disable, and Intelligent Identifier operations.

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

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

standard microprocessor read timings output array data, access the Intelligent Identifier codes, or output data for erase and program verification.

## **Integrated Stop Timer**

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

#### Write Protection

The command register is only active when  $V_{PP}$  is at high voltage. Depending upon the application, the system designer may choose to make the  $V_{PP}$  power supply switchable—available only when memory updates are desired. When  $V_{PP} = V_{PPL}$ , the contents of the register default to the read command, making the 28F512 a read-only memory. In this mode, the memory contents cannot be altered.



Table 2. 28F512 Bus Operations

|            | Pins                               | V <sub>PP</sub> (1) | Ao              | Ag                  | CE#             | OE#             | WE#             | DQ <sub>0</sub> -DQ <sub>7</sub> |
|------------|------------------------------------|---------------------|-----------------|---------------------|-----------------|-----------------|-----------------|----------------------------------|
| Operation  |                                    | · PP·               | 7.0             | 7.9                 | <b>J</b>        | <b>01</b> "     |                 | J 40 J 47                        |
|            | Read                               | V <sub>PPL</sub>    | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub> | VIL             | V <sub>IH</sub> | Data Out                         |
|            | Output Disable                     | $V_{PPL}$           | Х               | Х                   | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Tri-State                        |
| READ-ONLY  | Standby                            | V <sub>PPL</sub>    | Х               | Х                   | V <sub>IH</sub> | Х               | X               | Tri-State                        |
|            | Intelligent Identifier (Mfr)(2)    | V <sub>PPL</sub>    | VIL             | V <sub>ID</sub> (3) | VIL             | V <sub>IL</sub> | V <sub>IH</sub> | Data = 89H                       |
|            | Intelligent Identifier (Device)(2) | V <sub>PPL</sub>    | V <sub>IH</sub> | V <sub>ID</sub> (3) | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data = B8H                       |
|            | Read                               | V <sub>PPH</sub>    | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data Out(4)                      |
| READ/WRITE | Output Disable                     | V <sub>PPH</sub>    | Х               | Х                   | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Tri-State                        |
|            | Standby <sup>(5)</sup>             | V <sub>PPH</sub>    | Х               | Х                   | V <sub>IH</sub> | Х               | Х               | Tri-State                        |
|            | Write                              | V <sub>PPH</sub>    | A <sub>0</sub>  | A <sub>9</sub>      | VIL             | V <sub>IH</sub> | V <sub>IL</sub> | Data In(6)                       |

#### **NOTES:**

- 1. Refer to DC Characteristics. When V<sub>PP</sub> = V<sub>PPL</sub> memory contents can be read but not written or erased.
- 2. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 3. All other addresses low.
- 3. V<sub>ID</sub> is the Intelligent Identifier high voltage. Refer to DC Characteristics.
- Read operations with V<sub>PP</sub> = V<sub>PPH</sub> may access array data or the Intelligent Identifier codes.
- 5. With Vpp at high voltage, the standby current equals I<sub>CC</sub> + I<sub>pp</sub> (standby).
- 6. Refer to Table 3 for valid Data-In during a write operation.
- 7. X can be VIL or VIH.

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

The two-step program/erase write sequence to the Command Register provides additional software write protection.

#### **BUS OPERATIONS**

#### Read

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

When V<sub>PP</sub> is high (V<sub>PPH</sub>), the read operation can be used to access array data, to output the Intelligent Identifier codes, and to access data for program/erase verification. When V<sub>PP</sub> is low (V<sub>PPL</sub>), the read operation can **only** access the array data.

#### **Output Disable**

With Output-Enable at a logic-high level ( $V_{IH}$ ), output from the device is disabled. Output pins are placed in a high-impedance state.

#### Standby

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

#### Intelligent Identifier Operation

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



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

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

#### Write

Device erasure and programming are accomplished via the command register, when high voltage is applied to the V<sub>PP</sub> pin. The contents of the register serve as input to the internal state-machine. The state-machine outputs dictate the function of the device.

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

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

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

#### **COMMAND DEFINITIONS**

When low voltage is applied to the  $V_{PP}$  pin, the contents of the command register default to 00H, enabling read-only operations.

Placing high voltage on the V<sub>PP</sub> pin enables read/write operations. Device operations are selected by writing specific data patterns into the command register. Table 3 defines these 28F512 register commands.

**Table 3. Command Definitions** 

|                                                 | ı a           | Die 3. Commi             | and Demnik | J113    |                          |            |         |  |
|-------------------------------------------------|---------------|--------------------------|------------|---------|--------------------------|------------|---------|--|
| Command                                         | Bus<br>Cycles | First                    | Bus Cycle  |         | Second Bus Cycle         |            |         |  |
|                                                 | Req'd         | Operation <sup>(1)</sup> | Address(2) | Data(3) | Operation <sup>(1)</sup> | Address(2) | Data(3) |  |
| Read Memory                                     | 1             | Write                    | . X        | 00H     |                          |            |         |  |
| Read Intelligent Identifier Code <sup>(4)</sup> | 3             | Write                    | Х          | 90H     | Read                     | (4)        | (4)     |  |
| Set-up Erase/Erase(5)                           | 2             | Write                    | Х          | 20H     | Write                    | , X        | 20H     |  |
| Erase Verify <sup>(5)</sup>                     | 2             | Write                    | EA         | A0H     | Read                     | Х          | EVD     |  |
| Set-up Program/Program(6)                       | 2             | Write                    | Х          | 40H     | Write                    | PA         | PD      |  |
| Program Verify <sup>(6)</sup>                   | 2             | Write                    | . X        | COH     | Read                     | Х          | PVD     |  |
| Reset <sup>(7)</sup>                            | 2             | Write                    | Х          | FFH     | Write                    | Х          | FFH     |  |

#### **NOTES:**

- 1. Bus operations are defined in Table 2.
- 2. IA = Identifier address: 00H for manufacturer code, 01H for device code.
  - EA = Address of memory location to be read during erase verify.
  - PA = Address of memory location to be programmed.
  - Addresses are latched on the falling edge of the Write-Enable pulse.
- 3. ID = Data read from location IA during device identification (Mfr = 89H, Device = B8H).
  - EVD = Data read from location EA during erase verify.
  - PD = Data to be programmed at location PA. Data is latched on the rising edge of Write-Enable.
  - PVD = Data read from location PA during program verify. PA is latched on the Program command.
- 4. Following the Read Intelligent ID command, two read operations access manufacturer and device codes.
- 5. Figure 5 illustrates the Quick-Erase algorithm.
- 6. Figure 4 illustrates the Quick-Pulse Programming algorithm.
- 7. The second bus cycle must be followed by the desired command register write.



#### Read Command

While V<sub>PP</sub> is high, for erasure and programming, memory contents can be accessed via the read command. The read operation is initiated by writing 00H into the command register. Microprocessor read cycles retrieve array data. The device remains enabled for reads until the command register contents are altered.

The default contents of the register upon V<sub>PP</sub> power-up is 00H. This default value ensures that no spurious alteration of memory contents occurs during the V<sub>PP</sub> power transition. Where the V<sub>PP</sub> supply is hard-wired to the 28F512, the device powers-up and remains enabled for reads until the command-register contents are changed. Refer to the AC Read Characteristics and Waveforms for specific timing parameters.

#### Intelligent Identifier Command

Flash-memories are intended for use in applications where the local CPU alters memory contents. As such, manufacturer- and device-codes must be accessible while the device resides in the target system. PROM programmers typically access signature codes by raising A9 to a high voltage. However, multiplexing high voltage onto address lines is not a desired system-design practice.

The 28F512 contains an Intelligent Identifier operation to supplement traditional PROM-programming methodology. The operation is initiated by writing 90H into the command register. Following the command write, a read cycle from address 0000H retrieves the manufacturer code of 89H. A read cycle from address 0001H returns the device code of B8H. To terminate the operation, it is necessary to write another valid command into the register.

#### Set-up Erase/Erase Commands

Set-up Erase is a command-only operation that stages the device for electrical erasure of all bytes in the array. The set-up erase operation is performed by writing 20H to the command register.

To commence chip-erasure, the erase command (20H) must again be written to the register. The erase operation begins with the rising edge of the Write-Enable pulse and terminates with the rising edge of the next Write-Enable pulse (i.e., Erase-Verify Command).

This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, chip-erasure can only occur when high voltage is applied to the  $V_{PP}$  pin. In the absence

of this high voltage, memory contents are protected against erasure. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

#### **Erase-Verify Command**

The erase command erases all bytes of the array in parallel. After each erase operation, all bytes must be verified. The erase verify operation is initiated by writing A0H into the command register. The address for the byte to be verified must be supplied as it is latched on the falling edge of the Write-Enable pulse. The register write terminates the erase operation with the rising edge of its Write-Enable pulse.

The 28F512 applies an internally-generated margin voltage to the addressed byte. Reading FFH from the addressed byte indicates that all bits in the byte are erased.

The erase-verify command must be written to the command register prior to each byte verification to latch its address. The process continues for each byte in the array until a byte does not return FFH data, or the last address is accessed.

In the case where the data read is not FFH, another erase operation is performed. (Refer to Set-up Erase/Erase). Verification then resumes from the address of the last-verified byte. Once all bytes in the array have been verified, the erase step is complete. The device can be programmed. At this point, the verify operation is terminated by writing a valid command (e.g. Program Set-up) to the command register. Figure 5, the Quick-Erase algorithm, illustrates how commands and bus operations are combined to perform electrical erasure of the 28F512. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

#### Set-up Program/Program Commands

Set-up program is a command-only operation that stages the device for byte programming. Writing 40H into the command register performs the set-up operation.

Once the program set-up operation is performed, the next Write-Enable pulse causes a transition to an active programming operation. Addresses are internally latched on the falling edge of the Write-Enable pulse. Data is internally latched on the rising edge of the Write-Enable pulse. The rising edge of Write-Enable pulse. The rising edge of Write-Enable also begins the programming operation. The programming operation terminates with the next rising edge of Write-Enable, used to write the program-verify command. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.



#### **Program-Verify Command**

The 28F512 is programmed on a byte-by-byte basis. Byte programming may occur sequentially or at random. Following each programming operation, the byte just programmed must be verified.

The program-verify operation is initiated by writing C0H into the command register. The register write terminates the programming operation with the rising edge of its Write-Enable pulse. The program-verify operation stages the device for verification of the byte last programmed. No new address information is latched.

The 28F512 applies an internally-generated margin voltage to the byte. A microprocessor read cycle outputs the data. A successful comparison between the programmed byte and true data means that the byte is successfully programmed. Programming then proceeds to the next desired byte location. Figure 4, the 28F512 Quick-Pulse Programming algorithm, illustrates how commands are combined with bus operations to perform byte programming. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.

#### **Reset Command**

A reset command is provided as a means to safely abort the erase- or program-command sequences. Following either set-up command (erase or program) with two consecutive writes of FFH will safely abort the operation. Memory contents will not be altered. A valid command must then be written to place the device in the desired state.

#### **EXTENDED ERASE/PROGRAM CYCLING**

EEPROM cycling failures have always concerned users. The high electrical field required by thin oxide EEPROMs for tunneling can literally tear apart the oxide at defect regions. To combat this, some suppliers have implemented redundancy schemes, reducing cycling failures to insignificant levels. However, redundancy requires that cell size be doubled—an expensive solution.

Intel has designed extended cycling capability into its ETOX II flash memory technology. Resulting improvements in cycling reliability come without increasing memory cell size or complexity. First, an advanced tunnel oxide increases the charge carrying ability ten-fold. Second, the oxide area per cell subjected to the tunneling electric field is one-tenth that of common EEPROMs, minimizing the probability of oxide defects in the region. Finally, the peak electric field during erasure is approximately 2 MV/cm lower than EEPROM. The lower electric field

greatly reduces oxide stress and the probability of failure—increasing time to wearout by a factor of 100,000,000.

The 28F512 is capable of 100,000 program/erase cycles. The device is programmed and erased using Intel's Quick-Pulse Programming and Quick-Erase algorithms. Intel's algorithmic approach uses a series of operations (pulses), along with byte verification, to completely and reliably erase and program the device.

For further information, see Reliability Report RR-60 (ETOX-II Reliability Data Summary).

#### QUICK-PULSE PROGRAMMING ALGORITHM

The Quick-Pulse Programming algorithm uses programming operations of 10  $\mu s$  duration. Each operation is followed by a byte verification to determine when the addressed byte has been successfully programmed. The algorithm allows for up to 25 programming operations per byte, although most bytes verify on the first or second operation. The entire sequence of programming and byte verification is performed with  $V_{PP}$  at high voltage. Figure 4 illustrates the Quick-Pulse Programming algorithm.

#### QUICK-ERASE ALGORITHM

Intel's Quick-Erase algorithm yields fast and reliable electrical erasure of memory contents. The algorithm employs a closed-loop flow, similar to the Quick-Pulse Programming algorithm, to simultaneously remove charge from all bits in the array.

Erasure begins with a read of memory contents. The 28F512 is erased when shipped from the factory. Reading FFH data from the device would immediately be followed by device programming.

For devices being erased and reprogrammed, uniform and reliable erasure is ensured by first programming all bits in the device to their charged state (Data = 00H). This is accomplished, using the Quick-Pulse Programming algorithm, in approximately one second.

Erase execution then continues with an initial erase operation. Erase verification (data = FFH) begins at address 0000H and continues through the array to the last address, or until data other than FFH is encountered. With each erase operation, an increasing number of bytes verify to the erased state. Erase efficiency may be improved by storing the address of the last byte verified in a register. Following the next erase operation, verification starts at that stored address location. Erasure typically occurs in one second. Figure 5 illustrates the Quick-Erase algorithm.





Figure 4. 28F512 Quick-Pulse Programming Algorithm





Figure 5. 28F512 Quick-Erase Algorithm

vice.

the register is written with the read command.



#### **DESIGN CONSIDERATIONS**

### **Two-Line Output Control**

Flash-memories are often used in larger memory arrays. Intel provides two read-control inputs to accommodate multiple memory connections. Two-line control provides for:

- a. the lowest possible memory power dissipation and,
- b. complete assurance that output bus contention will not occur.

To efficiently use these two control inputs, an address-decoder output should drive chip-enable, while the system's read signal controls all flash-memories and other parallel memories. This assures that only enabled memory devices have active outputs, while deselected devices maintain the low power standby condition.

## **Power Supply Decoupling**

Flash-memory power-switching characteristics require careful device decoupling. System designers are interested in three supply current (I<sub>CC</sub>) issues—standby, active, and transient current peaks produced by falling and rising edges of chip-enable. The capacitive and inductive loads on the device outputs determine the magnitudes of these peaks.

Two-line control and proper decoupling capacitor selection will suppress transient voltage peaks. Each device should have a 0.1  $\mu F$  ceramic capacitor connected between V<sub>CC</sub> and V<sub>SS</sub>, and between V<sub>PP</sub> and V<sub>SS</sub>.

Place the high-frequency, low-inherent-inductance capacitors as close as possible to the devices. Also, for every eight devices, a 4.7  $\mu\text{F}$  electrolytic capacitor should be placed at the array's power supply connection, between VCC and VSS. The bulk capacitor will overcome voltage slumps caused by printed-circuit-board trace inductance, and will supply charge to the smaller capacitors as needed.

# **VPP Trace on Printed Circuit Boards**

Programming flash-memories, while they reside in the target system, requires that the printed circuit board designer pay attention to the  $V_{PP}$  power supply trace. The  $V_{PP}$  pin supplies the memory cell current for programming. Use similar trace widths and layout considerations given the  $V_{CC}$  power bus. Adequate  $V_{PP}$  supply traces and decoupling will decrease  $V_{PP}$  voltage spikes and overshoots.

### **Power Up/Down Protection**

The 28F512 is designed to offer protection against accidental erasure or programming during power transitions. Upon power-up, the 28F512 is indifferent as to which power supply, Vpp or V<sub>CC</sub>, powers up first. Power supply sequencing is not required. Internal circuitry in the 28F512 ensures that the command register is reset to the read mode on power up.

A system designer must guard against active writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either to  $V_{IH}$  will inhibit writes. The control register architecture provides an added level of protection since alteration of memory contents only occurs after successful completion of the two-step command sequences.

## 28F512 Power Dissipation

When designing portable systems, designers must consider battery power consumption not only during device operation, but also for data retention during system idle time. Flash memory nonvolatility increases the usable battery life of your system because the 28F512 does not consume any power to retain code or data when the system is off. Table 4 illustrates the power dissipated when updating the 28F512.

Table 4. 28F512 Typical Update
Power Dissipation<sup>(4)</sup>

| Operation                        | Notes | Power Dissipation (Watt-Seconds) |  |  |  |  |  |  |  |
|----------------------------------|-------|----------------------------------|--|--|--|--|--|--|--|
| Array Program/<br>Program Verify | 1     | 0.085                            |  |  |  |  |  |  |  |
| Array Erase/<br>Erase Verify     | 2     | 0.092                            |  |  |  |  |  |  |  |
| One Complete Cycle               | 3     | 0.262                            |  |  |  |  |  |  |  |

#### NOTES:

1. Formula to calculate typical Program/Program Verify Power = [Vpp  $\times$  # Bytes x Typical # Prog Pulses (twHwH1  $\times$  Ipp2 Typical + twHgL  $\times$  Ipp4 Typical)] + [Vcc  $\times$  # Bytes  $\times$  Typical # Prog Pulses (twHwH1  $\times$  Icc2 Typical) + twHgL  $\times$  Icc4 Typical).

2. Formula to calculate typical Erase/Erase Verify Power = [Vpp(lpp3 Typical  $\times$  terase Typical + lpp5 Typical  $\times$  twhGL  $\times$  # Bytes)] + [Vcc(lcc3 Typical  $\times$  terase Typical + lcc5 Typical  $\times$  twhGL  $\times$  # Bytes)].

3. One Complete Cycle = Array Preprogram + Array Erase + Program.

4. "Typicals" are not guaranteed, but based on a limited number of samples from production lots.



## **ABSOLUTE MAXIMUM RATINGS\***

| Operating Temperature  During Read0°C to +70°C(1)  During Erase/Program0°C to +70°C(1)   |
|------------------------------------------------------------------------------------------|
| Operating Temperature  During Read40°C to +85°C(2)  During Erase/Program40°C to +85°C(2) |
| Temperature Under Bias 10°C to +80°C(1)                                                  |
| Temperature Under Bias50°C to +95°C(2)                                                   |
| Storage Temperature $\dots -65^{\circ}\text{C}$ to $+125^{\circ}\text{C}$                |
| Voltage on Any Pin with Respect to Ground2.0V to +7.0V(2)                                |
| Voltage on Pin A <sub>9</sub> with Respect to Ground $-2.0V$ to $+13.5V$ (2, 3)          |

| V <sub>PP</sub> Supply Voltage with<br>Respect to Ground |                                 |
|----------------------------------------------------------|---------------------------------|
| During Erase/Program – 2.0V                              | to + 14.0V(2, 3)                |
| V <sub>CC</sub> Supply Voltage with                      |                                 |
| Respect to Ground2                                       | $2.0V \text{ to } + 7.0V^{(2)}$ |
| Output Short Circuit Current                             | 100 mA(4)                       |

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

#### NOTES:

- 1. Operating temperature is for commercial product defined by this specification.
- 2. Operating temperature is for extended temperature product defined by this specification.
- 3. Minimum DC input voltage is -0.5V. During transitions, inputs may undershoot to -2.0V for periods less than 20 ns. Maximum DC voltage on output pins is  $V_{CC} + 0.5$ V, which may overshoot to  $V_{CC} + 2.0$ V for periods less than 20 ns.
- 4. Maximum DC voltage on A<sub>9</sub> or V<sub>PP</sub> may overshoot to +14.0V for periods less than 20 ns.
- 5. Output shorted for no more than one second. No more than one output shorted at a time.

### **OPERATING CONDITIONS**

| Symbol          | Parameter Operating Temperature(1) | Lin  | nits | Unit | Comments                                                                        |  |  |
|-----------------|------------------------------------|------|------|------|---------------------------------------------------------------------------------|--|--|
|                 |                                    | Min  | Max  | )    | Johnnesta                                                                       |  |  |
| TA              |                                    | 0    | 70   | °C   | For Read-Only and<br>Read/Write Operations<br>for Commercial Products           |  |  |
| T <sub>A</sub>  | Operating Temperature(2)           | -40  | +85  | °C   | For Read-Only and<br>Read/Write Operations<br>for Extended Temperature Products |  |  |
| V <sub>CC</sub> | V <sub>CC</sub> Supply Voltage     | 4.50 | 5.50 | V    |                                                                                 |  |  |

## DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Commercial Products

| Cumbal           | Davamatav                                 | Notes | Limits |        |        |      | Took Conditions                                                                               |  |  |
|------------------|-------------------------------------------|-------|--------|--------|--------|------|-----------------------------------------------------------------------------------------------|--|--|
| Symbol           | Parameter                                 | Notes | Min    | Typ(4) | Max    | Unit | Test Conditions                                                                               |  |  |
| Ш                | Input Leakage Current                     | 1 -   |        |        | ±1.0   | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$                                          |  |  |
| l <sub>LO</sub>  | Output Leakage Current                    | 1     |        |        | ± 10.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or V_{SS}$                                         |  |  |
| Iccs             | V <sub>CC</sub> Standby Current           | 1     |        | 0.3    | 1.0    | mA   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = V <sub>IH</sub>                                |  |  |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current       | 1     |        | 10     | 30     | mA   | $V_{CC} = V_{CC} \text{ Max, CE} \# = V_{IL}$<br>$f = 6 \text{ MHz, } I_{OUT} = 0 \text{ mA}$ |  |  |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming<br>Current    | 1, 2  |        | 1.0    | 10     | mA   | Programming in Progress                                                                       |  |  |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current             | 1, 2  |        | 5.0    | 15     | mA   | Erasure in Progress                                                                           |  |  |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify<br>Current | 1, 2  |        | 5.0    | 15,    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress                              |  |  |



# DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Commercial Products (Continued)

| Cumbal           | Damanadan                                                       | N-A   |                | Limi | ts                    |                 | Total Constitutions                                              |  |
|------------------|-----------------------------------------------------------------|-------|----------------|------|-----------------------|-----------------|------------------------------------------------------------------|--|
| Symbol           | Parameter                                                       | Notes | Min Typ(4) Max | Max  | Unit                  | Test Conditions |                                                                  |  |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current                            | 1, 2  |                | 5.0  | 15                    | mA              | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress   |  |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                                 | 1     |                |      | ± 10.0                | μА              | $V_{PP} \leq V_{CC}$                                             |  |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, Standby<br>Current, or ID Current | 1     |                | 90   | 200                   | μΑ              | V <sub>PP</sub> > V <sub>CC</sub>                                |  |
|                  | 1                                                               |       |                |      | ± 10.0                |                 | $V_{PP} \leq V_{CC}$                                             |  |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current                             | 1, 2  |                | 8.0  | 30                    | mA              | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress    |  |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                                   | 1, 2  |                | 4.0  | 30                    | mA              | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress        |  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current                          | 1, 2  |                | 2.0  | 5.0                   | mA              | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress |  |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current                            | 1, 2  |                | 2.0  | 5.0                   | mA              | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress   |  |
| V <sub>IL</sub>  | Input Low Voltage                                               |       | -0.5           |      | 0.8                   | V               | ·                                                                |  |
| $V_{IH}$         | Input High Voltage                                              |       | 2.0            |      | V <sub>CC</sub> + 0.5 | ٧               |                                                                  |  |
| V <sub>OL</sub>  | Output Low Voltage                                              |       |                |      | 0.45                  | V               | $I_{OL} = 5.8 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$          |  |
| V <sub>OH1</sub> | Output High Voltage                                             |       | 2.4            |      |                       | ٧               | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$         |  |
| ·V <sub>ID</sub> | A <sub>9</sub> Intelligent Identifier Voltage                   |       | 11.50          |      | 13.00                 | ٧               |                                                                  |  |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current                   | 1, 2  |                | 90   | 200                   | μΑ              | $A_9 = V_{ID}$                                                   |  |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations                  |       | 0.00           |      | 6.5                   | ٧               | NOTE: Erase/Program are Inhibited when Vpp = VppL                |  |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations                 |       | 11.40          |      | 12.60                 | ٧               | ·                                                                |  |
| $V_{LKO}$        | V <sub>CC</sub> Erase/Write Lock Voltage                        |       | 2.5            |      |                       | ٧               |                                                                  |  |

# DC CHARACTERISTICS—CMOS COMPATIBLE—Commercial Products

| Cumbal           | Parameter                           |       |     | Limits | 3     |      | Test Conditions                                                     |
|------------------|-------------------------------------|-------|-----|--------|-------|------|---------------------------------------------------------------------|
| Symbol           | Parameter                           | Notes | Min | Typ(4) | Max   | Unit | rest Conditions                                                     |
| ILI              | Input Leakage Current               | . 1   |     | -      | ±1.0  | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$                |
| I <sub>LO</sub>  | Output Leakage Current              | 1     |     |        | ±10.0 | μΑ   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or V_{SS}$               |
| Iccs             | V <sub>CC</sub> Standby Current     | 1     |     | 50     | 100   | μΑ   | $V_{CC} = V_{CC} Max$ $CE \# = V_{CC} \pm 0.2V$                     |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current | 1     |     | 10     | 30    | mA   | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$ |



# DC CHARACTERISTICS—CMOS COMPATIBLE—Commercial Products (Continued)

| Symbol           | Parameter                                        | Notes |                       | Limits |                       | Unit | Tost Conditions                                                                 |  |
|------------------|--------------------------------------------------|-------|-----------------------|--------|-----------------------|------|---------------------------------------------------------------------------------|--|
| Symbol           | Parameter                                        | Notes | Min                   | Typ(4) | Max                   | Unit | Test Conditions                                                                 |  |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming<br>Current           | 1, 2  |                       | 1.0    | 10                    | mA   | Programming in Progress                                                         |  |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                    | 1, 2  |                       | 5.0    | 15                    | mA   | Erasure in Progress                                                             |  |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify<br>Current        | 1, 2  |                       | 5.0    | 15                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress                |  |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current             | 1, 2  |                       | 5.0    | 15                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress                  |  |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                  | 1     |                       |        | ± 10.0                | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                               |  |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, ID                 | 1     |                       | 90     | 200                   | μΑ   | V <sub>PP</sub> > V <sub>CC</sub>                                               |  |
|                  | Current, or Standby<br>Current                   | `     |                       |        | ±10.0                 |      | V <sub>PP</sub> ≤ V <sub>CC</sub>                                               |  |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming<br>Current           | 1, 2  |                       | 8.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress                   |  |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                    | 1, 2  |                       | 4.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress                       |  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify<br>Current        | 1, 2  |                       | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress                |  |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current             | 1, 2  |                       | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress                  |  |
| V <sub>IL</sub>  | Input Low Voltage                                |       | -0.5                  |        | 0.8                   | ٧    | ,                                                                               |  |
| V <sub>IH</sub>  | Input High Voltage                               |       | 0.7 V <sub>CC</sub>   |        | V <sub>CC</sub> + 0.5 | V    |                                                                                 |  |
| V <sub>OL</sub>  | Output Low Voltage                               |       |                       |        | 0.45                  | ٧    | $I_{OL} = 5.8 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                         |  |
| V <sub>OH1</sub> | Output High Voltage                              |       | 0.85 V <sub>CC</sub>  |        |                       | ٧    | $I_{OH} = -2.5 \text{ mA},$ $V_{CC} = V_{CC} \text{ Min}$                       |  |
| V <sub>OH2</sub> |                                                  |       | V <sub>CC</sub> - 0.4 |        |                       |      | $I_{OH} = -100 \mu A,$ $V_{CC} = V_{CC} Min$                                    |  |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Voltage |       | 11.50                 |        | 13.00                 | ٧    | $A_9 = V_{ID}$                                                                  |  |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |                       | 90     | 200                   | μА   | $A_9 = V_{ID}$                                                                  |  |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations   |       | 0.00                  |        | 6.5                   | ٧    | NOTE: Erase/Program<br>are Inhibited when<br>V <sub>PP</sub> = V <sub>PPL</sub> |  |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations  |       | 11.40                 |        | 12.60                 | ٧    |                                                                                 |  |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock<br>Voltage      |       | 2.5                   |        | `.                    | ٧    |                                                                                 |  |



# DC CHARACTERISTICS—TTL/NMOS COMPATIBLE—Extended Temperature Products

| Ob.ol            | Davis                                           | Limits |       | its    | Unit                  | Total Conditions |                                                                     |
|------------------|-------------------------------------------------|--------|-------|--------|-----------------------|------------------|---------------------------------------------------------------------|
| Symbol           | Parameter                                       | Notes  | Min   | Typ(4) | Max                   | Unit             | Test Conditions                                                     |
| ILI.             | Input Leakage Current                           | 1      |       |        | ±1.0                  | μΑ               | $V_{CC} = V_{CC} Max$<br>$V_{IN} = V_{CC} or V_{SS}$                |
| lLO              | Output Leakage Current                          | 1      |       |        | ±10.0                 | μΑ               | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or V_{SS}$               |
| lccs             | V <sub>CC</sub> Standby Current                 | 1      | ı     | 0.3    | 1.0                   | mA               | V <sub>CC</sub> = V <sub>CC</sub> Max<br>CE# = V <sub>IH</sub>      |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current             | 1      |       | . 10   | 30                    | mA               | $V_{CC} = V_{CC} Max, CE # = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$ |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current             | 1, 2   |       | 1.0    | 30                    | mA               | Programming in Progress                                             |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                   | 1, 2   |       | 5.0    | 30                    | mΑ               | Erasure in Progress                                                 |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current          | 1, 2   |       | 5.0    | 30                    | mA               | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress    |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current            | 1, 2   |       | 5.0    | 30                    | mA               | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress      |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                 | 1      |       |        | ± 10.0                | μΑ               | $V_{PP} \leq V_{CC}$                                                |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, Standby           | 1      |       | 90     | 200                   | μΑ               | $V_{PP} > V_{CC}$                                                   |
|                  | Current, or ID Current                          |        |       |        | ± 10.0                |                  | $V_{PP} \leq V_{CC}$                                                |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current             | 1, 2   |       | 8.0    | 30                    | mA               | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress       |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                   | 1, 2   |       | 4.0    | 30                    | mA               | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress           |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current          | 1, 2   |       | 2.0    | 5.0                   | mA               | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress    |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current            | 1, 2   |       | 2.0    | 5.0                   | mA               | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress      |
| $V_{IL}$         | Input Low Voltage                               |        | -0.5  |        | 0.8                   | ٧                | •                                                                   |
| V <sub>IH</sub>  | Input High Voltage                              |        | 2.0   |        | V <sub>CC</sub> + 0.5 | ٧                |                                                                     |
| V <sub>OL</sub>  | Output Low Voltage                              |        |       |        | 0.45                  | ٧                | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$          |
| V <sub>OH1</sub> | Output High Voltage                             |        | 2.4   | ,      |                       | ٧                | $I_{OH} = -2.5 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ Min}$         |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Voltage   |        | 11.50 |        | 13.00                 | ٧                |                                                                     |
| I <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current   | 1, 2   |       | 90     | 500                   | μΑ               | $A_9 = V_{ID}$                                                      |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations  |        | 0.00  |        | 6.5                   | ٧                | <b>NOTE:</b> Erase/Program are Inhibited when $V_{PP} = V_{PPL}$    |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations |        | 11.40 |        | 12.60                 | ٧                |                                                                     |
| $V_{LKO}$        | V <sub>CC</sub> Erase/Write Lock Voltage        |        | 2.5   |        |                       | ٧                | (                                                                   |



# DC CHARACTERISTICS—CMOS COMPATIBLE—Extended Temperature Products

| Symbol Parameter |                                           | Natas |                     | Limits | ,                     |      |                                                                                               |  |
|------------------|-------------------------------------------|-------|---------------------|--------|-----------------------|------|-----------------------------------------------------------------------------------------------|--|
| Symbol           | Parameter                                 | Notes | Min                 | Typ(4) | Max                   | Unit | Test Conditions                                                                               |  |
| lu               | Input Leakage Current                     | 1     |                     |        | ±1.0                  | μА   | V <sub>CC</sub> = V <sub>CC</sub> Max<br>V <sub>IN</sub> = V <sub>CC</sub> or V <sub>SS</sub> |  |
| ILO              | Output Leakage Current                    | 1     |                     |        | ± 10.0                | μА   | $V_{CC} = V_{CC} Max$<br>$V_{OUT} = V_{CC} or V_{SS}$                                         |  |
| Iccs             | V <sub>CC</sub> Standby Current           | 1     |                     | 50     | 100                   | μА   | $V_{CC} = V_{CC} Max$ $CE \# = V_{CC} \pm 0.2V$                                               |  |
| I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current       | 1     |                     | 10     | 50                    | mA   | $V_{CC} = V_{CC} Max, CE\# = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0 mA$                           |  |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current       | 1, 2  |                     | 1.0    | 10                    | mA   | Programming in Progress                                                                       |  |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current             | 1, 2  |                     | 5.0    | 15                    | mA   | Erasure in Progress                                                                           |  |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify<br>Current | 1, 2  |                     | 5.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress                              |  |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current      | 1, 2  |                     | 5.0    | 30                    | mA   | $V_{PP} = V_{PPH}$<br>Erase Verify in Progress                                                |  |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current           | 1     | -                   |        | ± 10.0                | μΑ   | $V_{PP} \leq V_{CC}$                                                                          |  |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, ID          | 1     |                     | 90     | 200                   | μΑ   | $V_{PP} > V_{CC}$                                                                             |  |
| `                | Current, or Standby<br>Current            |       |                     |        | ± 10.0                |      | $V_{PP} \leq V_{CC}$                                                                          |  |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current       | 1, 2  |                     | 8.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress                                 |  |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current             | 1, 2  |                     | 4.0    | 30                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress                                     |  |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify<br>Current | 1, 2  |                     | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress                              |  |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current      | 1, 2  |                     | 2.0    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress                                |  |
| $V_{IL}$         | Input Low Voltage                         |       | -0.5                |        | 0.8                   | ٧    |                                                                                               |  |
| V <sub>IH</sub>  | Input High Voltage                        |       | 0.7 V <sub>CC</sub> |        | V <sub>CC</sub> + 0.5 | V    |                                                                                               |  |
| V <sub>OL</sub>  | Output Low Voltage                        |       |                     |        | 0.45                  | ٧    | $I_{OL} = 5.8 \text{ mA}$ $V_{CC} = V_{CC} \text{ Min}$                                       |  |



# DC CHARACTERISTICS—CMOS COMPATIBLE—Extended Temperature Products (Continued)

| Symbol           | Parameter                                     | Notes | L                     | imits  | Unit  | Test Conditions |                                                                |  |
|------------------|-----------------------------------------------|-------|-----------------------|--------|-------|-----------------|----------------------------------------------------------------|--|
| Syllibol         | Parameter                                     | Notes | Min                   | Typ(4) | Max   | Offic           | rest Conditions                                                |  |
| V <sub>OH1</sub> | Output High Voltage                           |       | 0.85 V <sub>CC</sub>  |        |       | ٧               | $I_{OH} = -2.5 \text{ mA},$ $V_{CC} = V_{CC} \text{ Min}$      |  |
| V <sub>OH2</sub> |                                               |       | V <sub>CC</sub> - 0.4 |        |       |                 | $I_{OH} = -100 \mu A,$ $V_{CC} = V_{CC} Min$                   |  |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Voltage |       | 11.50                 |        | 13.00 | ٧               | $A_9 = V_{ID}$                                                 |  |
| l <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier Current | 1, 2  |                       | 90     | 500   | μΑ              | $A_9 = V_{ID}$                                                 |  |
| V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only Operations   |       | 0.00                  |        | 6.5   | V               | NOTE: Erase/<br>Program<br>are Inhibited<br>when<br>Vpp = VppL |  |
| V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write Operations  |       | 11.40                 |        | 12.60 | ٧               |                                                                |  |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage      |       | 2.5                   |        |       | V               |                                                                |  |

## CAPACITANCE $T_A = 25$ °C, f = 1.0 MHz

| Symbol           | Parameter                   | Notes | Lir | nits | Unit  | Conditions            |  |
|------------------|-----------------------------|-------|-----|------|-------|-----------------------|--|
| Symbol           | Parameter                   | Motes | Min | Max  | Oilit | Conditions            |  |
| C <sub>IN</sub>  | Address/Control Capacitance | 3     |     | 8    | pF    | $V_{IN} = 0V$         |  |
| C <sub>OUT</sub> | Output Capacitance          | 3     |     | 12   | pF    | V <sub>OUT</sub> = 0V |  |

#### NOTES

- 1. All currents are in RMS unless otherwise noted. Typical values at  $V_{CC} = 5.0V$ ,  $V_{PP} = 12.0V$ ,  $T = +25^{\circ}C$ . These currents are valid for all product versions (packages and speeds).
- 2. Not 100% tested: characterization data available.
- 3. Sampled, not 100% tested.
- 4. "Typicals" are not guaranteed, but based on a limited number of samples from production lots.



### AC TESTING INPUT/OUTPUT WAVEFORM



### AC TESTING LOAD CIRCUIT



### **AC TEST CONDITIONS**

Input Rise and Fall Times (10% to 90%) ......10 ns Input Pulse Levels .................0.45V and 2.4V Input Timing Reference Level .......0.8V and 2.0V Output Timing Reference Level ...........0.8V and 2.0V

### AC CHARACTERISTICS—Read-Only Operations

| Versions <sup>(1)</sup>             |                                              | ns(1) Notes |     | 512-120<br>512-120<br>512-120<br>512-120 | N28F512-150<br>P28F512-150 |     | Unit |
|-------------------------------------|----------------------------------------------|-------------|-----|------------------------------------------|----------------------------|-----|------|
| Symbol                              | Characteristic                               |             | Min | Max                                      | Min                        | Max | 1    |
| t <sub>AVAV</sub> /t <sub>RC</sub>  | Read Cycle Time                              |             | 120 |                                          | 150                        |     | ns   |
| t <sub>ELQV</sub> /t <sub>CE</sub>  | Chip Enable Access Time                      |             |     | 120                                      |                            | 150 | ns   |
| t <sub>AVQV</sub> /t <sub>ACC</sub> | Address Access Time                          |             |     | 120                                      | Ì                          | 150 | ns   |
| t <sub>GLQV</sub> /t <sub>OE</sub>  | Output Enable Access Time                    |             |     | 50                                       |                            | 55  | ns   |
| t <sub>ELQX</sub> /t <sub>LZ</sub>  | Chip Enable to Output in Low Z               | 2, 3        | 0   |                                          | 0                          |     | ns   |
| t <sub>EHQZ</sub>                   | Chip Disable to Output in High Z             | 2           |     | 55                                       |                            | 55  | ns   |
| t <sub>GLQX</sub> /t <sub>OLZ</sub> | Output Enable to Output in Low Z             | 2, 3        | 0   | •                                        | . 0                        |     | ns   |
| t <sub>GHQZ</sub> /t <sub>DF</sub>  | Output Disable to Output in High Z           | 2           | ,   | 30                                       |                            | 35  | ns   |
| tон                                 | Output Hold from Address, CE#, or OE# Change | 2, 4        | 0   |                                          | 0                          |     | ns   |
| twhGL                               | Write Recovery Time before Read              |             | 6   |                                          | 6                          |     | μs   |

- 1. Model number prefixes: N = PLCC, P = PDIP, T = Extended Temperature.
- 2. Sampled, not 100% tested.
- 3. Guaranteed by design.
- 4. Whichever occurs first.

5-83





# AC CHARACTERISTICS—Write/Erase/Program Operations(1, 4)

| Versions                           |                                                | Nata  | 28F5 | 12-120 | 28F5 | 11-14 |      |
|------------------------------------|------------------------------------------------|-------|------|--------|------|-------|------|
| Symbol                             | Characteristic                                 | Notes | Min  | Max    | Min  | Max   | Unit |
| t <sub>AVAV</sub> /t <sub>WC</sub> | Write Cycle Time                               |       | 120  |        | 150  |       | ns   |
| tAVWL/tAS                          | Address Set-Up Time                            |       | . 0  |        | 0    |       | ns   |
| t <sub>WLAX</sub> /t <sub>AH</sub> | Address Hold Time                              |       | 60   |        | 60   |       | ns   |
| t <sub>DVWH</sub> /t <sub>DS</sub> | Data Set-up Time                               |       | - 50 |        | 50   |       | ns   |
| t <sub>WHDX</sub> /t <sub>DH</sub> | Data Hold Time                                 |       | 10   |        | 10   |       | ns   |
| twHGL                              | Write Recovery Time before Read                |       | 6    |        | 6    |       | μs   |
| tGHWL                              | Read Recovery Time before Write                | 2     | 0    |        | 0    |       | μs   |
| t <sub>ELWL</sub> /t <sub>CS</sub> | Chip Enable Set-Up Time before Write           |       | 20   |        | 20   |       | ns   |
| twhen/tch                          | Chip Enable Hold Time                          |       | , 0  |        | 0    |       | ns   |
| t <sub>WLWH</sub> /t <sub>WP</sub> | Write Pulse Width                              |       | 60   |        | 60   |       | ns   |
| twhwL/twph                         | Write Pulse Width High                         |       | 20   |        | 20   |       | ns   |
| twHWH1                             | Duration of Programming Operation              | 3     | 10   |        | 10   | ,     | μs   |
| twhwh2                             | Duration of Erase Operation                    | 3     | 9.5  |        | 9.5  |       | ms   |
| t <sub>VPEL</sub>                  | V <sub>PP</sub> Set-Up Time to Chip Enable Low | 2     | 1.0  |        | 1.0  |       | μs   |

### NOTES:

- 1. Read timing characteristics during read/write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Guaranteed by design.
- 3. The integrated stop timer terminates the programming/erase operations, thereby eliminating the need for a maximum specification.
- 4. Erase/Program cycles on extended temperature products is 1,000 cycles.

### **ERASE AND PROGRAMMING PERFORMANCE**

|                      |         | Limits             |     |      |                                |     |      |      |
|----------------------|---------|--------------------|-----|------|--------------------------------|-----|------|------|
| Parameter            | Notes   | N/P28F512-120, 150 |     |      | TN/TP28F512-120 <sup>(6)</sup> |     |      | Unit |
|                      |         | Min                | Тур | Max  | Min                            | Тур | Max  |      |
| Chip Erase<br>Time   | 1, 3, 4 |                    | 1   | 10   |                                | 1   | 10   | Sec  |
| Chip Program<br>Time | 1, 2, 4 |                    | 1   | 6.25 |                                | 1   | 6.25 | Sec  |

- 1. "Typicals" are not guaranteed, but based on a limited number of samples from production lots. Data taken at 25°C, 12.0V  $V_{\rm PP}$  at 0 cycles.
- 2. Minimum byte programming time excluding system overhead is 16  $\mu s$  (10  $\mu s$  program + 6  $\mu s$  write recovery), while maximum is 400  $\mu s$ /byte (16  $\mu s \times 25$  loops allowed by algorithm). Max chip programming time is specified lower than the worst case allowed by the programming algorithm since most bytes program significantly faster than the worst case byte.
- 3. Excludes 00H Programming Prior to Erasure.
- 4. Excludes System-Level Overhead.
- 5. Refer to RR-60 "ETOX II Flash Memory Reliability Data Summary" for typical cycling data and failure rate calculations.
- 6. Extended temperature products





Figure 7. 28F512 Typical Program Time at 12V



Figure 8. 28F512 Typical Programming Capability





Figure 9. 28F512 Typical Erase Time at 12V



Figure 10. 28F512 Typical Erase Capability

290204-19



Figure 11. AC Waveforms for Programming Operations

TVPEL

12.0V V<sub>PP</sub>

 $V_{PPL}$ 



### **ALTERNATIVE CE#-CONTROLLED WRITES**

| Versions          |                                                      | Mada  | 28F5 | 12-120 | 28F51 | 2-150 |      |
|-------------------|------------------------------------------------------|-------|------|--------|-------|-------|------|
| Symbol            | Characteristic                                       | Notes | Min  | Max    | Min   | Max   | Unit |
| t <sub>AVAV</sub> | Write Cycle<br>Time                                  | :     | 120  |        | 150   |       | ns   |
| t <sub>AVEL</sub> | Address Set-<br>Up Time                              |       | 0    |        | 0     |       | ns   |
| t <sub>ELAX</sub> | Address Hold<br>Time                                 |       | 80   |        | 80    |       | ns   |
| t <sub>DVEH</sub> | Data Set-Up<br>Time                                  |       | 50   |        | 50    |       | ns   |
| t <sub>EHDX</sub> | Data Hold<br>Time                                    |       | 10   |        | 10    |       | ns   |
| t <sub>EHGL</sub> | Write<br>Recovery Time<br>before Read                |       | 6    |        | 6     |       | μs   |
| tGHEL             | Read<br>Recovery Time<br>before Write                | 2     | 0    |        | 0     |       | μs   |
| twlel             | Write Enable<br>Set-Up Time<br>before Chip<br>Enable |       | 0    |        | 0     |       | ns   |
| t <sub>EHWH</sub> | Write Enable<br>Hold Time                            |       | 0    |        | 0     |       | ns   |
| t <sub>ELEH</sub> | Write Pulse<br>Width                                 | - 1   | 70   |        | 70    |       | ns   |
| t <sub>EHEL</sub> | Write Pulse<br>Width High                            |       | 20   |        | 20    |       | ns   |
| t <sub>VPEL</sub> | V <sub>PP</sub> Set-Up<br>Time to Chip<br>Enable Low | 2     | 1.0  |        | 1.0   |       | μs   |

### NOTE:

2. Guaranteed by design.

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of Chip-Enable and Write-Enable. In systems where Chip-Enable defines the write pulse width (within a longer Write-Enable timing waveform) all set-up, hold and inactive Write-Enable times should be measured relative to the Chip-Enable waveform.

28F512









# **Ordering Information**



### Valid Combinations:

P28F512-120

N28F512-120

TP28F512-120

P28F512-150

N28F512-150

TN28F512-120

### ADDITIONAL INFORMATION

Order Number 294005

ER-20, "ETOX II Flash Memory Technology"
ER-24, "Intel Flash Memory"
RR-60, "ETOX II Flash Memory Reliability Data Summary"
AP-316, "Using Flash Memory for In-System Reprogrammable Nonvolatile Storage"

294008 293002 292046

AP-325 "Guide to Flash Memory Reprogramming"

292059

# **REVISION HISTORY**

| Number | Description                                                                                                                   |
|--------|-------------------------------------------------------------------------------------------------------------------------------|
| 006    | Removed 200 ns speed bin Revised Erase Maximum Pulse Count for Figure 5 from 3000 to 1000 Clarified AC and DC test conditions |
| 007    | Corrected AC Waveforms Added Extended Temperature devices; TP28F512-120, TN28F512-120                                         |
| 008    | Revised symbols; i.e., $\overline{CE}$ , $\overline{OE}$ , etc. to $CE\#$ , $OE\#$ , etc.                                     |



# 28F256A 256K (32K x 8) CMOS FLASH MEMORY

- Flash Electrical Chip-Erase
   1 Second Typical Chip-Erase
- Quick-Pulse Programming Algorithm
   10 µs Typical Byte-Program
  - 0.5 Second Chip-Program
- 100,000 Erase/Program Cycles
- 12.0V ±5% Vpp
- High-Performance Read— 120 ns Maximum Access Time
- **CMOS Low Power Consumption** 
  - 10 mA Typical Active Current
  - 50  $\mu$ A Typical Standby Current
  - 0W Data Retention Power
- Integrated Program/Erase Stop Timer

- Command Register Architecture for Microprocessor/Microcontroller Compatible Write Interface
- Noise Immunity Features
  - ± 10% V<sub>CC</sub> Tolerance
  - Maximum Latch-Up Immunity through EPI Processing
- **ETOX II Flash Nonvolatile Technology** 
  - EPROM-Compatible Process Base
  - High-Volume Manufacturing Experience
- JEDEC-Standard Pinouts
  - 32-Pin PDIP
  - 32-Lead PLCC

(See Packaging Spec., Order #231369)

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

The 28F256A is a 256-kilobit nonvolatile memory organized as 32,768 bytes of 8 bits. Intel's 28F256A is offered in 32-pin plastic dip and 32-lead PLCC. Pin assignments conform to JEDEC standards.

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

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

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





Figure 1. 28F256A Block Diagram



Figure 2. 28F256A Pin Configurations



**Table 1. Pin Description** 

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

### **APPLICATIONS**

The 28F256A flash memory provides nonvolatility along with the capability to perform over 100,000 electrical chip-erasure/reprogram cycles. These features make the 28F256A an innovative alternative to disk, EEPROM, and battery-backed static RAM. Where periodic updates of code and data-tables are required, the 28F256A's reprogrammability and nonvolatility make it the obvious and ideal replacement for EPROM.

Primary applications and operating systems stored in flash eliminate the slow disk-DRAM download process. This results in a dramatic enhancement of performance and substantial reduction of power consumption—considerations particularly important in portable equipment. Flash memory increases flexibility with electrical chip-erasure and in-system update capability of operating systems and application code. With updatable BIOS, system manufacturers can easily accommodate last-minute changes as revisions are made.

In diskless workstations and terminals, network traffic reduces to a minimum and systems become instant-on. Reliability exceeds that of electromechanical media. Often in these environments, power interrupts force extended re-boot periods for all networked terminals. This mishap is no longer an issue if boot code, operating systems, communications protocols and primary applications are flash-resident in each terminal.

For embedded systems that rely on dynamic RAM/ disk for main system memory or nonvolatile backup storage, the 28F256A provides higher performance, lower power consumption, instant-on capability, and allows an "execute in place" memory hierarchy for code and data table reading. Additionally, the flash memory is more rugged and reliable in harsh environments where extreme temperatures and shock can cause disk-based systems to fail.

The need for code updates pervades all phases of a system's life—from prototyping to system manufacturing to after-sale service. The electrical chip-erasure and reprogramming ability of the 28F256A allows in-circuit alterability; this eliminates unnecessary handling and less-reliable socketed connections, while adding greater test, manufacture, and update flexibility.

Material and labor costs associated with code changes increases at higher levels of system inte-



gration—the most costly being code updates after sale. Code "bugs", or the desire to augment system functionality, prompt after-sale code updates. Field revision to EPROM-based code requires the removal of EPROM components or entire boards. With the 28F256A, code updates are implemented locally via an edge-connector, or remotely over a communications link.

For systems currently using a high-density static RAM/battery configuration for data accumulation, flash memory's inherent nonvolatility eliminates the need for battery backup. The concern for battery failure no longer exists, an important consideration for portable equipment and medical instruments, both requiring continuous performance. In addition, flash memory offers a considerable cost advantage over static RAM.

Flash memory's electrical chip-erasure, byte programmability and complete nonvolatility fit well with data accumulation and recording needs. Electrical chip-erasure gives the designer a "blank slate" in which to log or record data. Data can be periodically off-loaded for analysis and the flash memory erased producing a new "blank slate".

A high degree of on-chip feature integration simplifies memory-to-processor interfacing. Figure 3 depicts two 28F256As tied to the 80C186 system bus. The 28F256A's architecture minimizes interface circuitry needed for complete in-circuit updates of memory contents.

With cost-effective in-system reprogramming, extended cycling capability, and true nonvolatility, the 28F256A is a functional superset of one or more of the alternatives: EPROMs, EEPROMs, battery backed static RAM, or disk. EPROM-compatible read specifications, straightforward interfacing, and in-circuit alterability offer designers unlimited flexibility to meet the high standards of today's designs.



Figure 3. 28F256As in a 80C186 System



### PRINCIPLES OF OPERATION

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

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

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

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

# Integrated Program/Erase Stop Timer

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

### Write Protection

The command register is only active when  $V_{PP}$  is at high voltage. Depending upon the application, the system designer may choose to make the  $V_{PP}$  power supply switchable—available only when memory updates are desired. When  $V_{PP} = V_{PPL}$ , the contents of the register default to the read command, making the 28F256A a read-only memory. In this mode, the memory contents cannot be altered.

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

The two-step program/erase write sequence to the Command Register provides additional software write protection.

### **BUS OPERATIONS**

### Read

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

When V<sub>PP</sub> is high (V<sub>PPH</sub>), the read operations can be used to access array data, to output the Intelligent Identifier codes, and to access data for program/erase verification. When V<sub>PP</sub> is low (V<sub>PPL</sub>), the read operation can access only the array data.

# **Output Disable**

With Output-Enable at a logic-high level ( $V_{IH}$ ), output from the device is disabled. Output pins are placed in a high-impedance state.

# Standby

With Chip-Enable at a logic-high level, the standby operation disables most of the 28F256A's circuitry and substantially reduces device power consumption. The outputs are placed in a high-impedance



state, independent of the Output-Enable signal. If the 28F256A is deselected during erasure, programming, or program/erase verification, the device draws active current until the operation is terminated.

### **Intelligent Identifier Operation**

The Intelligent Identifier operation outputs the manufacturer code (89H) and device code (B9H). Programming equipment automatically matches the device with its proper erase and programming algorithms. With Chip-Enable and Output-Enable at a logic low level, rising  $A_{\rm g}$  to high voltage  $V_{\rm ID}$  (see D.C. Characteristics) activates the operation. Data read from locations 0000H and 0001H represent the manufacturer's code and the device code, respectively.

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

### Write

Device erasure and programming are accomplished via the command register, when high voltage is ap-

plied to the V<sub>PP</sub> pin. The contents of the register serve as input to the internal state-machine. The state-machine outputs dictate the function of the device

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

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

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

### **COMMAND DEFINITIONS**

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

Placing high voltage on the V<sub>PP</sub> pin enables read/write operations. Device operations are selected by writing specific data patterns into the command register. Table 3 defines these 28F256A register commands.

Table 2, 28F256A Bus Operations

|                |                                |                     |                 | •                   |                 |                 |                 | ·                                |
|----------------|--------------------------------|---------------------|-----------------|---------------------|-----------------|-----------------|-----------------|----------------------------------|
|                | Pins                           | V <sub>PP</sub> (1) | Ao              | Ag                  | CE#             | OE#             | WE#             | DQ <sub>0</sub> -DQ <sub>7</sub> |
|                | Operation                      | V PP                | ~0              | Ag                  | OL "            | J - "           | W = "           | Day Day                          |
|                | Read                           | V <sub>PPL</sub>    | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data Out                         |
| READ-ONLY      | Output Disable                 | V <sub>PPL</sub>    | X(7)            | Х                   | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Tri-State                        |
| 2              | Standby                        | V <sub>PPL</sub>    | Х               | Х                   | V <sub>IH</sub> | · X             | Х               | Tri-State                        |
| ËĀ             | Intelligent ID Manufacturer(2) | V <sub>PPL</sub>    | VIL             | V <sub>ID</sub> (3) | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data = 89H                       |
| -              | Intelligent ID Device(2)       | V <sub>PPL</sub>    | V <sub>IH</sub> | V <sub>ID</sub> (3) | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data = B9H                       |
|                | Read                           | V <sub>PPH</sub>    | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data Out(4)                      |
| Òш             | Output Disable                 | V <sub>PPH</sub>    | Х               | X                   | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Tri-State                        |
| READ/<br>WRITE | Standby <sup>(5)</sup>         | V <sub>PPH</sub>    | Х               | Х                   | V <sub>IH</sub> | Х               | Х               | Tri-State                        |
| _ >            | Write                          | V <sub>PPH</sub>    | A <sub>0</sub>  | A <sub>9</sub>      | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Data In (6)                      |

- 1. Refer to DC Characteristics. When V<sub>PP</sub> = V<sub>PPL</sub> memory contents can be read but not written or erased.
- Manufacturer and device codes may also be accessed via a command register write sequence.Refer to Table 3. All other addresses low.
- 3. V<sub>ID</sub> is the Intelligent Identifier high voltage. Refer to D.C. Characteristics.
- 4. Read operations with V<sub>PP</sub> = V<sub>PPH</sub> may access array data or the Intelligent Identifier codes.
- 5. With VPP at high voltage, the standby current equals ICC + IPP (standby).
- 6. Refer to Table 3 for valid Data-In during a write operation.
- 7. X can be V<sub>IL</sub> or V<sub>IH</sub>.



**Table 3. Command Definitions** 

|                               | Bus First Bus Cycle |                          |                        | Second Bus Cycle    |                          |                        |                     |
|-------------------------------|---------------------|--------------------------|------------------------|---------------------|--------------------------|------------------------|---------------------|
| Command                       | Cycles<br>Req'd     | Operation <sup>(1)</sup> | Address <sup>(2)</sup> | Data <sup>(3)</sup> | Operation <sup>(1)</sup> | Address <sup>(2)</sup> | Data <sup>(3)</sup> |
| Read Memory                   | 1                   | Write                    | Х                      | 00H                 |                          |                        |                     |
| Read Intelligent ID Codes     | 3                   | Write                    | Х                      | 90H                 | Read                     | (4)                    | (4)                 |
| Set-Up Erase/Erase(6)         | 2                   | Write                    | Х                      | 20H                 | Write                    | Х                      | 20H                 |
| Erase Verify <sup>(6)</sup>   | 2                   | Write                    | EA                     | A0H                 | Read                     | Х                      | EVD                 |
| Set-Up Program/Program(5)     | 2                   | Write                    | Х                      | 40H                 | Write                    | PA                     | PD                  |
| Program Verify <sup>(5)</sup> | 2                   | Write                    | Х                      | C0H                 | Read                     | Х                      | PVD                 |
| Reset <sup>(7)</sup>          | 2                   | Write                    | Х                      | FFH                 | Write                    | Х                      | FFH                 |

### NOTES:

- 1. Bus operation are defined in Table 2.
- 2. IA = Identifier address: 00H for manufacturer code, 01H for device code.
  - EA = Address of memory location to be read during erase verify.
  - PA = Address of memory location to be programmed.
  - Addresses are latched on the falling edge of the Write-Enable pulse.
- 3. ID = Data read from location IA during device identification. (Mfr = 89H, Device = B9H).
  - EVD = Data read from location EA during erase verify.
  - PD = Data to be programmed at location PA. Data is latched on the rising edge of the Write-Enable. PVD = Data read from location PA during program verify. PA is latched on the Program command.
- 4. Following the Read Intelligent ID command, two read operations access manufacturer and device codes.
- 5. Figure 4 illustrates the Quick-Pulse Programming Algorithm.
- 6. Figure 5 illustrates the Quick-Erase Algorithm.
- 7. The second bus cycle must be followed by the desired command register write.

### Read Command

While V<sub>PP</sub> is high, for erasure and programming, memory contents can be accessed via the read command. The read operation is initiated by writing 00H into the command register. Microprocessor read cycles retrieve array data. The device remains enabled for reads until the command register contents are altered.

The default contents of the register upon V<sub>PP</sub> power-up is 00H. This default value ensures that no spurious alternation of memory contents occurs during the V<sub>PP</sub> power transition. Where the V<sub>PP</sub> supply is hard-wired to the 28F256A, the device powers-up and remains enabled for reads until the command register contents are changed. Refer to the AC Read Characteristics and Waveforms for specific timing parameters.

# **Intelligent Identifier Command**

Flash memories are intended for use in applications where the local CPU alters memory contents. As such, manufacturer- and device-codes must be accessible while the device resides in the target system. PROM programmers typically access signature codes by raising A<sub>9</sub> to a high voltage. However, mul-

tiplexing high voltage onto address lines is not a desired system-design practice.

The 28F256A contains an Intelligent Identifier operation to supplement traditional PROM-programming methodology. The operation is initiated by writing 90H into the command register. Following the command write, a read cycle from address 0000H retrieves the manufacturer code 89H. A read cycle from address 0001H returns the device code B9H. To terminate the operation, it is necessary to write another valid command into the register.

# **Set-Up Erase/Erase Commands**

Set-up Erase is a command-only operation that stages the device for electrical erase of all bytes in the array. The set-up erase operation is performed by writing 20H to the command register. To commence chip-erasure, the erase command (20H) must again be written to the register. The erase operation begins with the rising edge of the Write-Enable pulse and terminate with the rising edge of the next Write-Enable pulse (i.e., Erase-Verify Command).

This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, chip-erasure can only occur when high voltage is applied to the V<sub>PP</sub> pin. In the absence

of this high voltage, memory contents are protected against erasure. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

**Erase-Verify Command** 

The erase command erases all of the bytes of the array in parallel. After each erase operation, all bytes must be verified. The erase verify operation is initiated by writing AOH into the command register. The address for the byte to be verified must be supplied as it is latched on the falling edge of the Write-Enable pulse. The register write terminates the erase operation with the rising edge of its Write-Enable pulse.

The 28F256A applies an internally-generated margin voltage to the addressed byte. Reading FFH from the addressed byte indicates that all bits in the byte are erased.

The erase-verify command must be written to the command register prior to each byte verification to latch its address. The process continues for each byte in the array until a byte does not return FFH data, or the last address is accessed.

In the case where the data read is not FFH, another erase operation is performed. (Refer to Set-Up Erase/Erase.) Verification then resumes from the address of the last-verified byte. Once all bytes in the array have been verified, the erase step is complete. The device can be programmed. At this point, the verify operation is terminated by writing a valid command (e.g., Program Set-Up) to the command register. Figure 5, the Quick-Erase algorithm, illustrates how commands and bus operations are combined to perform electrical erasure of the 28F256A. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

# Set-Up Program/Program Commands

Set-up program is a command-only operation that stages the device for byte programming. Writing 40H into the command register performs the set-up operation.

Once the program set-up operation is performed, the next Write-Enable pulse causes a transition to an active programming operation. Addresses are internally latched on the falling edge of the Write-Enable pulse. Data is internally latched on the rising edge of the Write-Enable pulse. The rising edge of Write-Enable also begins the programming operation. The programming operation terminates with the next rising edge of Write-Enable, used to write the

program-verify command. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.

### **Program Verify Command**

The 28F256A is programmed on a byte-by-byte basis. Byte programming may occur sequentially or at random. Following each programming operation, the byte just programmed must be verified.

The program-verify operation is initiated by writing C0H into the command register. The register write terminates the programming operation with the rising edge of its Write-Enable pulse. The program-verify operation stages the device for verification of the byte last programmed. No new address information is latched.

The 28F256A applies an internally-generated margin voltage to the byte. A microprocessor read cycle outputs the data. A successful comparison between the programmed byte and true data means that the byte is successfully programmed. Programming then proceeds to the next desired byte location. Figure 4, the 28F256A Quick-Pulse Programming algorithm, illustrates how commands are combined with bus operations to perform byte programming. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.

### **Reset Command**

A reset command is provided as a means to safely abort the erase- or program-command sequences. Following either set-up command (erase or program) with two consecutive writes of FFH will safely abort the operation. Memory contents will not be altered. A valid command must then be written to place the device in the desired state.

# EXTENDED ERASE/PROGRAM CYCLING

EEPROM cycling failures have always concerned users. The high electrical field required by thin oxide EEPROMs for tunneling can literally tear apart the oxide at defect regions. To combat this, some suppliers have implemented redundancy schemes, reducing cycling failures to insignificant levels. However, redundancy requires that cell size be doubled—an expensive solution.

Intel has designed extended cycling capability into its ETOX II flash memory technology. Resulting improvements in cycling reliability come without increasing memory cell size or complexity. First, an



advanced tunnel oxide increases the charge carrying ability ten-fold. Second, the oxide area per cell subjected to the tunneling electric field is one-tenth that of common EEPROMs, minimizing the probability of oxide defects in the region. Finally, the peak electric field during erasure is approximately 2 MV/cm lower then EEPROM. The lower electric field greatly reduces oxide stress and the probability of failure—increasing time to wear out by a factor of 100,000,000.

The 28F256A is capable of 100,000 program/erase cycles. The device is programmed and erased using Intel's Quick-Pulse Programming and Quick-Erase algorithms. Intel's algorithmic approach uses a series of operations (pulses), along with byte verification, to completely and reliably erase and program the device.

For further reliability information, see Reliability Report RR-60 (ETOX II Reliability Data Summary).

# QUICK-PULSE PROGRAMMING ALGORITHM

The Quick-Pulse Programming algorithm uses programming operations of 10  $\mu s$  duration. Each operation is followed by a byte verification to determine when the addressed byte has been successfully programmed. The algorithm allows for up to 25 programming operations per byte, although most bytes verify on the first or second operation. The entire sequence of programming and byte verification is

performed with V<sub>PP</sub> at high voltage. Figure 4 illustrates the Quick-Pulse Programming algorithm.

### QUICK-ERASE ALGORITHM

Intel's Quick-Erase algorithm yields fast and reliable electrical erasure of memory contents. The algorithm employs a closed-loop flow, similar to the Quick-Pulse Programming algorithm, to simultaneously remove charge from all bits in the array. Erasure begins with a read of memory contents. The 28F256A is erased when shipped from the factory. Reading FFH data from the device would immediately be followed by device programming.

For devices being erased and reprogrammed, uniform and reliable erasure is ensured by first programming all bits in the device to their charged state (data = 00H). This is accomplished, using the Quick-Pulse Programming algorithm, in approximately one-half second.

Erase execution then continues with an initial erase operation. Erase verification (data = FFH) begins at address 0000H and continues through the array to the last address, or until data other than FFH is encountered. With each erase operation, an increasing number of bytes verify to the erased state. Erase efficiency may be improved by storing the address of the last byte verified in a register. Following the next erase operation, verification starts at that stored address location. Erasure typically occurs in one second. Figure 5 illustrates the Quick-Erase algorithm.





| Bus              | Command                          | Comments                                                                                                    |
|------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------|
| Operation        | Command                          | Comments                                                                                                    |
| Standby          |                                  | Wait for V <sub>PP</sub> ramp<br>to V <sub>PPH</sub> (= 12.0V) (1)<br>Initialize pulse-count                |
| Write            | Set-Up<br>Program                | Data = 40H                                                                                                  |
| Write            | Program                          | Valid address/data                                                                                          |
| Standby          |                                  | Duration of Program operation (twhwh1)                                                                      |
| Write            | Program <sup>(2)</sup><br>Verify | Data = C0H; Stops (3) Program Operation                                                                     |
| Standby          | -                                | twhgL                                                                                                       |
| Read             |                                  | Read byte to verify programming                                                                             |
| Standby          |                                  | Compare data output<br>to data expected                                                                     |
| Write<br>Standby | Read                             | Data = 00H, resets the register for read operations.  Wait for V <sub>PP</sub> ramp to V <sub>PPL</sub> (1) |

- 1. See DC Characteristics for the value of VPPH and VPPL.
- 2. Program Verify is only performed after byte programming. A final read/compare may be performed (optional) after the register is written with the Read command.
- 3. Refer to principles of operation.
- 4. CAUTION: The algorithm MUST BE FOLLOWED to ensure proper and reliable operation of the device.

Figure 4. 28F256A Quick-Pulse Programming Algorithm





| Bus<br>Operation | Command                        | Comments                                                                                                                   |
|------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Standby          |                                | Wait for V <sub>PP</sub> ramp<br>to V <sub>PPH</sub> (= 12.0V) (1)<br>Use Quick-Pulse<br>Programming (Fig. 4)              |
| Write            | Set-Up<br>Erase                | Initialize Addresses,<br>Erase Pulse Width,<br>and Pulse Count<br>Data = 20H                                               |
| Write            | Erase                          | Data = 20H                                                                                                                 |
| Standby          | Erase<br>Verify <sup>(2)</sup> | Duration of Erase<br>operation (t <sub>WHWH2</sub> )<br>Addr = Byte to verify;<br>Data = A0H; Stops<br>Erase Operation (3) |
| Standby<br>Read  | -                              | Read byte to verify                                                                                                        |
| Standby          |                                | Compare output to FFH increment pulse count                                                                                |
|                  |                                |                                                                                                                            |
| Write            | Read                           | Data = 00H, resets the register for read                                                                                   |
| Standby          |                                | operations.  Wait for V <sub>PP</sub> ramp  to V <sub>PPL</sub> (1)                                                        |

- 1. See DC Characteristics for the value of  $V_{\mbox{\footnotesize{PPH}}}$  and  $V_{\mbox{\footnotesize{PPL}}}$ .
- Erase Verify is performed only after chip-erasure. A final read/compare may be performed (optional) after the register is written with the Read command.
- 3. Refer to principles of operation.
- 4. CAUTION: The algorithm MUST BE FOLLOWED to ensure proper and reliable operation of the device.

Figure 5. 28F256A Quick-Erase Algorithm



### **DESIGN CONSIDERATIONS**

### **Two-Line Output Control**

Flash memories are often used in larger memory arrays. Intel provides two read-control inputs to accommodate multiple memory connections. Two-line control provides for:

- a. the lowest possible memory power dissipation, and
- b. complete assurance that output bus contention will not occur.

To efficiently use these two control units, an address-decoder output should drive chip-enable, while the system's read signal controls all flash memories and other parallel memories. This assures that only enabled memory devices have active outputs, while deselected devices maintain the low power standby condition.

### **Power Supply Decoupling**

Flash memory power-switching characteristics require careful device decoupling. System designers are interested in three supply current (I<sub>CC</sub>) issues—standby, active, and transient current peaks produced by falling and rising edges of chip-enable. The capacitive and inductive loads on the device outputs determine the magnitudes of these peaks.

Two-line control and proper decoupling capacitor selection will suppress transient voltage peaks. Each device should have a 0.1  $\mu F$  ceramic capacitor connected between  $V_{CC}$  and  $V_{SS}$ , and between  $V_{PP}$  and  $V_{SS}$ .

Place the high-frequency, low-inherent-inductance capacitors as close as possible to the devices. Also, for every eight devices, a 4.7  $\mu\text{F}$  electrolytic capacitor should be placed at the array's power supply connection, between VCC and Vss. The bulk capacitor will overcome voltage slumps caused by printed-circuit-board trace inductance, and will supply charge to the smaller capacitors as needed.

### **VPP Trace on Printed Circuit Boards**

Programming flash memories, while they reside in the target smith, requires that the printed circuit board designer pay attention to the V<sub>PP</sub> pin power supply trace. Use similar trace widths and layout considerations given the V<sub>CC</sub> power bus. Adequate V<sub>PP</sub> supply traces and decoupling will decrease V<sub>PP</sub> voltage spikes and overshoots.

### **Power Up/Down Protection**

The 28F256A is designed to offer protection against accidental erasure or programming during power transitions. Upon power-up, the 28F256A is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers up first. **Power supply sequencing is not required.** Internal circuitry in the 28F256A ensures that the command register is reset to the read mode upon power up.

A system designer must guard against active writes for  $V_{CC}$  voltages above  $V_{LKO}$  when  $V_{PP}$  is active. Since both WE# and CE# must be low for a command write, driving either to  $V_{IH}$  will inhibit writes. The control register architecture provides an added level of protection since alteration of memory contents only occurs after successful completion of the two-step command sequences.

### 28F256A Power Dissipation

When designing portable systems, designers must consider battery power consumption not only during device operation, but also for data retention during system idle time. Flash nonvolatility increases the usable battery life of your system because the 28F256A does not consume any power to retain code or data when the system is off. Table 4 illustrates the power dissipated when updating the 28F256A.

Table 4. 28F256A Typical Update Power Dissipation<sup>(4)</sup>

| Operation                    | Power Dissipation (Watt-Seconds) | Notes |
|------------------------------|----------------------------------|-------|
| Array Program/Program Verify | 0.043                            | 1     |
| Array Erase/Erase Verify     | 0.083                            | 2     |
| One Complete Cycle           | 0.169                            | 3     |

### NOTES

1. Formula to calculate typical Program/Program Verify Power =  $[V_{PP} \times \# Bytes \times typical \# Prog Pulses (t_{WHWH1} \times I_{PP2} typical + t_{WHGL} \times I_{PP4} typical)] + [V_{CC} \times \# Bytes \times typical \# Prog Pulses (t_{WHWH1} \times I_{CC2} typical) + t_{WHGL} \times I_{CC4} typical)].$ 

2. Formula to calculate typical Erase/Erase Verify Power = [V<sub>pp</sub> (I<sub>PP3</sub> typical × t<sub>ERASE</sub> typical + I<sub>PP5</sub> typical × t<sub>WHGL</sub> × # Bytes)] + [V<sub>CC</sub>(I<sub>CC3</sub> typical × t<sub>ERASE</sub> typical + I<sub>CC5</sub> typical × t<sub>WHGL</sub> × # Bytes)].

3. One Complete Cycle = Array Preprogram + Array Erase + Program.

4. "Typicals" are not guaranteed, but based on a limited number of samples from production lots.



### **ABSOLUTE MAXIMUM RATINGS\***

| Operating Temperature During Read0°C to +70°C(1) During Erase/Program0°C to +70°C                   |
|-----------------------------------------------------------------------------------------------------|
| Temperature Under Bias $-10^{\circ}$ C to $+80^{\circ}$ C                                           |
| Storage Temperature65°C to +125°C                                                                   |
| Voltage on Any Pin with Respect to Ground2.0V to +7.0V(2)                                           |
| Voltage on Pin A <sub>9</sub> with Respect to Ground2.0V to +13.5V(2, 3)                            |
| V <sub>PP</sub> Supply Voltage with<br>Respect to Ground<br>During Erase/Program2.0V to +14.0(2, 3) |
| V <sub>CC</sub> Supply Voltage with Respect to Ground2.0V to +7.0V(2)                               |

Output Short Circuit Current.....100 mA(4)

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

### NOTES:

1. Operating temperature is for commercial product defined by this specification.

- 2. Minimum DC input voltage is -0.5V. During transitions, inputs may undershoot to -2.0V for periods less than 20 ns. Maximum DC voltage on output pins is  $V_{CC}$  +0.5V, which may overshoot to  $V_{CC}$  +2.0V for periods less than 20 ns.
- 3. Maximum DC voltage on A<sub>9</sub> or V<sub>PP</sub> may overshoot to +14.0V for periods less than 20 ns.
- 4. Output shorted for no more than one second. No more than one output shorted at a time.

### **OPERATING CONDITIONS**

| Symbol           | Parameter                      | Limits |       | Limits |                                            | Limits |  | Limits |  | Limits |  | Unit | Comments |
|------------------|--------------------------------|--------|-------|--------|--------------------------------------------|--------|--|--------|--|--------|--|------|----------|
| Symbol Parameter | Min                            | Max    | J. J. |        |                                            |        |  |        |  |        |  |      |          |
| T <sub>A</sub>   | Operating Temperature          | 0      | 70    | °C     | For Read-Only and<br>Read/Write Operations |        |  |        |  |        |  |      |          |
| V <sub>CC</sub>  | V <sub>CC</sub> Supply Voltage | 4.50   | 5.50  | V      |                                            |        |  |        |  |        |  |      |          |



# DC CHARACTERISTICS—TTL/NMOS COMPATIBLE

| Symbol           | Parameter                                        | Notes |       | Limits     | 3                     | Unit  | Test Conditions                                                  |
|------------------|--------------------------------------------------|-------|-------|------------|-----------------------|-------|------------------------------------------------------------------|
| Syllibol         | raiailletei                                      | Notes | Min   | Typical(4) | Max                   | Oilit | rest conditions                                                  |
| l <sub>Ll</sub>  | Input Leakage Current                            | 1     |       |            | ±1.0                  | μΑ    | $V_{CC} = V_{CC} \max$ $V_{IN} = V_{CC} \text{ or } V_{SS}$      |
| llo              | Output Leakage Current                           | 1     |       |            | ±10.0                 | μΑ    | $V_{CC} = V_{CC} \max$<br>$V_{OUT} = V_{CC} \text{ or } V_{SS}$  |
| Iccs             | V <sub>CC</sub> Standby Current                  | 1     | ,     | 0.3        | 1.0                   | mΑ    | $V_{CC} = V_{CC}$ max<br>$CE \# = V_{IH}$                        |
| lcc1             | V <sub>CC</sub> Active Read Current              | 1     |       | 10         | 30                    | mA    | $V_{CC} = V_{CC}$ max CE# = $V_{IL}$ f = 6 MHz, $I_{OUT}$ = 0 mA |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current              | 1, 2  |       | 1.0        | 10                    | mΑ    | Programming in Progress                                          |
| I <sub>CC3</sub> | V <sub>CC</sub> Erasure Current                  | 1, 2  |       | 5.0        | 15                    | mΑ    | Erasure in Progress                                              |
| I <sub>CC4</sub> | V <sub>CC</sub> Program Verify Current           | 1, 2  |       | 5.0        | 15                    | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current             | 1, 2  |       | 5.0        | 15                    | mΑ    | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress   |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                  | 1     |       |            | ± 10.0                | μΑ    | V <sub>PP</sub> ≤ V <sub>CC</sub>                                |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, ID Current,        | 1     |       | 90         | 200                   | μΑ    | V <sub>PP</sub> > V <sub>CC</sub>                                |
|                  | or Standby Current                               |       |       |            | ±10.0                 |       | V <sub>PP</sub> ≤ V <sub>CC</sub>                                |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current              | 1, 2  |       | 8.0        | 30                    | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress    |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                    | 1, 2  |       | 4.0        | 20                    | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress        |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current           | 1, 2  |       | 2.0        | 5.0                   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current             | 1, 2  |       | 2.0        | 5.0                   | mA    | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress   |
| VIL              | Input Low Voltage                                |       | -0.5  |            | 0.8                   | ٧     |                                                                  |
| V <sub>IH</sub>  | Input High Voltage                               |       | 2.0   |            | V <sub>CC</sub> + 0.5 | ٧     |                                                                  |
| V <sub>OL</sub>  | Output Low Voltage                               |       |       |            | 0.45                  | ٧     | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ min}$       |
| V <sub>OH1</sub> | Output High Voltage                              |       | 2.4   |            |                       | ٧     | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{min}$          |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Voltage |       | 11.50 |            | 13.00                 | ٧     |                                                                  |
| l <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2  |       | 90         | 200                   | μΑ    | $A_9 = V_{ID}$                                                   |
| V <sub>PPL</sub> | V <sub>PP</sub> During Read-Only<br>Operations   |       | 0.00  |            | 6.5                   | ٧     | Note: Erase/Program are Inhibited when $V_{PP} = V_{PPL}$        |
| V <sub>PPH</sub> | V <sub>PP</sub> During Read/Write<br>Operations  |       | 11.40 |            | 12.60                 | ٧     |                                                                  |
| $V_{LKO}$        | V <sub>CC</sub> Erase/Write Lock Voltage         |       | 2.5   |            |                       | ٧     |                                                                  |



# DC CHARACTERISTICS—CMOS COMPATIBLE

| Symbol           | Parameter                                        | Notes  |                      | Limits                 |                       | Unit | Test Conditions                                                        |
|------------------|--------------------------------------------------|--------|----------------------|------------------------|-----------------------|------|------------------------------------------------------------------------|
| Cymbo.           | T diameter                                       | 110103 | Min                  | Typical <sup>(4)</sup> | Max                   | Oint | rest conditions                                                        |
| I <sub>LI</sub>  | Input Leakage Current                            | 1      |                      |                        | ±1.0                  | μΑ   | $V_{CC} = V_{CC} \text{ max}$<br>$V_{IN} = V_{CC} \text{ or } V_{SS}$  |
| lo               | Output Leakage Current                           | 1      |                      |                        | ±10.0                 | μΑ   | $V_{CC} = V_{CC} \text{ max}$<br>$V_{OUT} = V_{CC} \text{ or } V_{SS}$ |
| Iccs             | V <sub>CC</sub> Standby Current                  | 1      |                      | 50                     | 100                   | μΑ   | $V_{CC} = V_{CC}$ max<br>CE# = $V_{CC} \pm 0.2V$                       |
| lcc1             | V <sub>CC</sub> Active Read Current              | 1      |                      | 10                     | 30                    | mA   | $V_{CC} = V_{CC}$ max $CE \# = V_{IL}$<br>f = 6 MHz, $I_{OUT} = 0$ mA  |
| I <sub>CC2</sub> | V <sub>CC</sub> Programming Current              | 1, 2   |                      | 1.0                    | 10                    | mΑ   | Programming in Progress                                                |
| I <sub>CC3</sub> | V <sub>CC</sub> Erase Current                    | 1, 2   |                      | 5.0                    | 15                    | mΑ   | Erasure in Progress                                                    |
| ICC4             | V <sub>CC</sub> Program Verify Current           | 1, 2   |                      | 5.0                    | 15                    | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress       |
| I <sub>CC5</sub> | V <sub>CC</sub> Erase Verify Current             | 1, 2   | ,                    | 5.0                    | 15                    | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress         |
| I <sub>PPS</sub> | V <sub>PP</sub> Leakage Current                  | 1      |                      |                        | ±10.0                 | μΑ   | V <sub>PP</sub> ≤ V <sub>CC</sub>                                      |
| I <sub>PP1</sub> | V <sub>PP</sub> Read Current, ID                 | 1      |                      | 90                     | 200                   | μА   | V <sub>PP</sub> > V <sub>CC</sub>                                      |
|                  | Current, or Standby Current                      |        |                      |                        | ±10.0                 | , ,  | V <sub>PP</sub> ≤ V <sub>CC</sub>                                      |
| I <sub>PP2</sub> | V <sub>PP</sub> Programming Current              | 1, 2   |                      | 8.0                    | 30                    | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in Progress          |
| I <sub>PP3</sub> | V <sub>PP</sub> Erase Current                    | 1, 2   | ,                    | 4.0                    | 20                    | mΑ   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in Progress              |
| I <sub>PP4</sub> | V <sub>PP</sub> Program Verify Current           | 1, 2   | -                    | 2.0                    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Program Verify in Progress       |
| I <sub>PP5</sub> | V <sub>PP</sub> Erase Verify Current             | 1, 2   | ` y                  | 2.0                    | 5.0                   | mA   | V <sub>PP</sub> = V <sub>PPH</sub><br>Erase Verify in Progress         |
| V <sub>IL</sub>  | Input Low Voltage                                |        | -0.5                 |                        | 0.8                   | ٧    |                                                                        |
| V <sub>IH</sub>  | Input High Voltage                               |        | 0.7V <sub>CC</sub>   |                        | V <sub>CC</sub> + 0.5 | ٧    |                                                                        |
| V <sub>OL</sub>  | Output Low Voltage                               |        |                      |                        | 0.45                  | ٧    | $I_{OL} = 5.8 \text{ mA}$<br>$V_{CC} = V_{CC} \text{ min}$             |
| V <sub>OH1</sub> | Output High Voltage                              |        | 0.85V <sub>CC</sub>  |                        |                       | ٧    | $I_{OH} = -2.5 \text{ mA},$ $V_{CC} = V_{CC} \text{ min}$              |
| V <sub>OH2</sub> |                                                  |        | V <sub>CC</sub> -0.4 |                        |                       |      | $I_{OH} = 100 \mu A,$ $V_{CC} = V_{CC} min$                            |
| V <sub>ID</sub>  | A <sub>9</sub> Intelligent Identifier<br>Voltage |        | 11.50                |                        | 13.00                 | ٧    | ·                                                                      |
| IID              | A <sub>9</sub> Intelligent Identifier<br>Current | 1, 2   |                      | 90                     | 200                   | μΑ   | $A_9 = V_{ID}$                                                         |



### DC CHARACTERISTICS—CMOS COMPATIBLE (Continued)

| Symbol           | Parameter                                       | Notes  |       | Limits |       | Unit | Test Conditions                                           |
|------------------|-------------------------------------------------|--------|-------|--------|-------|------|-----------------------------------------------------------|
| Cymbol           | 1 diamotoi                                      | 110100 |       |        | Max   |      | 1 oot oonaldono                                           |
| V <sub>PPL</sub> | V <sub>PP</sub> During Read-Only<br>Operations  |        | 0.00  |        | 6.5   | ٧    | Note: Erase/Program are Inhibited when $V_{PP} = V_{PPL}$ |
| V <sub>PPH</sub> | V <sub>PP</sub> During Read/Write<br>Operations |        | 11.40 |        | 12.60 | ٧    |                                                           |
| V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage        |        | 2.5   |        |       | ٧    |                                                           |

### **CAPACITANCE(3)** T = 25°C, f = 1.0 MHz

| Symbol           | Parameter                      | Notes | Limits |     | Unit  | Conditions           |  |
|------------------|--------------------------------|-------|--------|-----|-------|----------------------|--|
| Symbol           | Parameter                      | Mores | Min    | Max | Offic | Conditions           |  |
| C <sub>IN</sub>  | Address/Control<br>Capacitance | 3     |        | 6   | pF    | V <sub>IN</sub> = 0V |  |
| C <sub>OUT</sub> | Output Capacitance             | 3     |        | 12  | pF    | $V_{OUT} = 0V$       |  |

### NOTES FOR DC CHARACTERISTICS AND CAPACITANCE:

- 1. All currents are in RMS unless otherwise noted. Typical values at V<sub>CC</sub> = 5.0V, V<sub>PP</sub> = 12.0V, T = 25°C. These currents are valid for all product versions (Packages and Speeds).
- 2. Not 100% tested: characterization data available.
- 3. Sampled, not 100% tested.
- 4. "Typicals" are not guaranteed, but based on a limited number of samples from production lots.

### AC TESTING INPUT/OUTPUT WAVEFORM



### **AC TESTING LOAD CIRCUIT**



### **AC Test Conditions**

Input Rise and Fall Times (10% to 90%) . . . . . 10 ns Input Pulse Levels ........................0.45 and 2.4 Input Timing Reference Level .........0.8 and 2.0 Output Timing Reference Level . . . . . . . 0.8 and 2.0



# **AC CHARACTERISTICS** Read-Only Operations

| Versions                           | Versions                                     |       | 28F25 | 6 <b>A-</b> 120 | 28F25 | 6 <b>A-</b> 150 | Unit |
|------------------------------------|----------------------------------------------|-------|-------|-----------------|-------|-----------------|------|
| Symbol                             | Characteristic                               | Notes | Min . | Max             | Min   | Max             |      |
| t <sub>AVAV</sub> /t <sub>RC</sub> | Read Cycle Time                              |       | 120   |                 | 150   |                 | ns   |
| t <sub>ELQV</sub> /t <sub>CE</sub> | Chip Enable Access Time                      |       |       | 120             |       | 150             | ns   |
| tavqv/tacc                         | Address Access Time                          |       |       | 120             |       | 150             | ns   |
| t <sub>GLQV</sub> /t <sub>OE</sub> | Output Enable<br>Access Time                 |       |       | 50              |       | 55              | ns   |
| t <sub>ELQX</sub> /t <sub>LZ</sub> | Chip Enable to Output in Low Z               | 2, 3  | 0     |                 | 0     |                 | ns   |
| t <sub>EHQZ</sub>                  | Chip Disable to Output in High Z             | 2     |       | 55              |       | 55              | ns   |
| tGLQX/tOLZ                         | Output Enable to Output in Low Z             | 2, 3  | 0     |                 | 0     |                 | ns   |
| t <sub>GHQZ</sub> /t <sub>DF</sub> | Output Disable to Output in High Z           | 2     |       | 30              |       | 35              | ns   |
| tон                                | Output Hold from Address, CE#, or OE# Change | 1, 2  | 0 .   |                 | 0     |                 | ns   |
| twhgL                              | Write Recovery Time<br>before Read           |       | 6     |                 | 6     |                 | μs   |

- Whichever occurs first.
   Sampled, not 100% tested.
- 3. Guaranteed by design.



Figure 6. AC Waveform for Read Operations



# AC CHARACTERISTICS—For Write/Erase/Program Operations(1)

| Versions                            |                                                   | Notes | 28F25 | 28F256A-120 |     | 6A-150 | Unit |
|-------------------------------------|---------------------------------------------------|-------|-------|-------------|-----|--------|------|
| Symbol                              | Characteristic                                    | Notes | Min   | Max         | Min | Max    |      |
| t <sub>AVAV</sub> /t <sub>WC</sub>  | Write Cycle Time                                  |       | 120   |             | 150 |        | ns   |
| tAVWL/tAS                           | Address Set-Up Time                               |       | 0     |             | 0   |        | ns   |
| t <sub>WLAX</sub> /t <sub>AH</sub>  | Address Hold Time                                 |       | 60    |             | 60  |        | ns   |
| t <sub>DVWH</sub> /t <sub>DS</sub>  | Data Set-Up Time                                  |       | 50    |             | 50  |        | ns   |
| t <sub>WHDX</sub> /t <sub>DH</sub>  | Data Hold Time                                    |       | 10    |             | 10  |        | ns   |
| t <sub>WHGL</sub>                   | Write Recovery Time before Read                   |       | 6     |             | 6   |        | μs   |
| t <sub>GHWL</sub>                   | Read Recovery Time before Write                   | 2     | 0     |             | 0   |        | μs   |
| t <sub>ELWL</sub> /t <sub>CS</sub>  | Chip Enable Set-Up<br>Time before Write           |       | 20    |             | 20  |        | ns   |
| t <sub>WHEH</sub> /t <sub>CH</sub>  | Chip Enable Hold Time                             |       | 0     |             | 0   |        | ns   |
| t <sub>WLWH</sub> /t <sub>WP</sub>  | Write Pulse Width                                 |       | 60    |             | 60  |        | ns   |
| t <sub>WHWL</sub> /t <sub>WPH</sub> | Write Pulse Width High                            |       | 20    |             | 20  |        | ns   |
| t <sub>WHWH1</sub>                  | Duration of<br>Programming Operation              | 3     | 10    |             | 10  |        | μs   |
| t <sub>WHWH2</sub>                  | Duration of<br>Erase Operation                    | 3     | 9.5   |             | 9.5 |        | ms   |
| t <sub>VPEL</sub>                   | V <sub>PP</sub> Set-Up Time to<br>Chip Enable Low | 2     | 1.0   |             | 1.0 |        | μs   |

### NOTES:

- 1. Read timing parameters during read/write operations are the same as during read-only operations. Refer to AC Characteristics for Read-Only Operations.
- 2. Guaranteed by design.
- 3. The integrated stop timer terminates the programming/erase operations, thereby eliminating the need for a maximum specification.

### **ERASE AND PROGRAMMING PERFORMANCE**

|                   |         | Limits      |     |     |     |      |     |     |  |  |
|-------------------|---------|-------------|-----|-----|-----|------|-----|-----|--|--|
| Parameter Notes   |         | 28F256A-120 |     |     | . 2 | Unit |     |     |  |  |
|                   |         | Min         | Тур | Max | Min | Тур  | Max |     |  |  |
| Chip Erase Time   | 1, 3, 4 |             | 1   | 10  |     | 1    | 10  | sec |  |  |
| Chip Program Time | 1, 2, 4 |             | 0.5 | 3   |     | 0.5  | 3   | sec |  |  |

- 1. "Typicals" are not guaranteed, but based on a limited number of samples taken from production lots. Data taken at 25°C, 12.0V V<sub>PP</sub>, at 0 cycles.
- 2. Minimum byte programming time excluding system overhead is 16  $\mu$ s program + 6  $\mu$ s write recovery), while maximum is 400  $\mu$ s/byte (16  $\mu$ s x 25 loops allowed by algorithm). Max chip programming is specified lower than the worst case allowed by the programming algorithm since most bytes program significantly faster than the worst case byte.
- 3. Excludes 00H Programming Prior to Erasure.
- 4. Excludes System-Level Overhead.
- 5. Refer to RR-60 "ETOX" II Flash Memory Reliability Data Summary for typical cycling data and failure rate calculations.





Figure 7. 28F256A Typical Programming Capability



Figure 8. 28F256A Typical Program Time at 12V





Figure 9. 28F256A Typical Erase Capability



Figure 10. 28F256A Typical Erase Time at 12.0V









### **ALTERNATIVE CE#-CONTROLLED WRITES**

| Versions            |                                                   | Notes | 28F25 | 6A-120 | 28F25 | 6A-150 | Unit |
|---------------------|---------------------------------------------------|-------|-------|--------|-------|--------|------|
| Symbol              | Characteristic                                    | Notes | Min   | Max    | Min   | Max    |      |
| tavav               | Write Cycle Time                                  |       | 120   |        | 150   |        | ns   |
| taveL               | Address Set-Up Time                               |       | 0     |        | 0     |        | ns   |
| t <sub>ELAX</sub>   | Address Hold Time                                 |       | 80    |        | 80    |        | ns   |
| t <sub>DVEH</sub>   | Data Set-Up Time                                  |       | 50    |        | 50    |        | ns   |
| t <sub>EHDX</sub>   | Data Hold Time                                    |       | 10    |        | 10    |        | ns   |
| t <sub>EHGL</sub>   | Write Recovery Time before Read                   |       | 6     |        | 6     |        | μs   |
| t <sub>GHEL</sub> . | Read Recover Time before Write                    | 2     | 0     |        | 0     |        | μs   |
| t <sub>WLEL</sub>   | Write Enable Set-Up Time before Chip-Enable       |       | 0     |        | 0     |        | ns   |
| tEHWH               | Write Enable Hold Time                            | ,     | 0     |        | 0     |        | ns   |
| tELEH               | Write Pulse Width                                 | 1     | 70    |        | 70    |        | ns   |
| t <sub>EHEL</sub>   | Write Pulse Width High                            |       | 20    |        | 20    |        | ns   |
| t <sub>VPEL</sub>   | V <sub>PP</sub> Set-Up Time<br>to Chip-Enable Low | 2     | 1.0   |        | 1.0   |        | μs   |

### NOTE:

2. Guaranteed by design.

<sup>1.</sup> Chip-Enable Controlled Writes: Write operations are driven by the valid combination of Chip-Enable and Write-Enable. In systems where Chip-Enable defines the write pulse width (with a longer Write-Enable timing waveform) all set-up, hold and inactive Write-Enable times should be measured relative to the Chip-Enable waveform.





### **ORDERING INFORMATION**



### **ADDITIONAL INFORMATION**

|         |                                                                      | Order Number |
|---------|----------------------------------------------------------------------|--------------|
| ER-20,  | "ETOX II Flash Memory Technology"                                    | 294005       |
| ER-24,  | "Intel Flash Memory"                                                 | 294008       |
| RR-60,  | "ETOX II Flash Memory Reliability Data Summary"                      | 293002       |
| AP-316, | "Using Flash Memory for In-System Reprogramming Nonvolatile Storage" | 292046       |
| AP-325, | "Guide to Flash Memory Reprogramming"                                | 292059       |

# **REVISION HISTORY**

| Number | Description                                                                                                                                                                                       |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 004    | Removed <b>Preliminary</b> Classification. Removed <b>200 ns</b> speed bin. Revised Erase Maximum Pulse Count for Figure 5 from <b>3000</b> to <b>1000</b> . Clarified AC and DC test conditions. |
| 005    | Corrected AC waveforms.                                                                                                                                                                           |
| 006    | Revised symbols; i.e., $\overline{\text{CE}}$ , $\overline{\text{OE}}$ , etc. to CE#, OE#, etc.                                                                                                   |



# APPLICATION NOTE

# Using Flash Memory for In-System Reprogrammable Nonvolatile Storage

SAUL ZALES
DALE ELBERT
APPLICATIONS ENGINEERING
INTEL CORPORATION

September 1993

### USING FLASH MEMORY FOR IN-SYSTEM REPROGRAMMABLE NONVOLATILE STORAGE

| CONTENTS                                                             | PAGE               |
|----------------------------------------------------------------------|--------------------|
| 1.0 INTRODUCTION                                                     |                    |
| Programming                                                          |                    |
| Upload                                                               |                    |
| Version Updates (Download)                                           |                    |
| Data Acquisition (Upload)                                            | 5-120              |
| 2.0 DEVICE FEATURES AND ISW APPLICATION CONSIDERATIONS               | 5 <sub>-</sub> 121 |
| 2.1 Flash Memory Pinouts                                             |                    |
| 2.2 Command Register Architecture                                    |                    |
| Simplified Processor Interface                                       |                    |
| Command Register Reset                                               |                    |
| Data Protection on Power Transitions                                 | 5-124              |
| 2.3 V <sub>PP</sub> Specifications                                   |                    |
| 3.0 HARDWARE DESIGN FOR ISW                                          | 5-125              |
| 3.1 V <sub>PP</sub> Generation                                       |                    |
| 3.1.1 Regulating Down from Higher Voltage                            |                    |
| 3.1.2 Pumping 5V up to 12V                                           |                    |
| 3.1.3 Absolute Data Protection -<br>V <sub>PP</sub> On/Off Control   | <br>5-126          |
| 3.1.4 Writes and Reads during V <sub>PP</sub> Transitions            | 5-126              |
| 3.1.5 Other V <sub>PP</sub> Considerations                           |                    |
| 3.1.6 V <sub>PP</sub> Circuitry and Trace<br>Layout                  |                    |
| 3.2 Communications — Getting Data<br>to and from the Flash<br>Memory |                    |
| 4.0 SOFTWARE DESIGN FOR ISW                                          |                    |
| 4.1 System Integration — Boot Cod<br>Requirements                    | e                  |
| 4.1.1 ISW Flag Check                                                 |                    |
| 4.2 Communication Protocols and Flash Memory ISW                     |                    |
| 4.3 Data Accumulation Software                                       |                    |

| 5.0 SYSTEM DESIGN EXAMPLE: AN 80C186 DESIGN        | APPENDIX F: DETAILED SYSTEM SCHEMATICS 5-154          |
|----------------------------------------------------|-------------------------------------------------------|
| Hardware Methods 5-132                             | PROGRAMMING FLOW CHART 5-152                          |
| Software Methods and Examples 5-132                | APPENDIX E:<br>DETAILED PARALLEL                      |
| 4.4.3 Pulse Width Timing Techniques 5-132          | CHART 5-150                                           |
| High Performance Parallel Device Programming 5-131 | APPENDIX D:                                           |
| Algorithm Timing Delays 5-131                      | COMPANIES 5-149                                       |
| 4.4.2 Quick-Pulse Programming Algorithm 5-131      | APPENDIX C:<br>LIST OF DC-DC CONVERTER                |
| High Performance Parallel Device Erasure 5-130     | APPENDIX B: V <sub>PP</sub> GENERATION CIRCUITS 5-145 |

**PAGE** 

**CONTENTS** 

APPENDIX A:

**CONTENTS** 

4.4 Reprogramming Routines ..... 5-129

4.4.1 Quick-Erase Algorithm .... 5-129
Algorithm Timing Delays ... 5-129

PAGE



#### 1.0 INTRODUCTION

Intel's ETOX II (EPROM tunnel oxide) flash memory technology uses a single-transistor cell to provide insystem reprogrammable nonvolatile storage. Reprogramming entails electrically erasing all bits in parallel and then randomly programming any byte in the array. This new technology offers designers alternatives for two of industry's needs: 1) a cost-effective means of updating program code; and 2) a solid-state approach for non-volatile data accumulation or storage.

#### This application note:

- introduces you to the concepts of in-system writing;
- discusses the hardware and software considerations for reprogramming flash memories in-system;
- offers a checklist for integrating Intel's flash memories into microprocessor- or microcontroller-based systems; and
- shows an example of an 80C186 design which incorporates flash memory.

#### 1.1 PROM Programmer vs System-Processor Controlled Programming

While soldered to a printed circuit board, one of two sources controls flash memory reprogramming: 1) a PROM programmer connected to the board, or 2) the system's own central processing unit (CPU). These are called on-board programming (OBP), and in-system writing (ISW), respectively. With OBP, the PROM programmer supplies the programming voltage (VPP) and the programming intelligence; with ISW, VPP is generated locally and the system itself drives the reprogramming process. Both methods offer a variety of benefits. However this application note focuses on ISW.

#### NOTE:

See Appendix A for OPB design considerations.

#### 1.2 Information Download and Upload

ETOX II flash memory technology programs extremely quick, permitting "on-the-fly" programming with unbuffered 19.2K baud data input. The remote ISW system handles the serial communication link for the host interface, as well as the flash memory reprogramming.

#### **Version Updates (Download)**

Flash memories enable code version updates using simple hardware designs. Beyond the basic system, a local V<sub>PP</sub> supply is all that is needed for remote code download.

A central host computer can download program code to many remote systems. Flash memory offers this capability without the drawbacks of other technologies. It is solid-state and nonvolatile, thus eliminating mechanical component wear-out (common with disk drives) and the risk of losing updates (a concern with battery-backed RAM). These aspects of flash memory offer major advantages in automated factories, remote systems, portable equipment and other applications. Finally, flash memories provide this capability at a much lower cost than byte-alterable EEPROM and battery-backed SRAM.

#### **Data Acquisition (Upload)**

Intel's flash memories allow single-byte programming for data accumulation applications. A remote data-logger uploads its information to a central host via serial link. The flash memory device is then in-system erased



Figure 1. These diagrams illustrate OBP and ISW. In OBP, a PROM programmer updates a system's flash memory. The ISW diagram shows a host updating remote flash memory via serial link. The remote system performs the flash reprogramming with its own CPU.



for resumption of data acquisition. This is useful in an advanced electrical power meter, for example. It could be configured to track and monitor power usage and report the data to a central computer for billing and utility management. This reduces the cost of manual door-to-door meter reading.

### 2.0 DEVICE FEATURES AND ISW APPLICATION CONSIDERATIONS

This section gives a brief overview of Intel's flash memory features and explains how they facilitate ISW design.

#### 2.1 Flash Memory Pinouts

The 32-pin DIP memory site is forward-compatible from the 256K bit to the 2 Mbit flash memory density. It fits into the 27C010 Mbit EPROM pinout and requires no multiplexed pins. Also, with just a single circuit-board jumper trace, a 28-pin EPROM can be placed in the lower pins of the 32-pin flash memory site. (See Figures 2A and 2B, Flash Memory Pinouts.) For more information on intertechnology pin compatibility see Ap Brief AB-25.



Figure 2A. Flash Memory Pinouts





Figure 2B. Flash Memory Pinouts



|                             | Bus<br>Cycles<br>Req'd | First Bus Cycle |                     |                     | Second Bus Cycle |                     |                     |
|-----------------------------|------------------------|-----------------|---------------------|---------------------|------------------|---------------------|---------------------|
| Command                     |                        | Opera-<br>ation | Addr <sup>(1)</sup> | Data <sup>(2)</sup> | Oper-<br>ation   | Addr <sup>(1)</sup> | Data <sup>(2)</sup> |
| Read Memory(3)              | 1                      | Write           | Х                   | 00H                 | Read             | Valid               | Valid               |
| Read Intelligent Identifier | 1                      | Write           | Х                   | 90H                 | Read             | 00/01H              | Ū                   |
| Set-Up Erase/Erase          | 2                      | Write           | Х                   | 20H                 | Write            | Х                   | 20H                 |
| Erase Verify                | 2                      | Write           | EA                  | A0H                 | Read             | Х                   | EVD                 |
| Set-Up Program/Program      | 2                      | Write           | Х                   | 40H                 | Write            | PA                  | PD                  |
| Program Verify              | 2                      | Write           | Х                   | C0H                 | Read             | Х                   | PVD                 |
| Reset(3)                    | 2                      | Write           | Х                   | FFH                 | Write            | Х                   | FFH                 |

#### NOTES

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

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

PA = Address of memory location to be read during program verify.

EVD = Data read from location EA during erase verify.

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

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

3. The second bus cycle must be followed by the next desired command register write, given the proper delay times.

#### 2.2 Command Register Architecture

#### **Simplified Processor Interface**

Intel's command register architecture simplifies the processor interface. The command register allows CE#, WE#, and OE# to have standard read/write functionality. All commands such as "Set-up Program" or "Program Verify" can be written with standard system timings. Raising Vpp to 12V enables the command register for memory read/write operation, while lowering Vpp below  $\rm V_{CC}+2V$  restores the device to a read only memory.

Writing to the register toggles an internal state-machine. The state-machine output controls device functionality. Some commands require one write cycle, while others require two. The command register itself does not occupy an addressable memory location. The register simply stores the command, along with address and data needed to execute the command. With this architecture, the device expects the first write cycle to be a command and does not corrupt data at the specified address. Table 1 contains a list of command register instructions.

The following sections describe the commands in relation to device operation. For more information on the command register see the appropriate flash memory data sheets, and Section 4.4 "Reprogramming Routines".

#### Read Memory Command-00H

This command allows for normal memory read operations with V<sub>PP</sub> turned on. After writing the command and waiting 6 µs, the CPU can read from the memory at system speeds. Once placed in the read mode no further action is required on the command register for subsequent read operations.

#### Read Intelligent Identifier Command-90H

Most PROM programmers read the device's intelligent identifier to select the proper programming algorithm. On EPROMs, raising A9 to the Vpp level configures the device for this purpose. Since this is unacceptable in-system, you can read the flash memory intelligent identifier by first writing command 90H. Follow this by reading address 0000 and 0001H for the manufacturer and device ID. Reset the device with the Read Memory command after you have read the identifier.

#### Set-Up Erase/Erase Commands—20H

Write this command (20H) twice in succession to initiate erasure. The first write cycle sets up the device for erasure. The device starts erasing itself on the second command's rising edge of Write-Enable. Erasure is stopped when the CPU issues the Erase Verify command or when the device's integrated stop timer times out. Integrated stop timers provide a safety net for complex system environments. In these environments, s/w timer accuracy may be difficult to achieve. Some method of timing is still required, however the timer need only meet a minimum specification (10 ms). This is far easier than calibrating a timer to meet both a minimum and maximum specification (10 ms  $\pm$  500  $\mu$ s).

#### NOTE:

Prior to erasure, it is necessary to program all bytes to the same level (data = 00H). See the Quick-Erase algorithm for more details.



#### Erase Verify Command—A0H

The erase command erases all bytes of the array in parallel. After each erase operation, all bytes must be verified to see if they erased. Write the Erase Verify command (A0H) to stop erasure and setup verification.

Alternatively, you may allow the internal stop timer to halt erasure. You must still issue the Erase Verify command to set up verification.

The device latches the address to be verified on the falling edge of WE# and the actual command on the rising edge. Wait 6  $\mu$ s before reading the data at the address specified on the previous write cycle.

The flash memory applies an internally-generated reference voltage to the addressed byte. Reading 0FFH from the addressed byte in this mode indicates that all bits in the byte are erased with sufficient margin to  $V_{CC}$  and temperature fluctuations.

If the location is erased, then repeat the Erase Verify procedure for the next address location. Write the command prior to each byte verification to latch the byte's address. Continue this process for each byte in the array until a byte does not return 0FFH data, or the last address is accessed.

In the case where the data read is not 0FFH, perform another erase operation. (Refer to Set-up Erase/Erase). Continue verifying from the address of the last verified byte. Once you have accessed the last address, erasure is complete and you can proceed to program the device. Terminate the erase verify operation by writing another valid command (e.g., Program Set-up).

#### Set-up Program/Program Commands—40H

Write this command (40H) twice in succession to initiate programming. The first write cycle sets up the device for programming. The device latches address and data on the falling and rising edges of the second write cycle, respectively. It also begins programming on the rising edge. You stop the programming operation by issuing the Program Verify command, or by allowing the integrated program stop timer to time out. This timer works similiar to the erase stop timer. Again, a minimum specification replaces a tougher minimum/maximum combination (10 µs-25 µs).

#### Program Verify Command—C0H

Flash memory devices program on a byte-by-byte basis. After each programming operation, the byte just programmed must be verified. Write the Program Verify command (COH) to stop programming and set-up verification. Should your software allow the integrated stop timer to halt programming, the software must resume the algorithm with the Program Verify command. The

device executes this command on the rising edge of Write-Enable. The program Verify command stages the device for verification of the byte last programmed. No new address information is latched.

The flash memory applies an internally-generated reference voltage to the addressed byte. Wait 6  $\mu$ s for the internal voltages to settle before reading the data at the address programmed. Reading valid data indicates that the byte programmed successfully.

#### Command Register Reset—FFH

Flash memories reset to the read mode during powerup, and remain in this mode as long as  $V_{PP}$  is less than  $V_{CC} + 2V$ . If your system leaves  $V_{PP}$  turned-on during a system reset, then incorporate a command register device reset into the hardware initialization routines. This is necessary because the CPU might be controlling programming or erasure when the system reset hits.

Write the reset command (0FFH) twice in succession to reset the device. The double write is necessary because of the state-machine reprogramming structure. For example, suppose the system is reset after a Set-up Program command. The flash memory state machine expects the next write cycle to contain valid address and data for programming, followed by another write cycle for program verification. The first Reset command will be mistaken for program data but will not corrupt the existing data. This is because the command (data = 0FFH) is a null condition for flash memory programming. Only data bits programmed to zero pull charge onto the memory cell and change the data. The second write cycle actually resets the device to the read function. Following the second reset cycle, you can write the next command (Read, Program Set-up, Erase Set-up, etc.).

If the  $V_{PP}$  supply is turned off upon system reset, the software reset is not required. The flash memory will reset itself automatically when  $V_{PP}$  powers down.

#### **Data Protection on Power Transitions**

The command register architecture offers another benefit in addition to simplified processor interface—during system power-up and power-down it protects data from corruption by unstable logic. Erasure or programming require  $V_{PP}$  to be greater than  $V_{CC} + 2V$  and the proper command sequence to be initiated. For example the CPU must write the erase command twice in succession. The odds of this occurring randomly are slim. Additionally, should  $V_{PP}$  ramp to 12V prior to  $V_{CC}$  ramping past 2.5V, the device will lock out all spurious writes and internally block 12V from the flash memory cells. For even greater security, you can switch  $V_{PP}$  as discussed in Section 3.13.



#### 2.3 V<sub>PP</sub> Specifications

Flash memories, like EPROMs, require a 12V externally-generated power supply for reprogramming. Intel's Vpp specifications 12.0V  $\pm 0.6$ V (5%) is compatible with most off-the-shelf (or available in-system) power supplies. (Note, Section 3.1 discusses Vpp generation techniques, and Appendix B shows different circuit alternatives.)

It is essential to use the specified V<sub>PP</sub> when reprogramming the flash memory device. Once the command to erase, program, or verify is issued, the device internally derives the required voltages from the V<sub>PP</sub> supply. The command register controls selection of internal reference circuitry tapped off of V<sub>PP</sub>. An improper V<sub>PP</sub> level causes the references to be wrong, degrading the performance of the part.

(When programming U.V. EPROMs,  $V_{CC}$  is raised to 6.5V. On flash memories, the  $V_{PP}$  reference circuitry and command register architecture provide the same function while keeping  $V_{CC}$  and  $V_{PP}$  at static levels. An incorrect  $V_{CC}$  level during U.V. EPROM programming poses similar hazards to improper  $V_{PP}$  levels on flash memories.)

The hardware design section discusses various methods for generating  $V_{\mbox{\footnotesize{PP}}}.$ 

#### 3.0 HARDWARE DESIGN FOR ISW

Covered in this section are the following:

- Description of ISW-specific functional system blocks including memory requirements
- V<sub>PP</sub> generation techniques
- Communication Considerations



Figure 3. System Block Diagram

#### System Level Hardware Requirements for ISW:

- · processor or controller
- limited amount EP/ROM or other flash memory devices for boot code, communications s/w, and reprogramming algorithms

- limited amount of RAM for variable storage (i.e., stacks, buffers, and other changing parameters)
- data import capability (i.e., serial line, LAN, floppy disk)
- flash memory for nonvolatile code or data storage needs
- V<sub>PP</sub> generator or regulator

All of the functional blocks in Figure 3 are typical of any embedded or reprogrammable system with the exception of the V<sub>PP</sub> generator. Some microcontrollers have on-chip EP/ROM, RAM and a serial port. With these devices, implementation of the ISW capability requires little additional hardware.

The next section discusses V<sub>PP</sub> generation techniques and communications design considerations.

#### 3.1 Vpp Generation

A static  $V_{PP}$  is needed to reprogram flash memories. The  $V_{PP}$  voltage can be generated by:

- 1) regulating it down from a higher voltage;
- pumping it up from a lower voltage (i.e., charge pump, DC/DC converter, etc.); or
- 3) designing or specifying the system's 12V supply with the required ISW tolerances and specifications.

Sufficient current for reprogramming should be considered when selecting your V<sub>PP</sub> generation option. Parallel reprogramming for flash memory in 16-bit or 32-bit systems will require, respectively, 2X or 4X additional current capability.

### 3.1.1 REGULATING DOWN FROM HIGHER VOLTAGE

 $V_{PP}$  is obtained from a higher voltage by using a linear regulator. Given the higher voltage, regulation offers the least expensive method of generating  $V_{PP}$ . Standard three terminal  $12V~\pm1\%,~\pm2\%,~\pm4\%$  non-adjustable regulators are available off-the-shelf. Some regulators have on/off control built-in. (See Appendix B,  $V_{PP}$  Circuit #1.) All regulators require a minimum input voltage greater than the output voltage. (See Appendix B,  $V_{PP}$  Circuit #2 and #3.)

#### 3.1.2 PUMPING 5V UP TO 12V

 $V_{PP}$  can be obtained by pumping  $V_{CC}$  and regulating it to the proper voltage. A voltage charge-pump can be designed and built by using a charge-pump integrated circuit and some discrete components (see Appendix B,  $V_{PP}$  Circuit #4) or by using a monolithic DC/DC converter (see Appendix A,  $V_{PP}$  Circuit #5).

When using adjustable circuits containing discrete components, design the output voltage so it falls within the  $V_{PP}$  specifications for all corners of the components'



skew (i.e.,  $V_{CC} \pm 10\%$ ; Rx  $\pm 1\%$ , Ry  $\pm 1\%$ , etc.). Include the resistors' temperature coefficients in the calculation matrix. Note that each of the various components can add error to the  $V_{PP}$  supply.

The monolithic DC/DC converter shown in Appendix B Circuit #5 fits into a 24-pin socket. It offers the advantages of close temperature tracking and ease of implementation. It has also been characterized at temperatures and meets all the Vpp specifications. Appendix C contains a partial list of vendors selling DC/DC converters.

Most DC/DC converters are only 50-60% efficient, so heat dissipation may be a concern. Some discrete boost circuits such as Appendix B, Circuit #4, offer much higher efficiency (70-85%). Circuit #4 as shown can supply 200 mA. Smaller inductor and capacitor component values and higher frequency boost convertors can be used where less power is required. For example, designs which reprogram one or two flash memories simultaneously might use the LT1172. (Contact Linear Technologies for more information.)

In all V<sub>PP</sub> generation methods, a capacitor on the input voltage terminals reduces the output noise voltage. Some power supplies (Appendix B, Circuits #3 and #4) specify a large-valued capacitor to decrease the Effective Series Resistance (ESR). Place a 0.1  $\mu$ F capacitor within 0.25 inches of each flash memory's V<sub>PP</sub> input (in addition the one on the V<sub>PP</sub> generator's input).

#### NOTE:

The ESR is inversely proportional to the capacitance value and the rated working voltage. To lower the ESR choose a capacitor with a large capacitance and a high working voltage (i.e., above 100V).

#### 3.1.3 ABSOLUTE DATA PROTECTION— VPP ON/OFF CONTROL

With  $V_{PP}$  below  $V_{CC}$  +2V or  $V_{CC}$  below 2.5V, internal circuitry disables the command register and eliminates the possibility of inadvertent erasure or programming. Switching the  $V_{PP}$  supply off provides the secondary benefits of improved power and thermal management.

There are two ways to switch VPP on and off:

- 1) directly switch the V<sub>PP</sub> generator's output, or
- switch the input voltage supplying the regulation circuit.

Any switching circuit will cause a voltage drop, so choose a switch with this drop in mind. Some power supplies have asymmetrical tolerances on 12V (i.e. +5%, -4%). Flash memory allows the 12V supply to drop as low as -5%. The 1% difference between the supply and the device requirement allows the switch to have an ON resistance voltage drop of 0.12V. Continuing with this example, assume the system only reprograms one flash memory at a time. The current through

the switch into the flash is  $I_{PP}=30$  mA. Solving for the allowable resistance across the switch: R=V/I=(0.12V)/(30 mA) = 4 Ohms. See Figure 4. Example Voltage Drop Across Switch. Note, one can reduce the effective  $R_{DS}$  (ON) by placing 2 or more FETs in parallel if necessary.



Figure 4

Controlling the input voltage of a DC/DC convertor with a MOSPOWER FET is another straightforward approach. (See Appendix B, Circuit #5.) Choose the FET switch carefully. It should have a very low on-resistance to minimize the voltage divider effect of the converter and FET switch. If the voltage across the FET switch is too high, the converter will not have the proper input voltage to meet its specifications. Always design the switching circuit with sufficient margin to maximum V<sub>PP</sub> and V<sub>CC</sub> load currents.

### 3.1.4 WRITES AND READS DURING V<sub>PP</sub> TRANSITIONS

After switching  $V_{PP}$  off, the CPU can read from the flash memory without waiting for the capacitors on  $V_{PP}$  to bleed off. To do this, write the Read Memory command prior to issuing the  $V_{PP}$ \_OFF instruction. Alternatively, the device resets automatically to read mode when  $V_{PP}$  drops below  $V_{CC}$  +2V.

Raising V<sub>PP</sub> to 12V enables the command register. You must wait 100 ns after V<sub>PP</sub> achieves its steady state value before writing to the command register. Remember that the steady state V<sub>PP</sub> settling time depends on both the power supply slew rate and the capacitive load on the V<sub>PP</sub> bus.

#### 3.1.5 OTHER VPP CONSIDERATIONS

The  $V_{PP}$  pin is an MOS input which can be damaged by electrostatic discharge (ESD). In OBP applications, an external power source supplies  $V_{PP}$  and then is removed. Electrostatic charge can build up on the floating  $V_{PP}$  pin. You can solve this problem by one of two means: 1) tie the pin to  $V_{CC}$  through a diode and pullup resistor (Figure 5a) or through a resistor to ground (Figure 5b). With either approach use a 10 K $\Omega$  or larger resistor to minimize  $V_{PP}$  power consumption.





Figure 5

#### NOTE:

Typically EPROMs require  $V_{PP}$  to be within one diode drop of  $V_{CC}$  for optimal standby power consumption. Either approach can be used with the flash memory.

ISW applications do not require this ESD protection as most regulators and charge pumps contain a voltage divider on the output stage. A divider provides a resistive path to ground even with the supply turned off. (Note: check the schematics of the V<sub>PP</sub> supply chosen.) However, if you directly switch the V<sub>PP</sub> supply, add the resistor to ground; the switch isolates the V<sub>PP</sub> pin and allows charge to build up.

#### 3.1.6 VPP CIRCUITRY AND TRACE LAYOUT

You should lay out Vpp circuitry and traces for high frequency operation since programming power characteristics exhibit an AC current component. Use the following standard power supply design rules:

- Keep leads as short as possible and use a single ground point or ground plane (a ground plane eliminates problems).
- Locate the resistor network (or a regulator) as close as possible to the adjustment pin to minimize noise pick-up in the feedback loop. The resistor divider network should also be as short as possible to minimize line loss.
- Keep all high current loops to a minimum length using copper connections that are as wide as possible. (This will decrease the inductive impedance which otherwise causes noise spikes.)
- Place the voltage regulator as close to the flash memory as practical to avoid an output ground loop. Excessive lead length results in an error voltage across the distributed line resistance.
- Separate the input capacitor return from the regulator load return line. This eliminates an input ground loop, which could result in excessive output ripple.

### 3.2 Communications—Getting Data to and from the Flash Memory

The flash memory does not care about the origin of the data to be programmed. The data could be downloaded from a serial link, parallel link, disk drive, or generated locally as in data accumulation applications.

While most systems communicate via serial link, sending a font to a printer's flash memory is an example of a parallel interface. In either format, designers must decide whether or not to buffer the incoming data. Errorfree serial protocols will require buffering for reconstruction of information packets. With equal capacity of RAM and flash memory in a system, the download time would only be limited by the speed of the communication link.

Both worst case and typical analysis must be done for real time download and un-buffered programming. The maximum transmission rate is 19.2K baud assuming worst case programming times. The time between characters at 19.2K baud is 520  $\mu$ s; the worst case byte programming time is approximately 0.5 ms (including software overhead). Typical byte programming takes 16  $\mu$ s which allows for much higher unbuffered transmission rates. However, a single byte can take up to the full 400  $\mu$ s specified time (plus software overhead), so you should not base transmission rate on typical programming times.

Partial buffering or FIFO schemes can also be implemented to increase transmission rates. An argument for buffering is reduction of interconnect time and costs.

#### 4.0 SOFTWARE DESIGN FOR ISW

Covered in this section are the following software requirements:

- system integration of ISW
- reprogramming considerations for single- and multiple-flash memory based designs.

### 4.1 System Integration—Boot Code Requirements

Boot code in remote systems should contain various ISW-specific procedures in addition to standard initialization and diagnostic routines.

The most dependable boot code for remote version updates contains some basic communications capability and the ISW reprogramming algorithms. Thus, a datalink disruption while reprogramming would be recoverable. For manufacturing flexibility, this boot memory could be an OBP 256K flash memory.



- 1. Bootstrap, and reset flash memory;
- Check "HOST\_INT" and "VALID\_AP" flags:
  - If HOST\_INT is inactive and VALID\_AP = 4150H, jump to application start address;
- 3. If VALID\_AP<>4150H, loop and wait for host (the link probably went down during update);
- 4. When "HOST\_INT" is active, vector to host interaction code.
  - (See next section.)



Figure 6. Example of ISW Integration to the Boot Sequence

An alternative to storing these routines in a separate boot device is storing them in the flash memory containing the program code. Prior to erasure, the CPU would transfer the ISW routines to system RAM and execute from there. This type of approach is suitable for battery-operated equipment or systems with back-up power supplies.

The communication link could be disrupted during reprogramming, leaving the device in an unknown configuration. Therefore, the boot code should reset the flash memory and check two ISW flags. The following section discusses the flag check concept.

#### 4.1.1 ISW FLAG CHECK

After resetting the flash memories and initializing other system components, the CPU should check the communications link for a host interrupt. We will call this the HOST\_INT flag. Had the communication link gone down prior to completion of downloading, then the host would have to re-establish contact to complete the task.

Assuming no HOST\_INT request has been made, the boot protocol then checks a data sequence in the flash memory signifying a valid application (VALID\_AP). You program this sequence into the memory array after confirmation of a successful download. If a download is interrupted midway through erasure or programming, then the VALID\_AP flag locations will not contain the VALID\_AP code. On the next system bootstrap the CPU recognizes this and holds up system boot until valid code is programmed. In Figure 6 an example flag protocol uses the VALID\_AP sequence of 4150H (ASCII codes for "AP").

### 4.2 Communication Protocols and Flash Memory ISW

The remote download communications protocol must guarantee accurate transmission of flash memory instructions and program code. This protocol can be as simple as a read-back technique or as complex as an error-free transmission protocol. (See Figure 7 for possible system-level flash memory instructions.)

A simple read-back technique optimizes download for boot code memory needs and ease of implementation. The embedded CPU echoes the flash memory instruction (i.e., Erase or Program) to the host, and waits for a confirmation prior to execution. After programming the update, the remote system checks the update by transmitting it back to the host for confirmation. The remote system then programs the VALID\_AP sequence. Note that programming and reading back 64 Kbytes at 19.2K baud takes about 0.57 minutes per direction:

(65,536 bytes) \* (10 bits/byte) \* (1 sec/19.2 Kbits) \* (1 min/60 sec) = 0.57 minutes.

Implementing either software- or hardware-based error-free communications protocol improves transmission efficiency. It eliminates the possibility of errant data being programmed if not buffered and checked, and optimizes the download process for transmission time. Additionally, file compression and decompression routines can improve the transmission rate.

General ISW instructions include:
STATUS CHECK
INITIATE REPROGRAMMING
MOVE ISW ROUTINES FROM FLASH MEMORY TO RAM
(If not resident in separate boot memory)
Data accumulation-specific commands include:
RETRIEVE DATA
ERASE FLASH MEMORY

Figure 7. Sample System-Level ISW Instruction Set



#### Status Check

The host should request a status update from the remote system prior to sending a reprogramming instruction. Depending on the response, the host may break the link and reconnect later, or it may send an erasure or data-upload command. This type of handshaking is necessary when system downtime for reprogramming might not be acceptable. An example of this is an automated factory where robots handle caustic chemicals.

### 4.3 Data Accumulation Software Techniques

Data can be accumulated in a remote environment with flash memory and then uploaded to a host computer for manipulation. You can adapt various standard datalogging techniques for use with flash memory. With any technique, you determine the next available memory location by reading for erased data (0FFH). This address would only be located once on system bootstrap and then recalled from RAM and incremented as needed.

Given a repeating data string of known length and composition, program start and stop codes at either end of the string. Do not pick 00H or 0FFH data for these codes because they are used during erasure. The start and stop codes enable the CPU to differentiate between available memory for logging and logged data equal to 00H or 0FFH.

For non-regular data input, you can address this same issue by programming the logged data followed by the variable identifier. Again, do not pick 00H or 0FFH data for the variable identifiers.

With any technique, the host computer separates and manipulates the data after the uploading operation.

#### 4.4 Reprogramming Routines

Intel's ETOX flash memories provide a cost-effective updatable, non-volatile code storage medium. The reliability and operation of the device is based on the use of specified erasure and programming algorithms.

Intel offers reprogramming software drivers to make it easy for you to design and implement flash memory applications. The software is designed around the CPU-family architectures and requires minimal modification to define your system parameters. For example, you supply the memory width (8-bit, 16-bit, or 32-bit), system timing, and a subroutine for control of Vpp.

#### NOTE:

Contact your nearest sales office for details.

If you prefer to implement the algorithms yourself, they are outlined in the device data sheets. Command register instructions required for the various operations are included in the data sheet flow charts.

The following sections describe both single-device and multiple-device parallel reprogramming implementations.

#### 4.4.1 Quick-Erase Algorithm

Flash memories chip-erase all bits in the array in parallel. The erase time depends on the V<sub>PP</sub> voltage level (11.4V-12.6V), temperature, and number of erase/write cycles on the part. See the device data sheets for specific parametric influences on reprogramming times.

Note that prior to erasing a flash memory device the processor must program all locations to 00H. This equalizes the charge on all memory cells insuring uniform and reliable erasure.

#### **Algorithm Timing Delays**

The Quick-Erase algorithm has three different time delays:

- 1) The first is an assumed delay when  $V_{PP}$  first turns on. The capacitors on the  $V_{PP}$  bus cause an RC ramp. After switching on  $V_{PP}$ , the delay required is proportional to the number of flash memory devices times  $0.1~\mu\text{F}/\text{device}$ .  $V_{PP}$  must reach its final value 100~ns before the CPU writes to the command register. Systems that hardwire  $V_{PP}$  to the device can eliminate this delay.
- 2) The second delay is the "Time Out TEW" function, where TEW is the erase timing width. The function occurs after writing the erase command (the second time) and before writing the erase-verify command. The erase-verify command or the integrated stop timer internally stops erasure.
  - TEW for ETOX II flash memories is a minimum of 10 ms. This delay can be either software or hardware controlled. Either way, the minimum nature of the timing specification allows for interrupt-driven timeout routines. Should the interrupt latency be longer than the minimum delay specification, the stop timer halts erasure.
- 3) The third delay in the erase algorithm is a 6  $\mu s$  time out between writing the erase verify command and reading for 0FFH. During this delay, the internal voltages of the memory array are changing from the



erase levels to the verify levels. A read attempt prior to waiting 6  $\mu$ s will give false data—it will appear that the chip does not erase. Repeatedly trying to erase verify the device without waiting 6  $\mu$ s will cause over-erasure. This delay is short enough that it is best handled with software timing. Again, note that the delay specification is a minimum.

#### **High Performance Parallel Device Erasure**

In applications containing more than one flash memory, you can erase each device serially or you can reduce total erase time by implementing a parallel erase algorithm. 7 You save time by erasing all devices at the same time. However, since flash memories may erase at different rates, you must verify each device separately. This can be done in a word-wise fashion with the command register Reset command and a special masking algorithm.

Take for example the case of two-device (parallel) erasure. The CPU first writes the data word erase command 2020h twice in succession. This starts erasure. After 10 ms, the CPU writes the data word verify command A0A0h to stop erasure and setup erase verifica-

tion. If both bytes are erased at the given address, then the CPU increments the address (by 2) and then writes the verify command A0A0h again. If neither byte is erased, then the CPU issues the erase sequence again without incrementing the address.

Suppose at the given address only the low byte verifies FFh data? Could the whole chip be erased? The answer is yes. Rather than check the rest of the low byte addresses independently of the high byte, simply use the reset command to mask the low byte from erasure and erase verification on the next erase loop. In this example the erase command would be 20FFh and the verify command would be A0FFh. Once the high byte verifies at that address, the CPU modifies the command back to the default 2020h and A0A0h, increments the address by 2, and writes the verify command to the next address.

See Figure 8 for a conceptual view of the parallel erase flow chart and Appendix D for the detailed version. These flow charts are for 16-bit systems and can be expanded for 32-bit designs.



Figure 8. High Performance Parallel Erasure (Conceptual Overview)

<sup>7.</sup> Parallel Erasure and Programming require appropriate choice of V<sub>PP</sub> supply to support the increased power consumption.



#### 4.4.2 Quick-Pulse Programming Algorithm

Flash memories program with a modified version of the Quick-Pulse Programming algorithm used for U.V. EPROMs. It is an optimized closed-loop flow consisting of 10  $\mu$ s program pulses followed by byte verification. Most bytes verify after the first pulse, although some may require more passes through the pulse/verify loop. As with U.V. EPROMs, this algorithm guarantees a minimum of ten years data retention. See the device data sheets for more details on the programming algorithm.

#### **Algorithm Timing Delays**

The Quick-Pulse Programming algorithm has three different time delays:

 The first and third—V<sub>PP</sub> set-up and verify set-up delays—are the same as discussed in the erasure section. In this case the third delay is for the transition between writing the Program Verify command and reading for valid data.  The second delay is the "Time Out 10 μs" function, which occurs after writing the data and before writing the program-verify command. This write command internally stops programming. The section entitled "Pulse Width Timing Techniques" gives 86family assembly code for generating a 10 μs timer routine.

#### **High Performance Parallel Device Programming**

Software for word- or double-word programming can be written in two different manners. The first method offers simplicity of design and minimizes software overhead by using a byte programming routine on each device independently. Here you increment the address by 2 or 4 when addressing 1 of 2 or 4 devices, respectively. The second method offers higher performance by programming the word or double-word data in parallel. This method manipulates the command register instructions for independent byte control. See Figure 9 for conceptual 2-device parallel programming flow chart and Appendix E for the detailed version.



Figure 9. Parallel Programming Flow Chart (Conceptual Overview)



#### NOTE:

Word or double-word programming assumes 2 or 4 8-bit flash memory devices.

Parallel Programming Algorithm Summary:

- Decreases programming time by programming 2 flash memories (16 bits) in parallel. The algorithm can be expanded for 32-bit systems.
- Eliminates tracking of high/low byte addresses and respective number of program pulses by directing the CPU to write data-words (16-bit) to the command register.
- Maintains word write and word read operations. Should a byte on one device program prior to a byte on the other, the CPU continues to write word-commands to both devices. However, it deselects the verified byte with software commands. An alternative is to independently program high and low bytes using hardware select capability.

#### 4.4.3 Pulse Width Timing Techniques

Software or hardware methods can be used to generate the timing required for erasure and programming. With either method you should use an in-circuit emulator (ICE<sup>TM</sup>) and an oscilloscope to verify proper timing. Also remove the flash memory device from the system during initial algorithm testing.

#### **Software Methods and Examples**

Software loops are easily constructed using a number of techniques. Timing loops need to be done in assembly language so that the number of clock cycles can be obtained from the instructions.

In order to calculate a delay loop three things are needed—

- 1) processor clock speed,
- 2) clock cycles per instruction, and
- 3) the duration of the delay loop.

As an example, the 80C186 divides the input clock by 2. With a 20 MHz input clock the processor's internal clock runs at 10 MHz. This translates to a 100 ns cycle time. Delays can be made by loading the CX register with a count and using the LOOP instruction. The

LOOP instruction takes 16 clock cycles to execute per pass. It decrements the CX register on each pass and jumps to the specified operand until CX equals zero.

When writing a delay loop consider all instructions between the start and end of the delay. If a macro is written that delays 10  $\mu$ s, add the clock cycles for all instructions in the macro.

Here is an example of a 10  $\mu$ s delay and the calculation of the constant required for a 10 MHz 80C186.

```
WAIT_10 μs:
                            ;10 clock cycles
         push cx
         mov cx,DELAY
                            :4 clock cycles
         loop $
                            :see calculation
         рор сх
                            ;10 clock cycles
1. Start to End
                   = 10 us/cycle time
                   = 10 \,\mu s / 100 \, ns
                   = 100 cycles
2. Loop Instruction = 100-24 cycles
                   = 76 cycles
3. Loop Cycles
                   = 76
                   = (15 \times [DELAY - 1] + 5)
4. Solving for DELAY = 6
```

#### Hardware Methods

Using an Internal Timer-

Many microcontrollers and some microprocessors have on-chip timers. At higher input clock speeds these internal timers have a resolution of 1  $\mu s$  or better. The timers are loaded with a count and then enabled. The timer starts counting and when it reaches the terminal count a bit is set. The CPU executes a polling algorithm that checks the timer status. Alternatively, a timer-controlled interrupt can be used. After the timer has been set and the interrupt enabled, the CPU can be programmed to wait in idle mode or it could continue executing until the timed interrupt.



One thing to take into account when using interrupts is the time required for the CPU to recognize and interrupt request (interrupt latency). This is important when figuring the timer value, because the time seen by the part will be the programmed delay plus the minmum interrupt latency time.

The 80C186 has three 16-bit timers on-chip. Timer #2 can be a prescaler for the other two timers, which extends timers #0 and #1 range out to  $2^3$ 2. By using two timers,  $10 \mu s$  pulses and 10 ms pulses can be easily achieved.

#### Using an External Timer-

External timers can take many forms. One popular example is the 82C54 (CHMOS Programmable Interval Timer) which has three 16-bit timers on-chip. One timer can be used as a prescaler for the others so that a count of 2^32 can be achieved as with the 80C186 internal timers.

#### 5.0 SYSTEM DESIGN EXAMPLE: AN 80C186 DESIGN

A general purpose controller and/or data acquisition system was built to demonstrate 86-based ISW. The 80C186 CPU drives the system, which contains 16 Kbytes of EPROM (two 27C64's), 64 Kbytes of flash memory (two 28F256A's), 64 Kbytes of SRAM (two 32K x 8's) three 8-bit ports (82C55A), one serial port (82510), and a 5V to 12.0V DC/DC converter. Three 74HC573's demultiplex the address/data bus and latch the byte high enable line (BHE#) and the status lines (if needed). Two data transceivers (74HC245) simulate the worst case data path for a system requiring added drive capability. If the transceivers are not needed they can be replaced with wired headers. See Appendix F for detailed schematics parts list, and changes for the 28F512 or 28F010.

The 80C186 reset (output) drives the reset input on the 82510, 82C55A, and the OE# inputs on the address latches and data transceivers. The reset line goes inactive 5 clock cycles before the first code fetch. Also, the CPU's write signal is split into byte-write-high and byte-write-low to allow for byte or word writes.

The 80C186 has on-chip memory and peripheral chip selects. Two of the memory chip selects are dedicated. One is the Upper Chip Select (UCS#, dedicated for the boot area) and the second is the Lower Chip Select (LCS#, for the interrupt vector table area). See the memory map in Figure 10.



Figure 10. 80C186 Memory Map

The permanent code was placed in an EPROM in the UCS memory segment; this code includes routines for hardware initialization, communications, data uploading and downloading, erasure and programming algorithms, I/O drivers, ASCII to binary conversion tables, etc. This would be useful for systems reconfigured for different communication protocols as the last step prior to shipment.

Code and constants that might change are placed in the 64 Kbytes of flash memory. Application examples include operating systems, code for rapidly advancing biomedical technologies such as blood test software, engine-control code and parameters, character fonts for printers, postage rates, etc. The RAM is used for the interrupt table, stack, variable data storage, and buffers

The three 8-bit ports on the 82C55A peripheral controller can be used for control and/or data acquisition. It powers-up with all port pins high. Similarly, all port pins go high after warm resets as well. Because the pins are high after a power-up/reset, an open collector invertor was used to control the MOSPOWER switch which in turn controls V<sub>PP</sub>. You must drive the FET switch to one rail or the other to guarantee its low on-resistance. V<sub>PP</sub> is turned off during power-up or reset as a hardware write protection solution. The DC/DC converter supplies V<sub>PP</sub>.

The 82510 is a flexible single channel CHMOS UART offering high integration. The device off-loads the system and CPU of many tasks associated with asynchronous serial communications.



The part can be used as a basic serial port for the host serial link, or can be configured to support high speed modem applications. For more information on the 82510 see the 82510 data sheet and AP-401 "Designing with the 82510 Asynchronous Serial Controller".

Software was written to download code and data parameters (code updates) from a PC to the demo board through the PC's COM1 port (serial port). The system also can upload data (remote data acquisition) to the PC via the same link.

Once the download code and data has been programmed it can not be lost, even if power should fail. This is because Intel's ETOX II flash memory technology is based on EPROM technology and does not need power to retain data.

The end result: rugged, solid state, low power nonvolatile storage.

#### 6.0 SUMMARY

Intel's flash memories offer designers cost-effective alternatives for remote version updates or for reliable data accumulation in the field or factory. Designers will also benefit from time savings in any kind of code development—no 15 minute waits for U.V. EPROM erasure.

This application note covers the basics of in-system writing to flash memories and can be used as a check list for systems other than the 80C186 design shown. The basic concepts remain the same: a CPU controls the reprogramming operations; a 12V supply must be applied to the flash memory for erasure and programming; and a communications link connects the host to the remote system and supplies the code to be programmed.



# APPENDIX A ON-BOARD PROGRAMMING DESIGN CONSIDERATIONS

5



#### INTRODUCTION

On-board programming<sup>1</sup> (OBP) with Intel's flash memory provides designers with cost reduction capabilities for alterable code storage designs. When used in conjunction with on-board programming, flash memory presents opportunities for savings in two areas: greater testability in the factory, which translates to improved outgoing quality and reduced return rate; and quicker, more reliable field updates, which translates to decreased product support cost.

#### This appendix:

- outlines the design considerations associated with on-board programming, and the improvements afforded by Intel's flash memory;
- offers guidelines for converting current 64K EPROM OBP designs;
- designs an 8-bit system for on-board programming;
- suggests some 16-bit flash design considerations; and offers information on OBP equipment and vendors.
- 1. With on-board programming, non-volatile memory is programmed while socketed or soldered on the application board, rather than before hand as a discrete component. This programming method is also called in-module or in-circuit programming, and has been practiced by some major corporations since 1981. See sidebar on following pages for more information on U.V. EPROM OBP usage.



On-Board Programming Manufacturing Example—A printer is customized via OBP for international markets: 1. printer assembly completed, diagnostics code programmed and tested, and unit stored in inventory; 2. order arrives for printer with foreign language font; 3. diagnostics code flash-erased, and desired font programmed; 4. printer ships to customer.

### INTEL'S FLASH MEMORY—DESIGNED TO MEET YOUR OBP NEEDS

Intel's flash memory simplifies OBP code updates by offering designers the command register architecture. As described in section 2.2, this architecture offers the full reliability of EPROM off-board programming without the hassles of elevating V<sub>CC</sub>.

### 5 Volt Vcc Erasure and Programming Verification

Unlike EPROM OBP, flash memory enables Vcc to remain at 5.0V throughout all operations. Internal circuitry derives the erasure and programming verification levels from the voltage on Vpp rather than from Vcc. These verify modes enable use of a single Vcc bus for the entire board, as opposed to the two buses needed for U.V. EPROM OBP. (See sidebar entitled EPROM OBP).

#### **EPROM OBP**

EPROM OBP has been a proven manufacturing technique since 1981. Ingenuity and clever circuit design have enabled manufacturers to overcome the hurdles associated with OBP and enjoy the benefits.

In many cases, Intel's flash memory simplifies today's solutions and offers new capabilities to advance the state of OBP technology. The following paragraphs outline the hurdles and a few of the solutions in use today.

EPROMs require program verification at an elevated  $V_{CC}$  to insure long-term data retention. PROM programmers easily accommodate this requirement, and it is generally invisible to the end-user.



#### REPLACING CURRENT EPROM OBP DESIGNS WITH FLASH MEMORY

#### **Hardware Considerations**

A slight hardware modification is required to adapt most of the current EPROM OBP designs for use with Intel's flash memory. Simply convert the EPROM memory sites from 28 to 32 pins. All other board-design cirteria used for EPROM OBP apply to flash memory as well. (For discussions of these criteria see section entitled New OBP Designs).

Standard EPROM OBP requires the board designer to bus PGM# to the edge connector. With flash memories' command register architecture, this same trace enables electrical erasure and programming, only now the line is called Write Enable (WE#). The timing for WE# is similar to that of read accesses, although that is handled via software changes.

Another potential hardware change is on the board programmer side of the design-the V<sub>PP</sub> supply. Many EPROMs program with 12.5-13.0V V<sub>PP</sub> supplies. Intel's ETOX II flash memory requires 11.4-12.6V V<sub>PP</sub>. This change should not be an issue since the V<sub>PP</sub> supply on many board programmers is programmable.

Mixed memory systems containing both conventional U.V. EPROM and flash memories require special consideration. This type of memory design requires separation of the Chip Enable (CE#) control lines between the EPROM and flash devices to allow for independent reprogramming control and access. The PGM# and

WE# lines can be common if the board programmer can give the appropriate timings to either type of device

#### Software Considerations

Manufacturers who program EPROMs on-board today will need new board-programmer software to take advantage of flash memory's feature set, specifically software for the Quick-Erase and Quick-Pulse Programming algorithms.

#### Benefits of Converting Your EPROM OBP Design to Flash

The most pressing reason to convert from a standard EPROM to flash memory is the total cost savings. To appreciate this, you must consider your way of doing business at the board and system levels-from the factory to installation and repair in the field. In the factory, boards can be tested with a diagnostics program in the flash memory and then erased and reconfigured for shipment in the same step. Improved testing will decrease the probability of field failures and costly customer returns. Simplified test and rework methods will decrease your inventory holding costs. Also, if in the process of converting to flash memory you include the ability to OBP via a cable-connector, service calls for code updates will be quicker, more reliable, and cost less money. Your serviceman would simply connect the programming equipment to the system without dismantling it to remove the EPROMs. (See section entitled The System/Board-Programmer H/W Connection for details.)

#### EPROM OBP (cont'd)

With OBP, the EPROM board-programmer handles the elevated- $V_{CC}$  requirement easily as well. However, when  $V_{CC}$  is greater than 5V, logic devices populating the same board may draw excessive current and not operate predictably.

One solution to this issue involves running separate  $V_{\rm CC}$  traces to the board's edge connector—one for EPROM programming, and one for powering up the rest of the board.

A second consideration when designing for EPROM OBP has been accessing manufacturer and device codes.

The identifier mode requires forcing A9 to 12V. This translates to adding extra isolation, which implies the increased costs of buffers and extra board space.



#### **NEW OBP DESIGNS**

#### **Design Considerations**

As with EPROM in-circuit programming, flash memory board programming requires the use of a board-programmer. Unlike U.V. erasure for standard EPROM OBP, electrical erasure enables flash memory OBP without removing the board from the system.

We will look at designing a board that is to remain powered-up in the system during erasure and reprogramming. The key concept is to design the board in such a way that the programmer can take control of the system during code updates. The implementation of such a design is straightforward, easy, and suited to automated production assembly.

#### **Taking Control**

The board-programmer needs to take control of the system's address bus, data bus, control lines, etc. to update the code without damaging the system. (See Figure 2. System to Board-Programmer Interface.) Taking control simply means isolating the rest of the system from these lines.

Various methods of isolating the memory from the system include using tristate buffers, latches, or even the capabilities designed into microprocessors ( $\mu P$ ) and microcontrollers ( $\mu C$ ). For example, Intel's 86-based  $\mu P$  family has HLD/HLDA signals that were set-up for multiprocessor system designs where bus control is a major concern. The HLD signal, when acknowledged, tristates the address, data, and control lines. Although not designed for multiprocessor environments, Intel's MCS®-51 and MCS-96 microcontroller families have Reset capabilities to help simplify this same task.

One issue to be aware of when using a CPU's reset control function is that it may switch from the reset to active condition at a non-standard logic level. This only presents a problem if the address/data buffer takes longer to activate than the CPU, and the CPU attempts to fetch code from a memory device isolated from it.

One approach to insure successful programming takeover (i.e. without bus contention) is to have the boardprogrammer's lines in a high impedance state during connection to the system. Once connection to the system has been secured, the serviceman could hit a button on the board-programmer to start the system takeover procedure. Then when total control has been established, the programmer would commence with erasure and reprogramming.

Aside from the flash device's isolation from the system, various CPU control lines (MEMRD#, WE#, PSEN#, etc.) may need isolation as well. If active during Reset, these lines may put the CPU into an unspecified state. When designing a board for OBP, check the  $\mu$ C/ $\mu$ P data sheets carefully for any special reset conditions.

### Printed Circuit Board Guidelines for $V_{CC}$ and $V_{PP}$

Programming conventional EPROM and flash memories takes 30 mA of current on  $V_{CC}$  and  $V_{PP}$ , due to the nature of hot-electron injection. Most of the charge transfers to the memory cell's floating gate in a short current spike during the first pulse. You should design both the  $V_{CC}$  and  $V_{PP}$  traces with A.C. current spikes in mind. Wherever possible, limit the inductance by widening the two traces. Bypass capacitors  $(0.1~\mu F)$  should be placed as close as possible to the memory device's  $V_{CC}$  and GND pins, as well as the devices  $V_{PP}$  and GND pins. The capacitor on  $V_{CC}$  decreases the power supply droop. The capacitor on  $V_{PP}$  supplies added charge, and filters and protects the memory from high frequency over-voltage spikes<sup>2</sup>.

For a complete discussion of electrical noise, grounds, power supply distribution and decoupling see Ap-74—High Speed Memory System Design Using the 2147H, and AP-125—Designing Microcontroller Systems for Electrically Noisy Environments.

#### **EPROM OBP (cont'd)**

Some users of OBP get around this issue by programming all EPROMs with a common algorithm. However, this practice compromises the device's reliability, and should not be done.

A better solution than ignoring the identifier is to choose a qualified EPROM vendor and program with its algorithm only.

One subtle concern with EPROM OBP that designers often overlook is U.V. board erasure.

→ U.V. EPROM board erasure requires removal of the board from its host system. This incurs the hidden costs of labor, lower yields due to handling, and the reliability risks of dismantling a system. Flash memory decreases these costs by enabling a greater degree of factory automation, and increases the flexibility afforded by OBP.





During normal system read operation, all interface traces are left open-circuited. Some of the lines have pull-downs or weak pull-ups to insure proper device operation.

Figure 2. System to Board-Programmer Interface

#### **EPROM OBP (cont'd)**

- → Special U.V. board erasers must be purchased, at significant costs and with limited throughput. A low-end U.V. bulb costs \$75-\$100 each. A U.V. board eraser system could cost upwards of \$10,000, with recurring costs of light bulbs and energy. Thus, the cost of U.V. erasure is often under-estimated.
- → Although portable board programmers are commercially available, U.V. lights by nature are not very rugged, and are not suited for out-of-factory code updates. This complicates field service.
- → Erasure can be easily controlled in a lab environment; however, it is not as clear on the manufacturing floor which label to remove for U.V. erasure, because parts other than EPROMs have windows (i.e. EPLD's, microcontrollers with embedded EPROM memory, etc.)



### The System/Board-Programmer Hardware Connection

In most U.V. EPROM OBP applications, designers use the board's edge-connector as the programmer interface. This approach is the lowest cost solution for standard EPROM technology because U.V. erasable devices require system disassembly for erasure anyway. With flash memory, you can eliminate the system dismantling and capitalize on the erase feature by adding a cable connector to the board for reprogramming purposes. The connector should extend from the board through the system's chassis, and should be easy to reach by a serviceman.

Various types of cables exist on the market that could be used to connect programming equipment to the system. The key design consideration when choosing the type of cable is elimination of all transient noise that would interfere with the programming or erasure process.

Three types of noise interference and methods to diminish the noise are as follows:

- line to line cross-talk (due to board-programmer's drivers that drive sharp step functions on adjacent address lines); solved with either ribbon cables, having alternate lines grounded, or with braided twistedpairs that have a ground line for each active signal;
- 2. programmer line-driver-to-board impedance mismatches leading to transmission line effects of signal reflection, and interference; solved by limiting cable length, decreasing programmer switching speed (or allowing longer settling time between address switches) or by using matched line drivers on the programmer and high impedance buffers on the board end, or by using series termination resistors on the driving end of the cable (i.e.—board-programmer end, with the exception of the bi-directional data bus which needs series resistors at both ends);
- f pick-up in electrically noisy environments; use either shielded cable such as coax, ribbon cable with solid copper ground plane, or a new type that has recently become available called Flex cable.

Braided twisted-pair cables when kept under three feet in length generally reduce cross-talk to acceptable levels. This type of cable offers the most cost-effective solution which works well in most applications. Depending on the environment, the programmer and your design, you may need a combination of solutions, such as braided twisted-pairs with series termination. At first all of these alternatives may seem expensive or superfluous, but keep in mind that the cost of a single cable and programmer gets amortized over the total number of systems programmed.

#### AN 8-BIT BUS DESIGN EXAMPLE

An example of an in-circuit reprogrammable controller board is an 80C31, two 28F256A's and some glue chips. (See Figure 3. for a system block diagram. See Appendix A. for a detailed system schematic.)<sup>3</sup> The important issues for erasure and reprogramming are as follows:

- 1. the board-programmer must have uncontested access and control of the flash memory array; and
- 2. the microcontroller must be reset (un-active) during the erasure and programming cycles.

#### SYSTEM DESIGN

#### **Bus Control Circuitry**

The 80C31 has an active-high reset pin, which tristates the address and data bases. Route this line (RESET) to the programming connector. Tie the OE# pins on the low-order address latch (74HCT573), and the PSEN# buffer-enable (74HCT125)4 together, and route that line MEMWR<sup>5</sup> to another pin on the programmer-interface connector.

During normal system operations when the  $\mu$ C reads program code from the 28F256 devices, the pull-down on MEMWR keeps the address latches and PSEN# buffer active. During flash memory OBP, the board-programmer drives MEMWR active-high, which disables these outputs, and isolates the address bus and PSEN# from the programming signals.

The board-programmer must independently control the RESET and MEMWR traces because they disable at different  $V_{IL}$  values (2.5V for RESET vs 0.8V for MEMWR). If controlled by the same 5V supply, on power-up or after a reset condition the  $\mu$ C would try to execute code while still isolated from its code source—specifically before the address latches and PSEN# buffer activate.

#### **Address Decode Circuitry**

This design shows two 28F256A flash memories. Systems with more than one memory device typically decode the CPU's high-order address to select a particular device.

5. MEMWR = > bus isolation control of PSEN# and the data bus.

<sup>3.</sup> Note that the flow-through latch on the data bus is not needed with the 80C31, but is drawn as an example for CPU's that can not tristate their data bus.

<sup>4.</sup> The isolation buffer is required on PSEN# in this design because the 80C31 goes into unspecified states when the Reset and PSEN# lines are active simultaneously. To avoid any possible problems, buffer PSEN#.

PS1

CE#

A15

A0-A14

MEMEN#

15

CE#

A0-A14

,∙15

AP-316

A15

Reset

A<sub>8</sub> - A<sub>15</sub>



This is accomplished as illustrated. When A15 is low, the lower 32K bytes are selected. The output of the inverter drives the other 28F256A's chip enable. This type of memory architecture promotes power savings by disabling all memories but the one being addressed.

To accomplish this two-line memory control architecture, route the inverter's input A15 to the 80C31 and to the programmer interface connector. The board-programmer controls the inverter's output enable with MEMEN#. The MEMEN# line performs the function normally performed by CE# in component programming. When driven to a logic "1" level MEMEN# pulls the inverter's output high. This deselects all memory devices controlled by that I.C. During normal read and standby operations, the pull-down on MEMEN# keeps the decoder enabled.

#### **Erasure and Programming Control Circuitry**

In this design,  $V_{PP}$  and WE# are active only during reprogramming. At other times, the two inputs would be inactive. Simply tie the WE# line to  $V_{CC}$  through a pull-up resistor. The pull-up limits the current to the board programmer during reprogramming. (Recall that WE# is active low.) Flash memories allow  $V_{PP}$  to be at 12V,  $V_{CC}$  or ground for read operations. This design ties  $V_{PP}$  to  $V_{CC}$  through a diode and resistor to allow for EPROM OBP compatibility. If this option is not required, simply tie  $V_{PP}$  to ground through a current-limiting pull-down resistor.

#### **Returning Control to the Host System**

The board-programmer should return system-control to the host processor in an organized manner. First it should lower V<sub>PP</sub> from 12V to 5V, or ground. Then the board programmer should place its address and data

buses into a high impedance state. Next PS2, which controls MEMWR should be tristated thus disabling the PSEN #/Address latch isolation. Finally the board-programmer should switch PS1, which drives the RE-SET line to reactivate the  $\mu$ C. This sequence guarantees that the  $\mu$ C will begin operation at a known program code location.

### 16-BIT BUS DESIGN CONSIDERATIONS

An example of an On-Board programmable 16-bit system board would be an 80C186 microprocessor, two 28F010 flash memories, RAM, and some glue chips. The basic hardware design considerations would be the same as those in the previously discussed 8-bit bus example.

There are a few issues with 16-bit designs that do not arise in 8-bit designs. For the programmer to take control of the system, it must tristate and reset the  $\mu P$  as well as tristate the bus buffers and latches. The HOLD and RESET lines of Intel's 86-based family of microprocessors have been designed with bus isolation in mind for use in multiprocessor systems.

The designer has two options for erasing and programming the high and low bytes of the flash memory array independently.

- 1) The designer can route two WE# lines to the programmer connector—BYTE HIGH WE# and BYTE LOW WE#.
- 2) The reprogramming software can follow the masking procedure shown in section 4.4. This method allows a common WE# line for the high and low bytes.

<sup>8.</sup> Note the lack of isolation buffers between the 80C31's high order addresses (Port 2) and the board-programmer interface, compared to the latch separating the low order addresses (Port 0) and the interface. In this design example, we make use of the 80C31's ability to tristate these ports, so no isolation is needed for any of the addresses. The latch on Port 0 is for the time-multiplexed address/data architecture of this microcontroller, and not specifically for isolation.

9. MEMEN = memory enable, active low.





Figure 4. Detailed 8-Bit Bus Design Schematic



#### **OBP EQUIPMENT AND VENDORS**

If you are considering OBP for your next design, and have not used on-board programming before, you will need to choose a board-programmer vendor. Various suppliers offer OBP systems; therefore, it is well worth it to send out requests for programming support bids. If your production volume justifies the purchase of more than one board-programmer, you may want to negotiate a non-recurring engineering charge for development cost, followed by variable costs for additional units.

Most vendors offer a variety of basic systems, designed to easily adapt to your needs. Systems can be purchased that program either single boards serially, or a number of boards in parallel. Light-weight OBP equipment designed for field reprogramming can also be obtained from some of the vendors.

Most companies will work directly with you at the beginning of your design phase to ensure OBP compatibility. If your design is beyond the definition stage, the programmer manufacturer will request a copy of your schematics or block diagrams under non-disclosure. The vendor has an OBP design specialist that will check the design for OBP compatibility. Any potential problems will be located and corrected at this early stage.

Every board's architecture is different (i.e., based on different central processing units (CPU), decoding schemes, buffering methodologies, interface connectors, and types and densities of memories). Vendors write custom software modules for each application. Also, the vendor or the board designer typically builds an interface jig to connect the board's edge connector to the programmer. This choice is often left as a decision for the designer.

### Partial List\* of Companies Selling Board-Programmers

Following are a few of the companies who offer onboard programming solutions today:

Data I/O Corp.
Digelec
Elan Digital Systems
Oliver Advanced Engineering, Inc.
Stag Microsystems, Inc.

\*This list is intended for example only, and in no way represents all companies that support on-board programming. Intel Corporation assumes no responsibility for circuity other than circuitry embodied in an Intel product. No other circuit patent licenses are implied.

#### **SUMMARY**

- On-board programming (OBP) has been around since 1981.
- Designing a board for OBP can be easily done by working with a board-programmer vendor's OBPdesign-specialist during the initial design phase.
- In-circuit alterable code storage can be easily implemented by using flash memory and it's features.
- Time and money savings can be realized in a number of ways by taking advantage of flash memory OBP:
- Oecreased board costs and improved reliability from elimination of EPROM sockets;
- Oecreased manufacturing costs from elimination of board eraser depreciation costs, recurring U.V. light bulb and energy expenses;
- Oecreased inventory expense from simplified test and rework methods (one-step diagnostics, erasure, and board configuration);
- Oecreased product costs based on decreased board-handling loss;
- Improved board diagnostics and testability leading to higher quality and decreased customer returns; and
- <> Quicker, more reliable field code updates.



# APPENDIX B VPP GENERATION CIRCUITS

Circuit #1-Regulation from a higher voltage

Circuit #2-Regulation from a higher voltage

Circuit #3—Regulation from a higher voltage

Circuit #4-5V to 12V Boost

Circuit #5-5V to 12V Boost

Circuit #6-Monolithic DC/DC Convertor

For more detailed information on V<sub>PP</sub> generation circuits, see AP-357 titled Power Supply Solutions for Flash Memory (Order Number 292092).

#### Circuit #1



\*Cost approximations assume 10,000 piece quantity.



#### Circuit #2



#### Circuit #3





#### Circuit #4





#### Circuit #5



#### **NOTES:**

- 1. The capacitor decreases output noise to 140 mV pk-pk.
- 2. We added the Buz11A Mospower nFET to enable/disable the converter. This control minimizes power consumption which under full load can reach 600 mA.
- 3. The voltage drop across the switch is 0.1V. Due to this drop the PM7006 will not maintain the  $V_{PP}$  spec with 10% fluctuations in  $V_{CC}$  supply.
- \*Cost approximations assume 10,000 piece quantity.



## APPENDIX C LIST\* OF DC-DC CONVERTER COMPANIES

AT&T MICROELECTRONICS†

3000 Skyline Drive Mesquite, TX 75149 Tel: (800) 526-7819 Fax: (214) 284-2317

**BURR-BROWN CORP.**†

P.O. Box 11400 Tucson, AZ 85734 Tel: (800) 548-6132 Fax: (602) 741-3895

LINEAR TECHNOLOGY CORP. A

1630 McCarthy Blvd. Milpitas, CA 95035 Tel: (408) 432-1900 Fax: (408) 434-0507

MAXIM INTEGRATED PRODUCTSA

120 San Gabriel Drive Sunnyvale, CA 94086 Tel: (408) 737-7600 Fax: (408) 737-7194

MOTOROLA INC.Δ 2100 E. Elliot Rd. Tempe, AZ 85284

Tel: (800) 845-6686

NATIONAL SEMICONDUCTOR CORP.

Mt. Prospect, IL 60056 Tel: (800) 628-7364 Fax: (800) 888-5113

SHINDENGEN AMERICA, INC.†

2649 Townsgate Rd., Suite 200 Westlake Village, CA 91361

Tel: (800) 634-3654 Fax: (805) 373-3710

SILICONIX INC. Δ

2201 Laurelwood Rd. Santa Clara, CA 95056 Tel: (800) 554-5565 Fax: (408) 727-5414

TOKO AMERICA, INC.† 1250 Feehanville Drive Mount Prospect, IL 60056 Tel: (708) 297-0070

Fax: (708) 699-7864

VALOR ELECTRONICS† 6275 Nancy Ridge Dr.

San Diego, CA 92121 Tel: (619) 458-1471

\*This list is intended for reference only, and in no way represents all companies that support power conversion products. Since this industry develops many new solutions each year, Intel recommends that the designer contacts the vendors for the latest products. Intel will continue to work with the industry to develop optimum solutions for power conversion. Intel Corporation assumes no responsibilities for circuitry other than circuitry embodied in Intel products. No other circuit patent licenses are implied.

†Monolithic Solutions ΔDiscrete DC to DC Converter Solutions



# APPENDIX D PARALLEL ERASE FLOW CHART





#### **Device Erase Verify and Mask Subroutine**



NOTE:

\*Masking can easily and efficiently be done in assembly languages. Simply load word registers with the incoming flash data (F\_DATA), the erase commands and the verify commands. Then manipulate the HI or LO register contents.



# APPENDIX E PARALLEL PROGRAMMING FLOW CHART





#### **Program Verify and Mask Subroutine**



#### COMMENTS

To look at the LO Byte, mask\* the HI Byte with 00.

If the LO Byte Verifies, mask the LO Byte commands with the reset command (FFH).

If the LO Byte does not verify, then increment its pulse counter and check for max count. FLAG = 1 denotes a LO byte error.

Repeat the sequence for the HI Byte.

FLAG = 2 denotes a HI Byte error. FLAG = 3 denotes both HI and LO Byte errors. FLAG = 0 denotes no max count errors; continue with algorithm.

292046-40

#### NOTE:

\*Masking can easily and efficiently be done in assembly languages. Simply load word registers with the incoming data (F-DAT), the program commands and the verify commands. Then manipulate the HI or LO register contents.



### APPENDIX F DETAILED SYSTEM SCHEMATICS





















### 256K FLASH MEMORY DEMO PARTS LIST

| Device    | Component    | Pins | Description                         |
|-----------|--------------|------|-------------------------------------|
| [1]       | 80C186       | 68   | 16-bit high integration CPU         |
| [2,3,4]   | 74HC573      | 20   | Latch                               |
| [5,6]     | 74HC245      | 20   | Transceiver                         |
| [7]       | 74HC32       | 14   | OR gate                             |
| [8L,8H]   | 27C64        | 28   | 16 Kbyte EPROM                      |
| [9L,9H]   | 28F256A      | 32   | 64 Kbyte flash memory               |
| [10L,10H] | 32K x 8 SRAM | 28   | 64 Kbyte SRAM                       |
| [11]      | 82510        | 28   | Asynchronous Serial Controller      |
| [12]      | 14C88        | 14   | RS-232 Line Driver                  |
| [13,14]   | 14C89        | 14   | RS-232 Line Receiver                |
| [15]      | 82C55A       | 40   | Programmable Peripheral Controller  |
| [16]      | PM7006       | 24   | DC/DC Convertor (5V-12.00V)         |
| [17]      | 7406         | 14   | Invertor—Open Collector (O.C.)      |
| C1        | 20 μF        | 2    | Capacitor for CPU reset             |
| 'D1       | 1N914        | 2    | Diode for CPU reset                 |
| F1        | BUZ11A       | 3    | MOSPOWER nFET                       |
| J1        | DB-25        | 25   | Connector (male)                    |
| OSC-1     | 20 MHz       | 14   | CPU Oscillator                      |
| OSC-2     | 18.432 MHz   | 14   | Serial Controller Oscillator        |
| R1        | 10 ΚΩ        | 2    | 1/4W, 10% Resistor for CPU reset    |
| R2        | 1 ΚΩ         | 2    | 1/4W, 10% Resistor for O.C. pull-up |
| SW1       |              | 3    | Momentary Push Button for CPU reset |

#### **NOTES:**

- 1. Place a 0.1  $\mu$ F bypass capacitor at the V<sub>CC</sub> input of each IC.
- 2. Place a 0.1 μF bypass capacitor on the V<sub>PP</sub> input of each 28F256 flash memory.

### 28F512 UPGRADE FOR THE 80C186/FLASH MEMORY DESIGN

To upgrade the 80C186/Flash memory design to handle 28F512's, the range of the CE# signal has to be increased. There are a number of ways to generate a CE# signal that will span the 128 Kbyte address range of two 28F512 devices.

 AND two of the current MCS lines together (defined for 64 Kbytes each); or 2. Change the MCS individual block-select size from 64 Kbytes:

MMCS\_VALUE = 41F8H, MPCS\_VALUE = 0A0B8H

to 128 Kbytes:

MMCS\_VALUE = 01FEH, MPCS\_VALUE = 0C0BEH

Also, cut the CE# trace to the RAM sockets. Then wire MCS0# to the RAM CE#. This eliminates the MCS0# and LMCS# range overlap caused by increasing the MCS range to 128 Kbytes. See 80C186 Data Sheet page 21 and 22 (Order # 270354).



### 28F010 UPGRADE TO THE 80C186/FLASH MEMORY DESIGN

To upgrade the 80C186/flash memory design to handle 28F010's, a CE# signal has to be generated. There are a number of ways to generate a CE# signal that will span the 256 Kbyte address range of two 28F010 devices.

 AND two of the MCS lines together (defined for 128 Kbytes each as noted in the 28F512 modifications):

Cut the LMCS trace to the RAM sockets. Connect MCS0# to CE# on the RAM sockets (U10L,UH).

Cut the MCS2# trace to the flash memory. Add an AND gate. Connect MCS2# (cut trace) and MCS3# to the inputs of the AND gate. Then wire the AND gate output to the CE# of the flash memories.

Also, change the onboard memory MCS register to:

MMCS\_\_VALUE=01FEH, MPCS\_\_
VALUE=0C0BEH [128K blocks],

and delete:

LMCS\_\_REG and LMCS\_\_Value.

### 2. Add a decoder;

Add a decoder (74HC138). Connect address lines A18 and A19 to the B and C inputs of the decoder. Tie the A input of the decoder low, and enable all the enables. By using outputs Y0, Y2, Y4, and Y6, you have four CE# lines decoding 256 Kbyte blocks each.

Cut the MCS2# trace to the flash memories. Connect the Y2 output from the decoder to the CE# input of the flash memory.

3. Replace the address latch (U2) with a PLD that latches and decodes.

Program a 5C032 as an integrated latch and decoder. Replace the upper address latch [U2] with the Intel 5C032 EPLD. Cut the CE# trace to the flash memories. Connect the flash memories' CE# to the 5C032 pin 12. This maps the address space 40000H to 7FFFFH. See Figures 1 and 2 for a comparison of the 74HC573 (U2) and programmed 5C032 pin outs. Figure 3 is the source code for the EPLD.

Also, change the value of the MMCS and MPCS registers to 64 Kbyte blocks so that the MCS0# range does not overlap the LMCS range.

MMCS\_VALUE=41F8H, MPCS\_ VALUE=0A0B8H.



Figure 1. Latch Pinout



Figure 2. Integrated Latch and Decoder



```
Thom Bowns - PLFG Applications
Intel
January 13, 1989
EPLD HOTLINE: 1-800-323-EPLD
002
50032
Custom Latched Decoder
OPTIONS: TURBO = ON
PART: 50032
INPUTS: ALEO11, RESETO1, A1905, A1804, A1703, A1602, nBHE06
OUTPUTS: LA18@17, LA17@18, LA16@19, LnBHE@15, nCE3@14, LA19@16,
          nCE2@13, nCE1@12
NETWORK:
          ALE = IN (ALE)
          RESET = INP (RESET)
          nRESET = NOT (RESET)
          A19 = INP (A19)
          A18 = INP (A18)
          A17 = INP (A17)
          A16 = INP (A16)
          nBHE = INP (nBHE)
          LA19, LA19 = COIF (LA19d, nRESET)
          LA18, LA18 = COIF (LA18d, nRESET)
          LA17, LA17 = COIF (LA17d, nRESET)
          LA16, LA16 = COIF (LA16d, nRESET)
          LnBHE, LnBHE = COIF (LnBHE, nRESET)
          nCE3, nCE3 = COIF (nCE3, nRESET)
          nCE2, nCE2 = COIF (nCE2, nRESET)
          nCE1, nCE1 = COIF (nCE1, nRESET)
EQUATIONS:
          LA19d = A19 * ALE + LA19 * !ALE;
          LA18d = A18 * ALE + LA18 * !ALE;
          LA17d = A17 * ALE + LA17 * !ALE;
          LA16d = A16 * ALE + LA16 * !ALE;
          LnBHEd = nBHE * ALE + LnBHE * !ALE;
          nCE3d = nCE3EQN * ALE + nCE3 * !ALE;
          nCE2d = nCE2EQN * ALE + nCE2 * !ALE;
          nceld = nceleqn * ALE + ncel * !ALE:
          nCE2EQN = !(A19 * !A18);
          nCE1EQN = !(!A19 * A18);
          nCE3EQN = !(!A19 * A18 + A19 * !A18);
END$
```

Figure 3. Source Code for the Integrated Latch and Decoder



**AP-325** 

## APPLICATION NOTE

# **Guide to First Generation Flash Memory Reprogramming**

APPLICATIONS ENGINEERING STAFF

March 1994

### 5

### **GUIDE TO FLASH MEMORY REPROGRAMMING**

| CONTENTS                                       | PAGE     | CONTENTS                                     | PAGE                    |
|------------------------------------------------|----------|----------------------------------------------|-------------------------|
| INTRODUCTION TO REPROGRAMMING                  | 5-164    | DEBUGGING YOUR CODE AN TIPS ON TESTING       | <b>D OTHER</b><br>5-174 |
| You Are in Control                             | 5-164    | Software Drivers Save You Time               | 9 5-174                 |
| FUNDAMENTALS OF FLASH<br>OPERATION             | 5-164    | Timers, Test Loops and Assemb<br>Programming |                         |
| Adaptive vs. Brute Force Algorithm             |          | Programming—The Key to Property Erasure      |                         |
| Moving Charge & Other Factors Y<br>Should Know |          | 16- and 32-Bit Systems                       |                         |
| ERASURE—THE GOLDEN RUL                         |          | Logic Analyzers and In-Circuit Emulators     | 5-175                   |
| Margin for Error                               |          | Testing Your Software—One Mo                 | ore<br>5-175            |
| Device Initialization and Reset                |          | Watchdog Timer Debug Circuit                 | 5-176                   |
| The Erase Algorithm Interpreted                | 5-171    | TROUBLE SHOOTING GUIDE                       | 5-177                   |
| The Program Algorithm Illuminate               | ed 5-173 | Determining the Root Cause                   | 5-177                   |
| Demiliantians of the Calden Dula               | F 470    |                                              |                         |



### INTRODUCTION TO REPROGRAMMING

### You Are in Control

Rewriting any type of memory requires hardware or software control. Traditional EEPROM designers combined all control functions into each chip's periphery. This provided a highly functional chip but at a high price. On the other hand, DRAM designers provided a bulk memory with little integrated peripheral circuitry. Each system designer then accommodated the DRAM with external refresh signals and learned quickly that failure to refresh yielded non-functioning memory boards. Initially, software drivers controlled DRAM refresh; today controllers provide the same function.

Similarly, early disk drives required every user to write software to manipulate drive head movement. Failure to follow drive specifications and algorithms caused irreversible head crashes. Leading-edge engineers faced these challenges and triumphed, as evidenced by the sophisticated systems available today.

Since 1988, thousands of engineers have written soft-ware to direct flash memory reprogramming. With first generation flash memories, one sends a control signal to a device to begin and end programming or erasure. It is a simple process implemented on more than 40 million units, however care must be taken. If algorithms are not properly followed, a device may be rendered inoperable. This document discusses proper software and debug technique, which yields dependable first generation flash memory operation. First generation products include the 28F256A, 28F512, 28F010 and 28F020. All second and third generation Intel Flash Memories contain automated program and erase routines.

### FUNDAMENTALS OF FLASH MEMORY OPERATION

### **Adaptive vs Brute Force Algorithms**

Many designers use EPROMs regularly. Few consider the programming algorithms because the PROM programmer vendors take care of that function.

Two types of algorithms are in use today:

- · Adaptive Algorithms
- Brute Force Algorithms

Adaptive algorithms such as Intel's Quick-Pulse Programming and Quick-Erase algorithms reduce programming time. A feedback mechanism recognizes when each byte has been programmed sufficiently. You may ask how is the point of sufficiency determined?

One simply adds the net effects of  $V_{CC}$  and temperature variations, and superimposes on those factors the normal EPROM charge leakage to obtain the answer. The next question is how can these factors be checked?

#### NOTE:

EPROM and EEPROM charge leakage occurs over a very long time—typically 100 years. Reliability papers often discuss charge leakage in terms of the memory's data retention characteristic.

If you look at EPROM programming algorithms, you will notice that  $V_{\rm CC}$  is elevated during programming. The elevated  $V_{\rm CC}$  acts as the feedback mechanism for the adaptive algorithm. Reading the device and checking for program completion is called verification, or margining. (One is checking the margin to  $V_{\rm CC}$  fluctuations.) For example, if the part can be verified at 6.25V, then it can withstand the fluctuations and normal charge leakage.

During the past few years most major EPROM manufacturers have converted to adaptive algorithms. The algorithm loops back and programs a byte again if the first program operation does not verify at the elevated voltage.

Brute force algorithms simply program each byte multiple times, typically with long program durations. This type of algorithm has no in-system margin verification. That is they assume but never verify program margin to the typical environment effects.

Many flash memories that specify a brute force algorithm may fail to retain data for 10 years. Additionally, they may not read the data correctly even at specified  $V_{CC}$  and temperature extremes.

Intel's flash memory program and erase algorithms are both adaptive. They offer margin verification without requiring users to elevate  $V_{\rm CC}$  in-system. When issued a command to program verify, the memory's command register logic taps an internally-generated elevated  $V_{\rm CC}$  from the user-supplied external  $V_{\rm PP}$  (12V). This is why it is essential that you provide the specified  $V_{\rm PP}$  voltage and follow the given adaptive algorithms. Intel's adaptive algorithms, combined with the command register architecture, assures reliable code and data storage and dependable system operation.

Figure 1 shows an example of an adaptive byte programming algorithm. Appendix A compares the algorithm in Figure 1 to a brute force approach.





Figure 1. The flow chart shows the fundamental nature of an adaptive algorithm. Based on the outcome of program verification, the flow may loop back for another program operation.

### Moving Charge and Other Factors You Should Know

This section discusses the mechanics of flash memory programming. For most system designers, transistorlevel discussions were last heard in college. We may recall that DRAM consists of a storage capacitor and a transistor. We remember this clearly because failure to refresh that capacitor causes systems to malfunction. In like fashion, one should understand the fundamentals of flash memory reprogramming. The understanding will enable error-free memory operation and reliable system performance.

In simplest terms, each data bit equates to a memory cell. Intel's flash memory uses one transistor per cell with the smallest possible architecture. This delivers the lowest cost per bit and highest capacity, levering system software (rather than bulky, complex cells) for reprogramming control.

Figure 2 shows a simplified cross section of Intel's flash memory transistor. Note the structure; the cell is a stacked gate MOS transistor. An isolated floating gate stores the memory charge. The floating gate consists of a layer of (conductive) polysilicon surrounded by (nonconductive) oxide layers.

On a DRAM cell, each transistor connects to a capacitor which stores the memory charge. The major difference between flash memory and DRAM derives from their cell structure. The DRAM cell loses its charge if not refreshed within a few milliseconds. On the other hand, the flash memory floating gate maintains its charge for typically 100 years. The structure is isolated and insulated by the field and gate oxides—hence the name "floating" gate.



Figure 2. Simplicity of design assures increasing densities, manufacturability and reliability.

These are the attributes that drive mainstream memories.



### CONTRARY TO INTUITION CHARGE = DATA "0" NOT DATA "1"

#### PROGRAMMING:

ADDS CHARGE TO FLOATING GATE

→ DATA = 0

### **ERASURE:**

REMOVES SOME CHARGE FROM FLOATING GATE

→ DATA = 1

### **PROGRAMMING DATA WITH MIXED 0s and 1s:**

- → ONLY DATA "0" BITS GET CHARGED
- → DATA "1" BITS REMAIN UNCHARGED

Changing the memory contents is simple. Figure 3 shows two memory cells—one being erased and one being programmed. Erasure removes charge from all bits simultaneously. Programming adds charge to selected bits. During erasure, not all charge is removed. The erase verify operation tells the system when enough charge has been removed. At that point, the flash memory behaves like a U.V.-erased EPROM.

Removing too much charge by erasing too long renders the memory unprogrammable. Excessive erasure lowers the cell threshold to the point where the transistor is always on and always reads data "1". (Recall that the cell threshold,  $V_t$ , determines when the transistor turns on or off.) You must control the erase timing within the algorithm specifications on first generation flash memories.

A second erase consideration relates to the first. Prior to erasing the chip, you must blanket program all bytes to data 00h, regardless of the previous data. This step equalizes the charge on all transistors.

If you skip this step and proceed directly to erasure, an interesting thing happens. Consider a typical byte programmed with data 0AAh (1010 1010b). While programming this data, bits with data "1" remain erased (charge removed), and bits with data "0" are programmed (charged added). Following programming, normal read operations sense whether a memory transistor has more or less charge and drives the outputs accordingly.





Figure 3. Flash memory cells during erasure and programming. Note the movement of charge on and off the floating gate. The charge adjusts the cell threshold, which tells the outputs whether a bit (transistor) is on or off.



Erasure then removes charge from all bits. The bits that have had charge added (data "0") have some quantity of charge removed; bits with less charge (data "1") have charge removed as well. This is akin to excessively erasing the data "1" bits. Pre-programming all bits to data "0" equalizes the charge which allows for controlled, uniform erasure of all bits in the device (i.e., all 1,048,576 bits in a 28F010).

The sections entitled "Margin for Error" and the "Erase Algorithm Interpreted, Program all Bytes to 00h" discuss this concept in greater detail.

### **ERASURE—THE GOLDEN RULE**

Erasure removes charge from all memory cells in parallel. This lowers the cells' threshold voltages from the programmed level (6.5V) below V<sub>CC</sub> to the erased level (3.2V) The device continues erasing until told to stop by the verify command or until the integrated stop-timer counts down.

### **Margin for Error**

Allowing erasure to continue too long depletes the charge in floating gates. So you ask—how long is too

long? Figure 4 shows the margin for error of a typical device. Following the algorithm would have stopped erasure after 1 second. Cell depletion occurred after 10 seconds giving a 10x margin for error. This 10x margin exists if the erased cell erases in 1 second or 10 seconds (i.e., within the algorithm limits). This chart shows one typical example where the device happened to take 1 second to erase.

Flash memory has generous margin for error over the stopping point defined by the algorithm. The stopping point is defined as the point when all bytes in the chip verify to FFh data. The erase operation duration (Twhwh2) is specified at 10 ms  $\pm$  500  $\mu$ s. Five hundred microseconds offers substantial allowance for system latency during erasure and even for slop in the timer generation. Processors or controllers can execute many lines of code in 500  $\mu$ s, and the margin for error simply adds another guardband.

Proper software and system design will never rely on the additional margin for error. Remember, you control the program code and system operation during erasure. Once you have fully debugged your driver code, the issue of software control disappears entirely.



Figure 4. The logarithmic-decaying nature of erasure allows for 10x error in erase time before a device becomes inoperable. Remember, each device has its own erase time, thus the use of an adaptive algorithm.



### **Most Common Development Issues**

Having covered the fundamentals of flash memory reprogramming, let's move on to the system's hardware and software perspectives. The following list of questions might have occurred to you ...

- You have defined a system power supply with regulated 5V and 12V outputs (V<sub>CC</sub> and V<sub>PP</sub>). Due to the smaller capacitive load on the V<sub>PP</sub> supply, V<sub>PP</sub> powers up much faster than the V<sub>CC</sub> supply. Will this affect the device?
- How does the flash command register architecture reset?
- Suppose your code sends a signal to start erasure, and never tells it to stop?
- Suppose your software delay timers are not calibrated. Instead of stopping erasure after ten milliseconds, the code issues the stop command after 10 seconds?
- Suppose your 6 μs timer used between the erase and erase verify modes is only 2 μs?
- Suppose you decide to skip the first erase operation (program all bytes to zero) because the device is already programmed with data?
- Suppose you are programming and erasing devices in a 16- or 32-bit system?

The answer to all these questions can be found in the following sections. The questions and the reasons all relate to the discussion of how the cell works.

#### **Device Initialization and Reset**

Many logic devices which contain command or control registers also have a reset pin. This pin serves two purposes: it resets the device's internal logic; and it synchronizes the device's clock to the system clock.

Intel's first generation flash memory command register and reprogramming circuitry reset to the read mode by three means:

- 1. raising or lowering  $V_{PP}$  with  $V_{CC} = 5V$ ;
- 2. raising  $V_{CC}$  with  $V_{PP} = 12V$ ;
- 3. issuing the reset command twice in succession.

### NOTE:

Method 3 stops erasure or programming as well as resets the chip.

A few cases require closer consideration.

### Case 1. The System Controls VPP with a Switch

Assuming  $V_{\rm CC}$  is stable with  $V_{\rm PP}$  switches on, then the command register defaults to the read mode. No power-on reset is required.

Designers might opt to include the  $V_{PP}$  switch for either (or both) of two reasons. The first reason is power minimization. Depending on the technology used, a voltage regulator or pump's efficiency can range from 40%-85%. Switching off the  $V_{PP}$  supply minimizes system power consumption. See Appendix B for an example  $V_{PP}$  generation circuit with ON/OFF control capability.

The second reason is absolute data protection. This feature is not available to 5V-only EEPROM because the reprogramming voltages are generated internally. On that class of memory device, logic glitches can spuriously change data during system power up or power down. Flash memory's 12V power requirement offers absolute control over these concerns; with  $V_{\rm PP}$  below  $V_{\rm CC}+2V$ , data protection is guaranteed. Internally, the electric fields are simply too weak to spuriously write data.

### Case 2. V<sub>PP</sub> Powers Up before V<sub>CC</sub>

Systems with  $V_{PP}$  hardwired to a regulated transformer might encounter this case. Typically,  $V_{CC}$  will charge many more bypass capacitors than  $V_{PP}$ .  $V_{CC}$  will therefore power up much more slowly.

The flash memory power-down ( $V_{CC}=0V$ ) default state blocks  $V_{PP}$  from disturbing the array. These conditions hold while  $V_{CC}$  is below  $\sim 2V$ . Once  $V_{CC}$  rises above  $\sim 2V$ , the internal logic kicks in and resets the device to the read mode. (This is analogous to the internal  $V_{PP}$  reset condition described in Case 1.)

Should the three control pins glitch during the powerup phase ( $\overline{\text{CE}}$ low,  $\overline{\text{WE}}$ low, and  $\overline{\text{OE}}$ high), then the command register acts to filter the data. The command port will only react to the correct command sequence.

Designers might opt to hardwire  $V_{PP}$  for a number of reasons. The first reason is cost minimization. A regulated 12V secondary from a transformer is commonly available. Adding a switch or a power supply sequencer adds cost and complexity. The second reason involves consideration of the end application. Using the flash memory as a read/write memory requires optimization for the write cycle. Powering  $V_{PP}$  on before each write would waste considerable time.





### NOTES:

<sup>1.</sup> The  $V_{PP}$  power supply can be hard-wired to the device or switchable. When  $V_{PP}$  is switched,  $V_{PP}$  1 may be ground, no-connect with a resistor tied to ground, or less than  $V_{CC}$  + 2.0V.

<sup>2.</sup> Erase verify is performed after chip-erasure. A final read/compare may be performed (optional) after the register is written with the read command.

<sup>3.</sup> CAUTION: The algorithm MUST BE FOLLOWED to ensure proper and reliable operation of the device.



### Case 3. Warm Resets

Warm resets, where the system maintains power while rebooting, requires closer inspection. Consider the situation where the system is reprogramming the flash memory and a hardware or software reset occurs.

The boot software would not realize that programming or erasure is ongoing and would not know to stop the reprogramming operation. Therefore safeguard against this condition with one of two means: 1) ensure that control logic switches Vpp off during reset; or 2) reset the flash memory before resetting the processor. For a software reset, simply add the flash memory reset command to the interrupt sequence. For hardware resets, wire the reset switch to the interrupt controller instead of directly to the reset input. Hardware resets would then execute the software interrupt sequence. Intel's second and third generation flash memories all include a H/W reset pin (RP#) formally called PWD#. This pin is essential for any device with automation or embedded algorithms.

### The Erase Algorithm Interpreted

The following section offers a block by block explanation of the Quick-Erase algorithm shown in Figure 5. Understanding the reasons behind a function will enable you to appreciate the importance of following the algorithm explicitly. Deviations will negatively affect the part's performance and should not be attempted. Note: the effect may not be immediately apparent.

### Apply $V_{\mbox{\footnotesize{PPH}}}$ (Optional, see Discussion on Device Initialization)

Switch on the local  $V_{PP}$  supply prior to erasure and programming. The time required for  $V_{PP}$  to reach its steady state  $12\pm0.6V$  depends on the capacitive load and the impedance of the printed circuit board trace. If you measure this delay on a wire-wrapped prototype system, remember that temperature, printed circuit traces and the board's layout change the load seen by the  $V_{PP}$  generator. Allow  $V_{PP}$  sufficient time to ramp before proceeding with the next step.

### Program All Bytes to $00h \rightarrow Data = 00h$ ?

Prior to erasure, blanket program all addresses in the flash memory to 00h (charge state), regardless of the previous data. Verify that each address equals 00h before proceeding to the next address. If you use only part of the memory array, you still need to pre-program the entire array for erasure. An example where this is an issue is using a 512K in a 256K socket. A second example is a system where internal microcontroller memory overlaps the external flash memory space.

Programming data 00h equalizes the charge on every bit in the array. This is necessary because erasure removes charge from all cells regardless of their previous state.

For example, reconsider the byte containing AAh data (1010 1010b). If you skip the pre-program step, then during erasure when the data "0" bits get charge removed, the previously erased bits (data "1") lose additional charge. This drives the cell threshold a little lower. The next time you erase the chip and change the code, the threshold will drop to 2.8V.

If the memory transistor is not pre-programmed to data "0" before the next erasure, then its threshold will drop on successive reprogramming cycles (denoted by E3, E4, etc. in Figure 6). Repeated violations of the blanket programming requirement drives the threshold to the point where the transistor is stuck on (data = "1").

#### Variable Initialization

Initialize two variables and a constant: ADDR (address), PLSCNT (pulse count), and TEW (erase pulse width). The pulse count increments from 0 to a maximum of 1000 erase tries. The erase pulse width remains constant at 10 ms. The address increments from the flash memory starting address to the ending address during verification.





Figure 6. Successful erasure requires blanket programming all bytes to the data "0" level first. This prevents threshold decline on successive erase cycles (E2, E3, etc.). Very low thresholds cause the chip to malfunction.

### Write Erase Set-Up Command

Write the erase set-up command (20h) to any flash memory address. This prepares the selected device for erasure, but does not activate the process. A second erase command (20h) is required. Any other data written to the flash memory between the set-up and erase commands will abort the sequence. Once the process is started, it will not stop until told to do so. The correct stop erasure command is Erase Verify (A0h). However, any command including the Reset command is an illegal sequence and will stop erasure as well.

#### Write Erase Command

The erase command starts the erase process. Internally, the device switches the voltages on all memory cell drains, gates, and sources to the erase configuration.

#### Time Out Tew (10 ms)

Start your software or hardware timer. Until commanded to verify or until the integrated stop-timer counts down, the flash memory continues the erase process. Therefore, assign a high priority to the timer interrupt. If a higher priority interrupt occurs, stop the erase process and switch contexts (store all variables, registers, etc.). This will allow reentry into the erase procedure in a controlled fashion.

### Write Erase Verify Command

Write the erase verify command (A0h) to the flash memory at the address given by the ADDR variable.

The erase verify command performs many tasks. Internally, the device stops erasure and latches the given address for verification. Additionally, the command changes the voltages on the memory cell drains, gates and sources to the erase verify configuration.

#### Time Out 6 µs

This time out accounts for the internal slew rate of switching the memory array from the erase to the erase verify configuration. Do not attempt to read from the device before 6  $\mu$ s has passed; the device will appear to still be programmed. This is because you have not allowed sufficient time for the memory to change configurations. Your code will then interpret this as a need for extra erase operations, and will continue erasing the device.

#### NOTE:

 $6~\mu s$  is a minimum specification. You can use the  $10~\mu s$  timer developed for the programming algorithm.



#### Read Data from Device

Read the data at the address given by the ADDR variable. This should be the same address driven with the erase verify command.

#### Data = FFh?

Compare the output data at address ADDR to FFh. If the data equals FFh, then that address has been erased. Continue verification until the last address has been verified or until the maximum erase pulse count (1000) has been reached. Typically, most devices will fully erase within 50–100 erase loops.

### Last Address → Increment Address

Check the ADDR variable to see if the last address has been verified. If not, increment the ADDR variable and re-write the erase verify command. Remember to write the erase verify command to address ADDR, since the verify command latches the address. Also, if your system has 64K byte segment boundaries, be sure to increment the base pointer every 64K byte addresses.

#### Write Read Command

After full chip verification, write the read command (00h) to switch the device to read mode. If you plan to reprogram the device immediately, this step is not necessary.

### Apply V<sub>PPL</sub> (Optional)

Switch V<sub>PP</sub> off. With V<sub>PP</sub> left on, the command register offers data protection by requiring a precise sequence to initiate programming or erasure. However, V<sub>PP</sub> controls overall command register operation. Turning V<sub>PP</sub> off disables the command register, thus providing absolute data protection. Without the high voltage, the reprogramming mechanisms cannot occur and the component becomes a read only memory (ROM).

#### Abort/Reset

Whenever a system error condition occurs (reset or reboot), write the Reset command (FFh) to each flash memory twice in succession. This is a good initialization practice in systems leaving Vpp at 12V. The processor would be unaware if prior to the reset, it had been in the middle of erasure, and this sequence aborts erasure.

### The Program Algorithm Illuminated

The full algorithm will not be interpreted here, although a few items should be noted. You can find a conceptual version of the Quick-Pulse Programming algorithm in Chapter 2, Figure 1, and the complete flow chart in Appendix C.

First, similar to erasure, a two-write sequence starts programming. The first write is the Program Set-Up Command which primes the chip for programming. The chip then latches the address and data to be programmed on the second write. You can abort programming by writing the Reset Command twice in succession instead of the data to be programmed.

Second, the device continues programming until commanded to stop by the Program Verify Command. Similar to the Erase Verify Command, this command performs a couple of functions. Internally, it halts programming and latches the given address for verification. Additionally, the command changes the voltages on the memory array's drains, gates, and sources to the program verify configuration.

The cell programming mechanism is self-limiting. However, do not assume that programming all twenty-five 10  $\mu$ s operations in one pass is the best way to attain reliable operation. To a certain degree, programming stresses the memory cell. The stress is considerably lower than that applied to EEPROM (2 MV/cm lower to be specific). But why stress a component without cause? The adaptive Quick-Pulse Programming algorithm with its fast program operations, minimizes all stresses and affords the greatest reliability.

Finally, after writing the Program Verify Command to the device, wait a minimum of 6  $\mu$ s before reading the device. The time out accounts for the internal slew rate of switching the memory array from the program to program verify configuration. Do not attempt to read from the device before 6  $\mu$ s has passed; the device may appear unprogrammed. Your code will then interpret this as a need for extra program operations. It may needlessly reach the 25 operation limit, even though the byte most probably programmed on the first pass.

### Ramifications of the Golden Rule

Always follow the erase command with an erase verify command to stop erasure. Interrupt-driven systems must give high priority to servicing the reprogramming timer interrupts. Systems that reset upon a watchdog time-out must reset the flash memory device before rebooting. (See discussion on device initialization.) Likewise any non-maskable interrupt should software- or hardware-reset the flash memory before performing a context switch.

Use an oscilloscope to calibrate all time delays before attempting erasure. The delay modules include the 6  $\mu$ s, 10  $\mu$ s, and 10 ms timer routines.

Blanket program all addresses to 00h data before erasing. Verify correct implementation of the programming algorithm with a PROM programmer before attempting erasure. (Chapter 4 explains how this can be done.)



16- and 32-bit systems require special attention. Each flash device has its own erase characteristic. Do not assume that if the low byte of a data word is not erased, then the high byte must not be either.

Always follow the listed guidelines and take care while developing your code to eliminate the erase control issue. Consider it similar to implementing any control function. Once the code is debugged and stable, the issue goes away.

You might ask, is it not possible to control erasure through hardware? The alternative to software control is integrated hardware control or an external controller. Intel ofers a complete line of high density, cost-effective products with integrated hardware control, often called automation. Whether software or hardware controlled, Intel's ETOX Flash Memory offers the most reliable, dense, manufacturable, and fastest read/write nonvolatile memory. Other EEPROM approaches have drawbacks of multiple transistors per memory cell. This property negatively affects all those attributes offered by Intel's ETOX flash memory.

### DEBUGGING YOUR CODE AND OTHER TIPS ON TESTING

As with any software checkout, a few simple principles enable complete flash memory algorithm debug. The following sections offer some hints to make your job easier.

### Software Drivers Save You Time

Intel saves you time by offering various processor-family flash memory drivers. You simply edit the files to suit your system. Then assemble the driver, link, and locate it, and you are ready for debug.

These drivers offer the framework for successful flash memory reprogramming, and require some customization to fit your particular system. If your processor's driver is not available, you may use the available driver software as an example. One caution in advance: The drivers have been written in assembly language to give the most speed- and memory- efficient code. However, most people prefer high-level programming.

High-level programming can be used for everything except software-timer generation. Compilers may give different routines with different object code on each compilation. Therefore, the timers must be either hardware-based or coded in assembly language. Software

timers also present some risk if there is a frequency upgrade change on the controlling processor. Regenerate and check your timer routines whenever the system clock rate changes.

### Timers, Test Loops and Assembly Level Programming

Timing circuits or software play the most crucial role in flash memory reprogramming. Good timers precisely control their function; sloppy timers produce faults. An example of a sloppy timer is one produced by a compiler. Each time high-level languages recompile, the low-level object coding may change. Thus, a timing loop may be 10 ms one compilation, and much longer or shorter the next time.

You can check your timing method with the following simple technique. Develop test loops which call the various timers' routines. For example, implement the 6  $\mu$ s, 10  $\mu$ s, and 10 ms timers used with the 28F512 and 28F010. If you have a spare port or peripheral output, use it to trigger an oscilloscope. Follow the trigger call with the timer routines. If you do not have a spare port, write to the flash memory address space before and after each timer call. You can trigger the oscilloscope off of the flash memory CE# signal. Remember to power-down the system and remove the flash memory before attempting these methods.

Once the timer code has been verified, you can link and locate it to a higher-level erase/program algorithm implementation.

### Programming—The Key to Proper Erasure

Earlier sections described the importance of programming 00's prior to erasure. This procedure equalizes the charge on all memory cells; following this step all bits erase in unison.

A conclusive debug technique can check your programming software. Simply use your software to program zeroes into the flash memory and then verify this step using a conventional PROM programmer. Load the PROM programmer's buffer with all zeroes and compare the buffer to the flash memory. If your programmer does not service the flash memory, call the company for the latest software upgrade. Alternatively, one can easily rig the 512K flash memory to look like a 512K EPROM. Simply jumper V<sub>CC</sub> on a 32-pin socket



to a few pins. Note that the 27512 EPROM and 28F512 flash memory have different intelligent identifier codes. Override the identifier code check to use this method. See Figure 7 for socket details.

Some microcontrollers have limited address space or internal memory that masks certain external address space. Even if you do not use sections of the flash memory, you must still access these sections to program zeroes before erasure. Map and decode port bits to access unused address space, and verify that all bytes are programmed to zero before proceeding with erasure.



Figure 7. A 28F512 can be read in a PROM programmer as a 27512 by jumpering the appropriate pins to V<sub>CC</sub>. The same method applies to the 28F010.

### 16- and 32-Bit Systems— Achieving Optimum Reprogramming Throughput

Erasing flash memory in 16- and 32-bit systems requires special consideration. One could implement the program and erase algorithms in a byte-wise fashion, but this is time-consuming. Alternately, one can treat the multiple flash memory as a data word, and gain optimum performance.

The primary consideration with the latter approach is that one device may program or erase faster than the other(s). Subsequent programming or erasure of a slower device compromises the functionality of the faster device by subjecting it to the slow-device timing.

Consider an example of erasure in a 16-bit system. After 10 passes through the erase operations, both devices verify through address 07C3h. Then at address 07C5h, the processor reads data word 83FFh.

Since erase data is FFFFh, a few bits in the upper byte/ device have not erased. The natural flow of the algorithm would dictate another erase operation. But what about the lower device? Could it be completely erased? Of course it could be; every device erases at a different rate and the algorithm has only checked up to address 07C5h.

You can take advantage of the data rate of wider data buses by utilizing the command register, the reset command and an analysis of erasure. Each erase operation is 10 ms. Each byte verification takes 6  $\mu$ s. Therefore, erasure takes three orders of magnitude longer than verification. Optimization for erasure yields the optimum performance because verification is a second order effect.

Let us reconsider the previous example. At address 07C5h, the data word does not verify. On the next erase operation edit the erase (and erase verify) command word such that only the high byte gets the erase command, and the low byte gets a reset command. (i.e., change the command word from 2020h to 20FFh).

See Application Note AP-316 for a detailed flow chart for this approach. Note this document is based on the 28F256; however, most concepts carry through to the higher density devices. (Literature Order number 292046).

### Logic Analyzers and In-Circuit Emulators

Many programmers use logic analyzers and in-circuit emulators to debug code. These approaches are fine for flash memory algorithm debug if certain conditions are met.

- 1. Check timing routines with an oscilloscope; there is no alternative.
- 2. Know your code and set breakpoints intelligently. One designer had the bad luck of throwing in a breakpoint in the middle of the program 00's loop. After stepping through a couple of byte program 00 loops, he called the erase flow routine. Can you identify the problem?
- 3. Single step through your reprogramming code, if and only if, the flash memory device is removed from the system.

### Testing Your Software—One More Time

Some flash memories specify 100 erase/program cycles. This is a minimum specification; Intel Flash Memories cycle 100,000 times. With this in mind, feel free to check and recheck reprogramming operations. There is no reliability risk in doing so.



One confidence-raising test is similar to that done on systems: stress the system/software by executing test code numerous times consecutively. Set the reprogramming drivers in a loop, and let them run 20-40 times. On each consecutive pass, use a constant data pattern such as 0AAh. This tests the reprogramming code from a quasi-static perspective. Missing is the true system environment. In the true system environment, multiple inputs compete with the flash memory for interrupt priority. Also, RF noise from motors can cause spikes and glitching on VPP or VCC. Additionally, fully loaded systems or partially loaded systems might have different V<sub>PP</sub> response characteristics or noise levels. Signals that look clean in the lab, might not be all that clean in the true operating environment. Therefore, flash reprogramming tests should be done in the true system environment as a final test.

### **Watchdog Timer Debug Circuit**

This section describes a simple tool you can build for debugging your code. Since Intel's first generation Flash Memories contain integrated stop-timers, this tool offers no real benefit. It is simply shown in case a designer is debugging code for alternate sources. An EPLD watches the flash memory data bus and control signals for the erase sequence—erase set-up, erase, and erase verify commands. Once the CPU initiates erasure, the debug tool starts a 15 ms timer. Should the timer count down prior to receiving the erase verify command, then the circuit switches Vpp off.

This tool does not check for the other items discussed in the **Tips on Testing** section; you must still check those yourself.

Figure 8 shows the circuit schematic. The EPLD source code and the name of an Intel EPLD applications engineer is located in Appendix D.



Figure 8. Watchdog Timer Debug Circuit



### TROUBLE SHOOTING GUIDE

### Determining the Root Cause— Software Error vs Device Damage

The three major indications of a flash memory problem are labeled in the following section. The subsequent paragraphs define potential root causes to investigate.

### I. The Device Does Not Program

Did it program before?

#### A. No.

- Trigger your oscilloscope on CE# while probing V<sub>PP</sub>. Verify that V<sub>PP</sub> has reached a steadystate 12V when the device is first written.
- Set the time-base to 10 μs/division (the duration of the program operation). Trigger on CE# and probe WE# (look at both traces). Check the duration of the 10 μs program operation time delay. Also, check the duration of the 6 μs delay between writing the program verify command and read.
- Look for ringing on V<sub>PP</sub> when V<sub>PP</sub> has been switched on. Over-voltage stress on V<sub>PP</sub> (ringing with amplitude greater than 13V) will destroy V<sub>PP</sub>'s silicon structure.
- Power the system down and back up. Look for destructive glitches on V<sub>CC</sub> or V<sub>PP</sub> (greater than 7V and 13V respectively).
- 5. Verify erasure and programming on a PROM programmer (if available). Fill the programmer buffer first with 00h data and program the buffer to the flash memory. Then erase the device, and repeat with AAh data. Repeat the last step with 55h data. This sequence fully exercises the array, the input buffers and the output buffers. If all tests pass then check for a hardware or software error.

#### B. Yes.

- Have you done anything that may have ESD zapped the devices (i.e., touched the devices while not being grounded, re-wired the protoboard with the components socketed, etc.)? If yes, check part as outlined in section 1.A.5.
- 2. Have you attempted erasure? If yes, verify your algorithm as outlined in Chapter 4. Also, implement the in-system intelligent identifier mode. If the device outputs an incorrect code, then either an output has been zapped or the golden rule has been violated. Section 1.A.5 describes a method of checking for ESD damage.

#### II. The Device Does not Erase

Did it erase before?

#### A. No.

Follow steps 1-5 outlined in section I. When performing step 2, adjust the oscilloscope time base to 10 ms/div.

#### B. Yes.

Has the board design, clock rate or software changed? System clock rates directly affect the accuracy of software timers. See AP-316 for a discussion on software timing versus clock rate.

### III. The Device Erases Spuriously

Exercise all system functions while monitoring the flash memory chip selects. Verify that I/O mapped addresses or logic are not accidentally selecting the flash memory. For example, the space bar character sent from a keyboard controller happens to be 20h. If the flash memory is accidentally selected while this data is on the bus, then erasure will commence on the following cycle when the condition occurs again.



### APPENDIX A

### TWO APPROACHES TO ALGORITHMS



Figure 9. Left and right flow charts compare Intel's (adaptive) Quick-Pulse Programming algorithm and another company's (brute force) approach to flash memory programming.



### APPENDIX B



Figure 10. Basic flash memory V<sub>PP</sub> voltage supply with ON/OFF control.

When V<sub>PP</sub> COMMAND goes low, the Linear Technology LT1072 switching regulator produces 12V.

This circuit is just one example of a V<sub>PP</sub> supply.



### APPENDIX C QUICK-PULSE PROGRAMMING ALGORITHM



#### NOTES:

- 1. The  $V_{PP}$  power supply can be hard-wired to the device or switchable. When  $V_{PP}$  is switched,  $V_{PP}$  I may be ground, no-connect with a resistor tied to ground, or less than  $V_{CC}$  + 2.0V.
- 2. Program Verify is only performed after byte programming. A final read/compare may be performed (optional) after the register is written with the Read command.
- 3. CAUTION: The algorithm MUST BE FOLLOWED to ensure proper and reliable operation of the device.



### APPENDIX D WATCHDOG TIMER CIRCUIT

### **EPLD Source Code and Applications Contact Person**

```
Thom Bowns_PLFG Applications
Intel
January 5, 1989
Rev. 008
5AC312
Watchdog timer to cut VPP from FLASH if erase cycle too long.
OPTIONS: TURBO = ON
PART: 5AC312
INPUTS:
              CLK, D0@3, D1@4, D2@5, D3@6, D4@7, D5@8, D6@9, D7@10,
              nCE@2, nWE@11, TIMER_IN@13, RESET@14, AHR@15
OUTPUTS:
              TIMCLR@23, TIMST@22, LED@21, VPP@20
NETWORK:
              CLK = INP (CLK)
              DO = INP (DO)
              D1 = INP (D1)
              D2 = INP (D2)
              D3 = INP (D3)
              D4 = INP (D4)
              D5 = INP (D5)
              D6 = INP (D6)
              D7 = INP (D7)
              nCE = INP (nCE)
              nWE = INP (nWE)
              TIMER_IN = INP (TIMER_IN)
              RESET = INP (RESET)
              AHR = INP (AHR)
                                         % RESET active high if AHR is high %
              COND1 = NOCF (Cld)
                                         % Conditions 1-4 are routed
              COND2 = NOCF (C2d)
                                         % through combinatorial feedbacks
                                                                                %
              COND3 = NOCF (C3d)
                                         % to reduce product term count.
                                                                                %
              COND4 = NOCF (C4d)
                                                                                %
              CLR = NOCF (CLRd)
EQUATIONS:
              CLRd = RESET * AHR + !RESET * !AHR:
              TIMEOUT = /TIMER_IN:
              Cld = (/nCE * /nWE * 20H);
                                                 % Write 20 %
              C2d = (/nCE * /nWE * aOH);
                                                 % Write AO %
              C3d = (/nCE * /nWE * /20H);
C4d = (/nCE * /nWE * /AOH);
                                                 % Write other than 20 %
                                                 % Write other than AO %
              20H = /D7 * /D6 * /D5 * /D4 * /D3 * /D2 * /D1 * /D0;
AOH = /D7 * /D6 * /D5 * /D4 * /D3 * /D2 * /D1 * /D0;
```



```
MATCHING:
           WATCHDOG -
CLOCK:
            CLK
STATES:
              VPP
                   LED
                         TIMST
                                TIMCLR
                                         XSB
 START
            [
               0
                    0
                           0
                                   0
                                          0
            Ē
    Sl
               1
                                          0
                    0
                           0
                                   0
    S2
               1
            [
[
[
                    0
                           1
                                   0
                                          0
    S3
               1
                    0
                                          0
                           1
                                   1
    S4
               1
                    0
                           O
                                   1
                                          O
    S5
            ]
[
]
               1
                    0
                           -1
                                   1
                                          1
    S6
               1
                    0
                                   0
                                          1
                           1
    S7
               0
                    1
                           1
           % TRANSITION STATEMENTS %
START: S1
                                        % From power up, go to Sl right away %
Sl:
      IF COND1
                   THEN S2
                                        % If write 20, go to next state
      IF /COND1
                   THEN S3
S2:
                                        % Until not write 20, hold
                                                                                %
                   THEN S1
      IF CLR
S3:
      IF COND1
                   THEN S4
                                        % If another write 20, start timer
                                                                                %
      IF COND3
                   THEN S7
                                        % If write other than 20, error
                                                                                %
      IF CLR
                   THEN S1
S4:
      S5
                                        % Trigger timer then go to S5 loop
                                                                                %
S5:
      IF COND2
                   THEN S6
                                        % If write AO, stop timer
                                                                                %
      IF TIMEOUT
                   THEN S7
                                        % If timer times out.
                                          go to error state
                   THEN S7
      IF COND4
                                                                                %
                                        % If write other than AO, error
S6:
      Sl
                                        % Stop timer and go back to Sl
                                                                                %
      IF CLR
S7:
                   THEN S1
                                        % Error state. wait for a RESET.
END$
```





### APPENDIX E

### **Checklist: Most Common Mistakes that May Lead to Excessive Erasure**

- not programming all bytes to 00 data prior to erasure;
- not observing the 6  $\mu$ s set-up times between programming or erasure and verification;
- attempting to program before V<sub>PP</sub> is at 12V (Capacitive Load)
- not latching the erase verify address with the erase verify command, or changing the address on the subsequent read cycle;

Chapters three and four discuss the correct methods of developing and debugging code to diminish the possibility of making these mistakes.



### ENGINEERING REPORT

Intel Flash Memory 28F256A 28F512 28F010 28F020

October 1993

### 5

### Intel Flash Memory 28F256A, 28F512, 28F010, 28F020

| CONTENTS            | PAGE  | CONTENTS           | PAGE  |
|---------------------|-------|--------------------|-------|
| INTRODUCTION        | 5-186 | DEVICE RELIABILITY | 5-187 |
| TECHNOLOGY OVERVIEW | 5-186 | SUMMARY            | 5-188 |
| DEVICE ARCHITECTURE | 5-186 | ,                  |       |



### INTRODUCTION

Intel's ETOX (EPROM tunnel oxide) Flash Memory adds electrical chip erasure and reprogramming to EPROM non-volatility and ease of use. Advances in tunnel oxides and photolithography have made it possible to develop a double-polysilicon single-transistor read/write random access nonvolatile memory, capable of greater than 100,000 reprogramming cycles. Intel Flash Memory electrically erases all bits in the array matrix via electron tunneling. The EPROM programming mechanism of hot electron injection is employed for electrical byte programming.

A command port interface, internal margin voltage generation, power up/down protection and address and data latches augment standard EPROM circuitry to optimize Intel's Flash Memory for microprocessor-controlled reprogramming.

Read timing parameters on Intel's 28F256A, 28F512, 28F010 and 28F020 are equivalent to those of CMOS EPROMs, EEPROMs, and SRAMs. Access times as fast as 65 ns result from a memory cell current of approximately 50  $\mu$ A, low resistance poly-silicide wordlines, advanced scaled periphery transistors, and an optimized data-out buffer.

### **TECHNOLOGY OVERVIEW**

Intel's ETOX flash memory technology is derived from its standard CMOS EPROM process base. Using advanced 1.0  $\mu$ m and 0.8  $\mu$ m double-polysilicon n-well CMOS technology, Intel Flash Memory employs a 3.8  $\mu$ m x 4.0  $\mu$ m single transistor cell (1.0  $\mu$ m) technology and a 2.5  $\mu$ m x 2.9  $\mu$ m single transistor cell (0.8  $\mu$ m technology), affording equivalent array density as comparable EPROM technology. The flash memory cell structure is identical to the EPROM structure, except for the thinner gate (tunnel) oxide. Figure 1 compares the flash memory cell to the EPROM cell.

High quality tunnel oxide under the single floating polysilicon gate promotes electrical erasure. All cells in the array are simultaneously erased via Fowler-Nordheim tunneling. Applying 12V on the source junctions and grounding the select gates erases the entire array in one second (typical). Programming is accomplished with the standard EPROM mechanism of hot electron injection from the cell drain junction to the floating gate. Programming is initiated by bringing both the select gate and the cell drain to high voltage. Programming occurs at a rate of 10  $\mu$ s pulses per byte.

### **DEVICE ARCHITECTURE**

### **Command Port**

One feature which differentiates Intel's Flash Memory is the command port architecture, illustrated in Figure 2.

The command port simplifies microprocessor control of the erase, erase verify, program, program verify, and read operations, without the need for additional control pins or the multiplexing of high voltage with control functions. On-chip address and data latches minimize system interface logic and free the system bus during erase and program operations. High voltage (12V) on the V<sub>PP</sub> pin enables the command port. In the absence of this high voltage, the command port defaults to the read operation, inhibiting erasure or programming of the device.



Figure 1. EPROM Cell vs. Flash Memory Cell

The command port consists of a command register, command decoder and state latch, the data-in latch, and the address latch. The command decoder output directs the operation of the high voltage flash-erase switch, program voltage generator, and the erase/program verify voltage generator.

Functions are selected via the command port in a microprocessor write cycle controlled by the Chip-Enable and Write-Enable pins. Contents of the address latch are updated on the falling edge of Write-Enable. The rising edge of Write-Enable latches the command and data registers, and initiates operations.



### **Erasure**

Erasure is achieved through a two-step write sequence. The erase set-up code is written to the command register in the first cycle. The erase confirmation code is written in the second cycle. The rising edge of this second Write-Enable pulse initiates the erase operation. The command decoder triggers the high voltage flasherase switch, connecting the 12V supply to the source of all bits in the array, while all wordlines are grounded. Fowler-Nordheim tunneling results in the simultaneous erasure of all bits.

The array source switch, shown in Figure 3, switches high voltage onto the source junctions. During erasure, the high voltage latch formed by  $M_5$  through  $M_8$  enables transistor  $M_{15}$ . Transistor  $M_{15}$  pulls the array source up to 12V. Transistor  $M_{16}$  pulls the source to ground during read and program operations.

To obtain fast erase times, the device must supply the grounded gate breakdown current which occurs on the sources of the memory array. The upper boundary for current sourcing capability of  $M_{15}$  is set by the maximum allowable substrate current. If  $V_{PP}$  is raised to 12V before  $V_{CC}$  is above approximately 1.8V, the low  $V_{CC}$  detect circuit formed by transistors  $M_1$  to  $M_4$  drives the node LOW  $V_{CC}$  to 9V. Transistors  $M_9$  to  $M_{11}$  then force the erase circuit into a non-erase state with  $M_{15}$  off and  $M_{16}$  on. When  $V_{CC}$  rises above 1.8V, the chip will be reset into the read state.

Writing the erase verify code into the command register terminates erasure, latches the address of the byte to verify, and sets the internally-generated erase margin voltage. The microprocessor then accesses the output from the addressed byte using standard read timings. The verify procedure repeats for all addresses. Should a byte require more time to reach the erased state, another erase operation is applied. The erase and verify operations continue until the entire array is erased.

### **Programming**

Programming follows a similar flow. The program setup command is written to the command register on the first cycle. The second cycle loads the address and data latches. The rising edge of the second Write-Enable pulse initiates programming by applying high voltage to the gates and drains of the bits to be programmed. Writing the program verify command to the register terminates the programming operation and applies the program verify voltage to the newly programmed byte. Again, the addressed byte can be read using standard microprocessor read timings. Should the addressed byte require more time to reach the programmed state, the programming operation and verification are repeated until the byte is programmed.

### **DEVICE RELIABILITY**

### **Cell Margining**

Erase and program verification ensure the data retention of the newly altered memory bits. The cell margining performed in the Quick-Pulse Programming and Quick-Erase algorithms is more reliable than historical overpulsing schemes as margining tests the amount of charge stored on the floating gate.

Intel's 28F256A through 28F020 Flash Memories employ a unique circuit to internally generate the erase and program verify voltages. Figure 4 shows a simplified version of the circuit. The circuit consists of a high voltage switch and the verify voltage generator. Transistors M<sub>1</sub> through M<sub>4</sub> constitute the high voltage switch which disconnects V<sub>PP</sub> from the resistor when the device is not in the verify mode. The verify voltage generator includes a resistor divider and a buffer. Internal margin voltage generation maintains microprocessor compatibility by eliminating the need for external reference voltages.

### Erase/Program Cycling

One of the most significant aspects of Intel Flash Memory is its capability for greater than 100,000 erase/program cycles. Destructive oxide breakdown has been a limiting factor in extended cycling of thin oxide EEPROMs. Intel's ETOX flash memory technology extends cycling performance through: improved tunnel oxide processing that increases charge carrying capability ten-fold; reduced oxide area under stress minimizing probability of oxide defects in the region; and reduced oxide stress due to a lower peak electric field (lower erase voltage than EEPROM).



A typical cell erase/program margin (Vt) is shown as a function of reprogramming cycles in Figure 5. After 100,000 reprogramming cycles, a 2.5V program read margin exists, ensuring reliable data retention.

Reliable erase/program cycling also requires proper selection of the erase Vt maximum and maintenance of a tight Vt distribution. The maximum erased Vt is set to 3.2V via the erase algorithm and the internal erase verify circuits. Superior oxide quality gives an erased Vt distribution width that improves slightly with cycling (Figure 6). The tight erase Vt distribution gives an order of magnitude of erase time margin to the fastest erasing cell (Figure 7).

### SUMMARY

Intel's ETOX flash memory technology is a breakthrough in adding electrical chip-erasure to high-density EPROM technology. Intel's CMOS Flash Memory offers the most cost-effective and reliable alternative for read/write random access non-volatile memory. Microprocessor-compatible specifications, straightforward interfacing, and in circuit alterability allow designers to easily augment memory flexibility and satisfy the need for nonvolatile storage in today's designs.



Figure 2. Command Port Block Diagram





Figure 3. Array Source Switch



Figure 4. Erase/Program Verify Generator



Figure 5. 1M Array V<sub>t</sub> vs Cycles



Figure 6. Erase V<sub>t</sub> Distribution vs Cycling





Figure 7. Array Erase V<sub>t</sub> vs Erase Time





Figure 8. 28F256A Die Photograph





intel®

Figure 9. 28F512 Die Photograph





Figure 10. 28F010 (1.0 $\mu$ ) Die Photograph





Figure 11. 28F020 Die (1.0 $\mu$ ) Photograph





Figure 12. Flash Memory Pinouts





Figure 13. Flash Memory Pinouts





**Figure 14. Flash Memory Pinouts** 



Columns are number 0 through 511 beginning with the column nearest the X-decoder. Outputs are grouped as follows:

|                 |                 | Array O         | rganiza        | ation:         |                |                | 100 101                                                                         | If Array<br>IO <sub>2</sub> IO <sub>3</sub><br>← BL <sub>0</sub> | Right Half Array<br>IO <sub>4</sub> IO <sub>5</sub> IO <sub>6</sub> IO <sub>7</sub><br>BL <sub>0</sub> → BL <sub>384</sub> |                                   |  |  |  |
|-----------------|-----------------|-----------------|----------------|----------------|----------------|----------------|---------------------------------------------------------------------------------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|--|--|
|                 |                 | Ac              | dress          |                |                |                |                                                                                 | Bitli                                                            | ines                                                                                                                       |                                   |  |  |  |
| A <sub>14</sub> | A <sub>12</sub> | A <sub>10</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | A <sub>3</sub> | 100 & 107                                                                       | IO <sub>1</sub> & IO <sub>6</sub>                                | 10 <sub>2</sub> & 10 <sub>5</sub>                                                                                          | IO <sub>3</sub> & IO <sub>4</sub> |  |  |  |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | BL <sub>384</sub>                                                               | BL <sub>256</sub>                                                | BL <sub>128</sub>                                                                                                          | BLo                               |  |  |  |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | BL <sub>385</sub>                                                               | BL <sub>257</sub>                                                | BL <sub>129</sub>                                                                                                          | BL <sub>1</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 0              | 1              | 0              | BL <sub>386</sub>                                                               | BL <sub>258</sub>                                                | BL <sub>130</sub>                                                                                                          | BL <sub>2</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 0              | 1              | 1              | BL <sub>387</sub>                                                               | BL <sub>259</sub>                                                | BL <sub>131</sub>                                                                                                          | BL <sub>3</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 0              | 0              | BL <sub>388</sub>                                                               | BL <sub>4</sub>                                                  |                                                                                                                            |                                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 0              | 1              | BL389                                                                           | BL <sub>260</sub><br>BL <sub>261</sub>                           | BL <sub>132</sub><br>BL <sub>133</sub>                                                                                     | BL <sub>5</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 1              | 0              | BL <sub>390</sub>                                                               | BL <sub>262</sub>                                                | BL <sub>134</sub>                                                                                                          | BL <sub>6</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 1              | 1              | BL <sub>391</sub>                                                               | BL <sub>263</sub>                                                | BL <sub>135</sub>                                                                                                          | BL <sub>7</sub>                   |  |  |  |
| •               | •               | •               | •              | •              | •              | •              | •                                                                               | •                                                                | •                                                                                                                          | •                                 |  |  |  |
| 1               | 1 .             | 1 1             | 1              | 1              | 0              | 0              | BL <sub>508</sub> BL <sub>380</sub> BL <sub>252</sub> BL <sub>124</sub>         |                                                                  |                                                                                                                            |                                   |  |  |  |
| 1               | 1               | 1               | 1              | 1              | 0              | 1              | BL <sub>509</sub>                                                               | BL <sub>381</sub>                                                | BL <sub>253</sub>                                                                                                          | BL <sub>125</sub>                 |  |  |  |
| 1               | 1               | 1 1             | 1              | 1              | 1              | 0              | 0   BL <sub>510</sub>   BL <sub>382</sub>   BL <sub>254</sub>   BL <sub>1</sub> |                                                                  |                                                                                                                            |                                   |  |  |  |
| 1               | 1               | 1               | 1              | 1              | 1              | 1              | BL <sub>511</sub>                                                               | BL <sub>383</sub>                                                | BL <sub>255</sub>                                                                                                          | BL <sub>127</sub>                 |  |  |  |

Figure 15. 28F256A Bitline Decoding

|                |                |                | X Ac           | ddress          |                 |                |                | Row                |
|----------------|----------------|----------------|----------------|-----------------|-----------------|----------------|----------------|--------------------|
| A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>13</sub> | A <sub>11</sub> | A <sub>9</sub> | A <sub>8</sub> | WL                 |
| 0              | 0              | 0              | 0              | 0               | 0               | 0              | 0              | XL <sub>0</sub>    |
| 0              | 0              | 0              | 0              | 0               | 0               | 0              | 1 -            | XL <sub>1</sub>    |
| 0              | 0              | 0              | 0              | 0               | 0               | 1              | 0 ,            | XL <sub>2</sub>    |
| 0              | 0              | 0              | 0              | 0               | 0               | 1              | 1              | XL3                |
| 0              | 0              | 0              | 0              | 0               | 1               | 0              | 0              | XL₄                |
| 0              | . 0            | 0              | 0              | 0               | 1               | 0 ~            | 1              | XL <sub>5</sub>    |
| 0              | 0              | 0              | .0             | 0               | 1               | 1              | 0              | XL <sub>6</sub>    |
| 0              | 0              | 0              | 0              | 0               | 1 -             | 1              | 1              | XL <sub>7</sub>    |
| 0              | 0              | 0              | 0              | 1               | 0               | 0              | 0              | XL <sub>8</sub>    |
| 0              | 0              | 0              | 0              | 1               | . 0             | 0              | 1              | XLa                |
| 0              | 0              | 0              | 0              | 1               | ' O .           | 1              | 0              | XL <sub>10</sub>   |
| 0              | 0              | 0              | 0              | 1               | 0               | 1              | 1              | XL11               |
| 0              | . 0            | 0              | 0              | . 1             | 1               | 0              | 0              | XL <sub>12</sub>   |
| 0 ~            | 0              | 0              | 0              | 1               | 1               | 0              | 1              | XL <sub>13</sub>   |
| 0              | 0              | . 0            | 0              | 1               | 1               | 1              | 0              | XL14               |
| 0              | 0              | 0              | 0              | 1               | 1               | 1              | 1              | XL <sub>15</sub>   |
| 0              | . 0            | 0              | 1              | 1               | 1               | 1              | 1              | XL <sub>16</sub>   |
| 0              | 0              | 0              | 1              | 1               | 1               | 1              | 0              | XL <sub>17</sub>   |
| 0              | 0              | √ 0            | 1              | 1               | 1               | 0              | 1              | XL <sub>18</sub>   |
| - 0            | 0              | 0              | 1              | 1 .             | 1               | 0              | 0              | l XL <sub>10</sub> |
| 0              | 0              | 0              | 1              | 1               | 0               | 1              | 1              | l XLan             |
| 0              | 0              | 0              | 1              | 1               | 0               | 1              | 0              | XL <sub>21</sub>   |
| 0              | 0              | 0              | 1              | 1               | 0               | 0              | 1              | l XLoo             |
| 0              | 0              | 0              | 1              | . 1             | - 0             | 0              | 0              | XL23               |
| 0              | 0              | 0              | 1              | 0               | 1               | 1              | 1              | l XL24             |
| 0              | 0 .            | 0              | - 1            | 0               | 1               | 1              | 0              | I XL25             |
| 0              | 0              | 0              | 1              | 0               | 1               | 0              | 1              | l XL26             |
| 0              | 0              | 0              | 1              | 0               | 1               | 0              | 0              | l XL27             |
| 0              | 0              | 0              | 1              | 0               | 0               | 1              | 1              | l XL2g             |
| 0              | 0              | 0              | 1              | 0               | 0               | 1              | 0              | l XL2a             |
| 0              | 0              | 0              | 1              | 0               | 0               | 0              | 1              | l XLan             |
| 0              | 0              | 0              | 1              | 0               | 0               | 0              | 0              | XL <sub>31</sub>   |

Figure 16. 28F256A Wordline Decoding



|                |                |                | X Ad           | dress           |                 | i              |                | Row   |
|----------------|----------------|----------------|----------------|-----------------|-----------------|----------------|----------------|-------|
| A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>13</sub> | A <sub>11</sub> | A <sub>9</sub> | A <sub>8</sub> | WL    |
| 0              | 0              | 1              | 0              | 0               | 0               | 0              | 0              | XL32  |
| •              | •              | •              | •              | •               | •               | •              | •              | • • • |
| 0              | 0              | 1 .            | 0              | 1               | 1               | 1              | 1              | XL47  |
| 0              | 0              | 1              | 1              | 1               | 1               | 1              | 1              | XL48  |
| •              | ●,             | •              | •              | •               | •               | •              | •              | • • • |
| 0              | 0              | 1              | 1              | . 0             | 0               | 0              | 0              | XL63  |
| 0              | 1              | 0              | 0              | 0               | 0               | 0              | 0              | XL64  |
| •              | •              | •              | •              | •               | •               | •              | •              | • • • |
| 0              | 1              | 0              | O              | 1.              | 1               | 1              | 1              | XL79  |
| 0              | 1              | 0              | 1              | 1               | 1               | 1              | 1              | XL80  |
| •              | •              | •              | •              | •               | •               | •              | •              | • • • |
| 0              | 1              | 0              | 1              | 0               | 0               | 0              | 0              | XL95  |
| 1              | 1              | 1              | 0              | 0               | 0               | 0              | 0              | XL234 |
| •              | •              | •              | •              | •               | •               | •              | •              | • • • |
| 1              | 1              | 1 .            | 0              | 1               | 1               | 1              | 1              | XL249 |
| 1              | 1              | 1              | 1              | 1               | 1               | 1              | 1              | XL250 |
| •              | •              | •              | •              | •               | •               | •              | •              | • • • |
| 1              | 1              | 1              | 1              | 0               | 0               | 0              | 0 -            | XL255 |

Figure 16. 28F256A Wordline Decoding (Continued)



Figure 17. 28F256A Bit Map



Columns are numbered 0 through 511 beginning with the column nearest the X-decoder.

Outputs are grouped as follows:

|     |     |    |        |    |    |     | Left Ha | If Array<br>O2 O3 | Right Ha | alf Array<br>O6 O7 |
|-----|-----|----|--------|----|----|-----|---------|-------------------|----------|--------------------|
|     |     | A  | ddress |    |    |     |         | Bitli             | ines     |                    |
| A14 | A15 | А3 | A10    | A2 | A1 | A0  | 100/7   | 101/06            | 102/05   | IO3/04             |
| . 0 | 0   | 0  | 0      | 0  | 0  | 0   | BL384   | BL256             | BL128    | BL0                |
| 0 . | 0   | 1  | 0      | lo | 0  | 0   | BL385   | BL257             | BL129    | BL1                |
| 0   | 0   | 0  | 0      | 0  | 0  | 1 . | BL386   | BL258             | BL130    | BL2                |
| 0   | 0   | 1  | 0      | 0  | 0  | 1 1 | BL387   | BL259             | BL131    | BL3                |
| 0   | 0   | 0  | 0      | 0  | 1  | 0   | BL388   | BL260             | BL132    | BL4                |
| 0   | 0   | 1  | 0      | 0  | 1  | 0   | BL389   | BL261             | BL133    | BL5                |
| 0   | 0   | 0  | 0      | 0  | 1  | 1   | BL390   | BL262             | BL134    | BL6                |
| 0   | 0   | 1  | 0      | 0  | 1  | 1   | BL391   | BL263             | BL135    | BL7                |
| •   | •   | •  | •      | •  | •  | •   | •       | •                 | •        | •                  |
| 1   | 1   | 0  | 1      | 1  | 1  | 0   | BL508   | BL380             | BL252    | BL124              |
| 1   | 1   | 1  | 1      | 1  | 1  | 0   | BL509   | BL381             | BL253    | BL125              |
| 1   | 1 1 | 0  | 1      | 1  | 1  | 1   | BL510   | BL382             | BL254    | BL126              |
| 1   | 1   | 1  | 1      | 1  | 1  | 1   | BL511   | BL383             | BL255    | BL127              |

Figure 18. 28F512 Bitline Decoding

X-DECODING: Wordlines are numbered 0 through 511 beginning at the top of the array.

|     |    | ******************* |            | X Addres | S   |     |     |     | Row  |
|-----|----|---------------------|------------|----------|-----|-----|-----|-----|------|
| A12 | A7 | A6                  | <b>A</b> 5 | A4       | A13 | A11 | A9  | A8  | WL   |
| 0   | 0  | 0                   | 0          | 0        | 0   | 0   | 0   | 0   | XL0  |
| 0   | 0  | 0                   | 0          | 0        | 0   | 0   | 0   | 1   | XL1  |
| 0   | 0  | 0                   | 0          | 0        | 0   | 0   | 1   | 0   | XL2  |
| 0   | 0  | 0                   | 0          | 0        | 0   | 0   | 1   | 1   | XL3  |
| 0   | 0  | 0                   | 0          | 0        | 0   | 1   | 0   | 0   | XL4  |
| 0   | 0  | 0                   | 0          | 0        | 0   | 1   | 0   | 1   | XL5  |
| 0   | 0  | 0                   | 0          | 0        | 0   | 1.  | 1   | 0   | XL6  |
| 0   | 0  | -0                  | 0          | 0        | 0   | 1   | 1   | 1 . | XL7  |
| 0   | 0  | 0                   | 0          | -0       | . 1 | 0   | 0   | 0   | XL8  |
| 0   | 0  | 0                   | 0          | 0        | 1   | 0   | 0   | 1   | XL9  |
| 0   | 0  | 0                   | 0          | 0        | - 1 | 0   | 1   | 0   | XL10 |
| 0   | 0  | 0                   | 0          | 0        | 1   | 0   | 1   | 1   | XL11 |
| 0   | 0  | 0                   | 0          | 0        | 1   | 1   | 0   | 0   | XL12 |
| 0   | 0  | 0                   | 0          | 0        | 1   | 1   | 0   | 1   | XL13 |
| 0   | 0  | 0                   | 0          | . 0      | 1   | 1   | 1   | 0   | XL14 |
| . 0 | 0  | 0                   | 0          | 0        | 1   | 1   | 1   | 1   | XL15 |
| 0   | 0  | 0                   | 0          | 1        | 1   | 1   | 1   | 1   | XL16 |
| 0   | 0  | 0 ,                 | 0          | -1       | 1   | 1   | 1   | . 0 | XL17 |
| 0   | 0  | 0                   | 0          | 1        | 1   | 1   | 0   | 1   | XL18 |
| 0   | 0  | 0                   | 0          | 1 .      | 1   | 1   | 0   | 0   | XL19 |
| 0   | 0  | 0                   | 0          | 1        | 1   | 0   | 1   | 1   | XL20 |
| 0   | 0  | .0                  | 0          | 1        | 1   | 0   | 1   | 0   | XL21 |
| 0   | 0  | 0                   | 0          | 1        | 1   | 0   | 0   | 1   | XL22 |
| 0   | 0  | 0                   | 0          | 1        | 1   | 0   | 0 · | 0   | XL23 |
| 0   | 0  | 0.                  | 0          | 1        | 0   | 1   | 1   | 1   | XL24 |
| 0   | 0  | 0                   | . 0        | 1        | 0   | 1   | 1   | 0   | XL25 |
| 0   | 0  | 0                   | 0          | 1        | 0   | 1   | 0   | 1   | XL26 |
| 0   | 0  | 0                   | 0          | 1        | 0   | 1   | 0   | 0   | XL27 |
| 0   | 0  | 0                   | 0          | 1        | 0   | 0   | 1   | 1.  | XL28 |
| 0   | 0  | 0 '                 | 0          | 1        | 0   | 0   | 1   | 0   | XL29 |
| , 0 | 0  | 0                   | 0          | 1        | 0   | 0   | 0   | 1   | XL30 |
| 0   | 0  | 0                   | 0          | 1        | 0   | 0   | 0   | 0   | XL31 |

Figure 19. 28F512 Wordline Decoding



X-DECODING: Wordlines are number 0 through 511 beginning at the top of the array.

|     | X Address |            |            |     |     |     |     |     |       |  |  |  |  |
|-----|-----------|------------|------------|-----|-----|-----|-----|-----|-------|--|--|--|--|
| A12 | A7        | <b>A</b> 6 | <b>A</b> 5 | A4  | A13 | A11 | A9  | A8  | WL    |  |  |  |  |
| 0   | 0         | 0          | 1          | 0   | 0   | 0   | 0   | 0   | XL32  |  |  |  |  |
| •   | \ •       | •          | •          | •   | •.  | •   | •   | •   | •     |  |  |  |  |
| Ô   | 0         | 0          | 1          | 0   | 1   | 1   | 1   | 1   | XL47  |  |  |  |  |
| 0   | 0         | 0          | 1          | 1   | 1   | 1   | 1   | 1   | XL48  |  |  |  |  |
| •   | •         | •          | •          | •   | •   | •   | •   | •   | •     |  |  |  |  |
| 0   | 0         | 0          | 1          | 1   | 0   | 0   | 0   | 0   | XL63  |  |  |  |  |
| 0 . | 0         | 1          | 0          | 0   | 0   | 0   | 0   | 0   | XL64  |  |  |  |  |
| •   | • ,       | •          | . •        | . • | •   | •   | •   | •   | • 1   |  |  |  |  |
| 0   | 0         | 1          | 0          | 0   | 1   | 1   | 1   | 1 1 | XL79  |  |  |  |  |
| 0   | 0         | 1          | 0          | 1   | 1   | 1   | 1   | 1   | XL80  |  |  |  |  |
| •   | • '       | •          | •          | •   | •   | •   | •   | •   | •     |  |  |  |  |
| . 0 | 0         | 1 '        | 0          | 1   | 0   | 0   | 0   | 0   | XL95  |  |  |  |  |
| 1   | 1 .       | 1          | 1          | 0   | 0   | 0   | 0   | 0   | XL480 |  |  |  |  |
| •   | •         | • .        | •          | •   | •   | •   | •,  | •   | •     |  |  |  |  |
| 1   | 1         | 1          | 1          | 0   | 1   | 1   | 1   | 1   | XL495 |  |  |  |  |
| 1   | 1         | 1          | 1          | 1   | 1   | 1   | 1   | 1   | XL496 |  |  |  |  |
| •   | •         | •          | . •        | •   | •   | •   | • . | •   | •     |  |  |  |  |
| 1   | . 1       | 1          | 1          | 1   | 0   | 0   | 0   | 0   | XL511 |  |  |  |  |

Figure 19. 28F512 Wordline Decoding (Continued)



Figure 20. 28F512 Bit Map



Columns are number 0 through 511 beginning with the column nearest the X-decoder. Outputs are grouped as follows:

|                 |                 | Array O         | rganiza        | ation:         |                |                | 100 101                           | If Array<br>IO <sub>2</sub> IO <sub>3</sub><br>← BL <sub>0</sub> | Right Half Array $IO_4 IO_5 IO_6 IO_7$ $BL_0 \rightarrow BL_{384}$ |                                   |  |  |  |
|-----------------|-----------------|-----------------|----------------|----------------|----------------|----------------|-----------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------|--|--|--|
|                 |                 | Ac              | idress         |                |                |                |                                   | Bitli                                                            | ines                                                               |                                   |  |  |  |
| A <sub>16</sub> | A <sub>15</sub> | A <sub>10</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | A <sub>3</sub> | 10 <sub>0</sub> & 10 <sub>7</sub> | IO <sub>1</sub> & IO <sub>6</sub>                                | IO <sub>2</sub> & IO <sub>5</sub>                                  | IO <sub>3</sub> & IO <sub>4</sub> |  |  |  |
| 0               | . 0             | 0               | 0              | 0              | 0              | 0              | BL <sub>384</sub>                 | BL <sub>256</sub>                                                | BL <sub>128</sub>                                                  | BLO                               |  |  |  |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | BL <sub>385</sub>                 | BL <sub>257</sub>                                                | BL <sub>129</sub>                                                  | BL <sub>1</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 0              | 1              | 0              | BL <sub>386</sub>                 | BL <sub>258</sub>                                                | BL <sub>130</sub>                                                  | BL <sub>2</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 0              | 1              | 1              | BL <sub>387</sub>                 | BL <sub>259</sub>                                                | BL <sub>131</sub>                                                  | BL <sub>3</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 0              | 0              | BL <sub>388</sub>                 | BL <sub>260</sub>                                                | BL <sub>132</sub>                                                  | BL <sub>4</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 0              | 1              | BL <sub>389</sub>                 | BL <sub>261</sub>                                                | BL <sub>133</sub>                                                  | BL <sub>5</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 1              | 0              | BL <sub>390</sub>                 | BL <sub>262</sub>                                                | BL <sub>134</sub>                                                  | BL <sub>6</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1              | 1              | 1              | BL <sub>391</sub>                 | BL <sub>263</sub>                                                | BL <sub>135</sub>                                                  | BL <sub>7</sub>                   |  |  |  |
| •               |                 | •               | . •            | 0              | ٥              | •              | , <b>o</b>                        | •                                                                | •                                                                  | •                                 |  |  |  |
| 1               | 1               | 1               | 1              | 1              | 0              | 0              |                                   |                                                                  |                                                                    |                                   |  |  |  |
| 1               | 1               | 1               | 1              | 1              | 0              | 1              | BL <sub>509</sub>                 | BL <sub>381</sub>                                                | BL <sub>253</sub>                                                  | BL <sub>125</sub>                 |  |  |  |
| 1               | 1               | 1               | 1              | 1              | 1              | 0              | BL <sub>510</sub>                 | BL <sub>382</sub>                                                | BL <sub>254</sub>                                                  | BL <sub>126</sub>                 |  |  |  |
| 1               | 1.              | 1               | 1              | 1              | 1              | 1              | BL <sub>511</sub>                 | BL <sub>383</sub>                                                | BL <sub>255</sub>                                                  | BL <sub>127</sub>                 |  |  |  |

Figure 21. 28F010 Bitline Decoding

|                 |                 |                |                | X Ad           | dress          |                 |                 |                |                | Row              |
|-----------------|-----------------|----------------|----------------|----------------|----------------|-----------------|-----------------|----------------|----------------|------------------|
| A <sub>14</sub> | A <sub>12</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>13</sub> | A <sub>11</sub> | A <sub>9</sub> | A <sub>8</sub> | WL               |
| 0               | 0               | 0              | 0              | 0              | 0              | 0               | 0               | 0              | 0              | XL <sub>0</sub>  |
| 0               | 0               | 0              | 0              | 0              | 0              | 0               | 0               | 0              | 1              | XL <sub>1</sub>  |
| 0               | 0               | 0              | 0              | 0              | 0              | 0               | 0               | 1              | 0              | XL <sub>2</sub>  |
| 0               | 0               | 0              | 0 .            | 0              | . 0            | 0               | 0               | 1              | 1              | XL <sub>3</sub>  |
| 0               | 0               | 0              | 0              | 0              | 0              | 0               | 1               | 0              | 0              | XL <sub>4</sub>  |
| 0               | 0               | 0              | 0              | 0              | 0              | 0               | 1               | 0              | 1              | XL <sub>5</sub>  |
| 0               | × 0             | 0              | 0              | 0              | 0              | 0               | 1               | 1              | 0              | XL <sub>6</sub>  |
| 0               | 0               | 0              | 0              | 0              | 0              | 0               | 1               | 1              | 1              | XL <sub>7</sub>  |
| 0               | . 0             | 0              | 0              | 0              | 0              | 1               | 0               | 0              | 0              | XLa              |
| 0               | 0               | 0              | 0              | 0              | 0              | 1               | 0               | 0              | 1              | XL <sub>9</sub>  |
| 0               | 0               | 0              | 0              | 0              | 0              | 1               | 0               | 1              | 0 .            | XL <sub>10</sub> |
| 0               | 0               | 0              | 0              | 0              | 0              | 1               | 0               | 1              | 1              | XL <sub>11</sub> |
| 0               | 0               | 0              | 0              | 0              | 0              | 1               | 1               | 0              | 0              | XL <sub>12</sub> |
| 0               | 0               | 0              | 0              | 0              | 0              | 1               | 1               | 0              | 1              | XL <sub>13</sub> |
| 0               | 0               | 0              | 0              | 0              | 0              | 1               | 1               | 1              | 0              | XL <sub>14</sub> |
| 0               | 0               | 0              | 0              | 0              | 0              | 1               | 1               | 1              | 1              | XL <sub>15</sub> |
| 0               | 0               | 0              | 0              | 0              | 1              | 1               | 1               | 1′             | 1              | XL <sub>16</sub> |
| 0               | 0               | 0              | .0             | 0              | 1              | 1               | 1               | 1              | 0              | XL <sub>17</sub> |
| 0               | 0               | 0              | 0              | 0              | 1              | 1               | 1               | 0              | 1              | XL <sub>18</sub> |
| 0               | 0               | 0              | 0              | 0              | 1              | 1               | 1               | 0              | 0              | XL <sub>19</sub> |
| 0               | 0               | 0              | 0              | 0              | 1 1            | 1               | 0               | 1              | 1 1            | XL <sub>20</sub> |
| 0               | 0               | 0              | 0              | 0              | 1              | 1               | 0               | 1              | 0              | XL <sub>21</sub> |
| . 0             | 0               | 0              | . 0            | 0              | 1              | 1               | 0               | 0              | 1              | XL <sub>22</sub> |
| 0 .             | .0              | 0              | 0              | . 0            | 1              | 1               | 0               | 0              | 0              | XL <sub>23</sub> |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 1               | 1              | 1              | XL <sub>24</sub> |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 1               | 1              | 0              | XL <sub>25</sub> |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 1               | 0              | 1              | XL26             |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 1               | 0              | 0              | XL27             |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 0               | 1              | 1              | l XL28           |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 0               | 1              | 0              | XL29             |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 0               | 0              | 1              | l XL3n           |
| 0               | 0               | 0              | 0              | 0              | 1              | 0               | 0               | 0              | 0              | XL <sub>31</sub> |

Figure 22. 28F010 Wordline Decoding



|                 | X Address       |                |                |                |     |                 |                 |                |                |        |  |  |
|-----------------|-----------------|----------------|----------------|----------------|-----|-----------------|-----------------|----------------|----------------|--------|--|--|
| A <sub>14</sub> | A <sub>12</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A4  | A <sub>13</sub> | A <sub>11</sub> | A <sub>9</sub> | A <sub>8</sub> | WL     |  |  |
| 0               | 0               | 0              | 0              | 1              | 0   | 0               | 0               | 0              | 0.             | XL32   |  |  |
| •               | •               | •              | • .            | . •            | •   | •               | •               | • *            | •              | • • •  |  |  |
| 0               | 0               | 0              | 0              | 1              | 0   | 1               | 1               | 1              | 1              | XL47   |  |  |
| 0 -             | 0               | 0              | 0              | 1              | 1   | 1               | 1               | 1              | - 1            | XL48   |  |  |
| •               | •               | •              | •              | •              | •   | •               | •               | •              | •              | • • •  |  |  |
| 0 -             | 0               | 0              | 0              | 1              | 1 . | 0               | 0               | 0              | 0              | XL63   |  |  |
| 0               | 0               | 0              | 1              | 0              | 0   | 0               | 0               | 0              | 0              | XL64   |  |  |
| •               | •               | . •            | •              | •              | •   | •               | •               | •              | •              | •••    |  |  |
| 0               | 0               | 0              | 1              | 0              | 0   | 1               | 1               | 1              | - 1            | XL79   |  |  |
| 0               | 0               | 0              | 1              | 0              | 1   | .1              | 1               | 1              | 1              | XL80   |  |  |
| •               | •               | •              | •              | •              | •   | •               | •               | •              | •              | • • •  |  |  |
| 0               | 0               | 0              | 1              | 0              | 1   | 0               | 0               | 0              | 0              | XL95   |  |  |
| 1               | 1               | 1              | 1              | 1              | 0   | 0               | 0               | 0              | 0              | XL992  |  |  |
| •               | • .             | •              | •              | •              | •   |                 | •               | •              | •              | • • •  |  |  |
| 1               | 1               | 1              | 1              | 1              | 0   | 1               | 1               | 1              | 1              | XL1007 |  |  |
| 1               | .1              | 1              | 1              | 1              | 1   | 1               | 1               | 1              | 1              | XL1008 |  |  |
| •               | •               | . •            | •              | •              | •   | •               | •               | •              |                | • • •  |  |  |
| 1               | 1               | 1              | 1              | 1              | 11  | 0               | 0               | 0              | 0              | XL1023 |  |  |

Figure 22. 28F010 Wordline Decoding (Continued)



Figure 23. 28F010 Bit Map



Columns are number 0 through 511 beginning with the column nearest the X-decoder. Outputs are grouped as follows:

|                 |                 | Array O         | rganiza        | ation: |                |                | 100 101                           | If Array<br>IO <sub>2</sub> IO <sub>3</sub><br>← BL <sub>0</sub> | Right Half Array $IO_4 IO_5 IO_6 IO_7$ $BL_0 \rightarrow BL_{384}$ |                                   |  |  |  |
|-----------------|-----------------|-----------------|----------------|--------|----------------|----------------|-----------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------|--|--|--|
|                 |                 | Ac              | ldress         |        |                |                |                                   | Bitlines                                                         |                                                                    |                                   |  |  |  |
| A <sub>16</sub> | A <sub>15</sub> | A <sub>10</sub> | A <sub>2</sub> | Α1     | A <sub>0</sub> | A <sub>3</sub> | IO <sub>0</sub> & IO <sub>7</sub> | IO <sub>1</sub> & IO <sub>6</sub>                                | IO <sub>2</sub> & IO <sub>5</sub>                                  | 1O <sub>3</sub> & 1O <sub>4</sub> |  |  |  |
| 0 -             | 0               | 0               | 0              | 0      | 0              | 0              | BL <sub>384</sub>                 | BL <sub>256</sub>                                                | BL <sub>128</sub>                                                  | BL <sub>0</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 0      | 0              | 1              | BL <sub>385</sub>                 | BL <sub>257</sub>                                                | BL <sub>129</sub>                                                  | BL <sub>1</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 0      | 1              | 0              | BL <sub>386</sub>                 | BL <sub>258</sub>                                                | BL <sub>130</sub>                                                  | BL <sub>2</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 0      | 1              | 1              | BL <sub>387</sub>                 | BL <sub>259</sub>                                                | BL <sub>131</sub>                                                  | BL <sub>3</sub>                   |  |  |  |
| 0               | - 0             | 0               | 0              | 1      | 0              | 0              | BL <sub>388</sub>                 | BL <sub>388</sub>   BL <sub>260</sub>   BL <sub>132</sub>        |                                                                    |                                   |  |  |  |
| 0               | 0               | 0               | 0              | 1      | 0              | 1              | BL <sub>389</sub>                 | BL <sub>261</sub>                                                | BL <sub>133</sub>                                                  | BL <sub>5</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1      | 1              | 0              | BL <sub>390</sub>                 | BL <sub>262</sub>                                                | BL <sub>134</sub>                                                  | BL <sub>6</sub>                   |  |  |  |
| 0               | 0               | 0               | 0              | 1      | 1              | 1              | BL <sub>391</sub>                 | BL <sub>263</sub>                                                | BL <sub>135</sub>                                                  | BL <sub>7</sub>                   |  |  |  |
| .•              | •               | •               | •              | •      |                | •              | •                                 | •                                                                | •                                                                  | •                                 |  |  |  |
| 1               | 1               | 1 1             | 1              | 1      | 0              | 0              | BL <sub>508</sub>                 | BL <sub>380</sub>                                                | BL <sub>252</sub>                                                  | BL <sub>124</sub>                 |  |  |  |
| 1               | 1               | 1               | 1              | 1      | 0              | 1              | BL <sub>509</sub>                 | BL <sub>381</sub>                                                | BL <sub>253</sub>                                                  | BL <sub>125</sub>                 |  |  |  |
| 1               | 1               | 1               | 1              | 1      | 1              | 0              | BL <sub>510</sub>                 | BL <sub>382</sub>                                                | BL <sub>254</sub>                                                  | BL <sub>126</sub>                 |  |  |  |
| 1               | 1               | 1               | 1              | _ 1    | 1              | 1              | BL <sub>511</sub>                 | BL <sub>383</sub>                                                | BL <sub>255</sub>                                                  | BL <sub>127</sub>                 |  |  |  |

Figure 24. 28F020 Bitline Decoding

|                 |                 |                 |                | Х              | Addres         | s              |                 |                 |                |                | Row                 |
|-----------------|-----------------|-----------------|----------------|----------------|----------------|----------------|-----------------|-----------------|----------------|----------------|---------------------|
| A <sub>17</sub> | A <sub>14</sub> | A <sub>12</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>13</sub> | A <sub>11</sub> | A <sub>9</sub> | A <sub>8</sub> | WL                  |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 0               | 0               | 0              | 0              | XL <sub>0</sub>     |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 0               | 0               | 0              | . 1            | XL <sub>1</sub>     |
| .0              | . 0             | 0               | 0              | 0              | 0              | 0              | 0               | 0               | 1              | 0              | XL2                 |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 0               | 0               | 1              | 1              | XL <sub>3</sub>     |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 0               | 1               | 0              | 0              | l XL₄ l             |
| 0 .             | 0               | 0               | 0              | 0              | . 0            | 0              | 0               | 1               | 0              | 1              | XL <sub>5</sub>     |
| 0               | 0               | 0               | 0              | 0 .            | 0              | 0              | 0               | 1               | 1              | 0              | l XL <sub>6</sub> l |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 0               | 1               | 1              | 1              | $ XL_7 $            |
| 0               | 0               | 0               | 0              | -0             | 0              | 0              | 1               | 0               | 0              | 0              | XLa                 |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 1               | 0               | 0              | 1              | l XL₀ l             |
| 0               | 0               | . 0             | 0              | 0              | 0              | 0              | 1               | 0               | 1              | 0              | XL <sub>10</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 1               | 0               | 1              | 1              | XL <sub>11</sub>    |
| 0               | • 0             | 0               | 0              | 0              | 0              | 0              | 1               | 1               | 0              | 0              | XL12                |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 1               | 1               | . 0            | 1              | XL <sub>13</sub>    |
| 0               | 0 ,             | 0               | 0              | 0              | 0              | 0              | 1               | 1               | 1              | 0              | XL14                |
| 0               | 0               | 0               | 0              | 0              | 0              | 0              | 1               | 1               | 1              | 1              | XL <sub>15</sub>    |
| 0               | . 0             | 0               | 0              | 0              | 0              | 1.             | 1               | 1               | 1              | 1              | XL <sub>16</sub>    |
| 0               | . 0             | 0               | 0              | 0              | 0              | 1              | 1               | 1               | 1              | 0              | XL <sub>17</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | 1.              | 1               | 0              | 1              | l XL₁a l            |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | 1               | 1               | 0              | 0              | XL <sub>19</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | 1               | 0               | 1              | 1              | l XLan I            |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | 1               | 0               | 1              | 0              | XL <sub>21</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | 1               | 0               | 0              | 1              | XL <sub>22</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              | ] ]            | 1               | 0               | 0              | 0              | XL <sub>23</sub>    |
| 0               | 0 ;             | 0               | 0              | 0              | 0              | ]              | 0               | ]               | ]              | 1              | XL <sub>24</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              |                | 0               | ]               | 1              | 0              | XL <sub>25</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              |                | 0               | ]               | 0              | 1              | XL <sub>26</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              |                | 0               | 1               | 0              | 0              | XL27                |
| 0               | 0               | 0               | 0              | 0              | 0              |                | 0               | 0               | - 1            | 1              | XL <sub>28</sub>    |
| 0               | 0               |                 |                | 0              | 0              |                | 0               | 0               | 1              | 0              | XL <sub>29</sub>    |
| 0               | 0               | 0               | 0              | 0              | 0              | 1              | 0               | 0               | 0              | 1 0            | XL <sub>30</sub>    |
|                 | U               | U               |                | U              |                | <u> </u>       | U               |                 | U              |                | XL <sub>31</sub>    |

Figure 25. 28F020 Wordline Decoding



| X Address       |                 |                 |                |                |                       |                |                 |                 |                |                |         |  |
|-----------------|-----------------|-----------------|----------------|----------------|-----------------------|----------------|-----------------|-----------------|----------------|----------------|---------|--|
| A <sub>17</sub> | A <sub>14</sub> | A <sub>12</sub> | A <sub>7</sub> | A <sub>6</sub> | <b>A</b> <sub>5</sub> | A <sub>4</sub> | A <sub>13</sub> | A <sub>11</sub> | A <sub>9</sub> | A <sub>8</sub> | WL      |  |
| 0               | 0               | 0               | 0              | 0              | 1                     | 0              | . 0             | 0               | 0              | . 0            | XL32    |  |
| • .             | •               | ' •             | •              | • ,            | •                     | •              | •               | •               | •              | •              | •••     |  |
| 0               | 0               | 0               | 0              | 0              | 1                     | 0              | 1               | 1               | 1              | 1              | XL47    |  |
| 0               | Ö               | 0               | . 0            | 0              | 1                     | 1              | 1               | 1 .             | 1              | 1              | XL48    |  |
| •               | •               | •               | •              | •              | •                     | •              | •               | •.              | •              | •              | • • •   |  |
| 0               | 0 -             | 0               | 0              | 0              | 1                     | 1              | 0               | . 0             | 0              | 0              | XL63    |  |
| 0               | . 0             | 0               | 0              | 1              | 0                     | 0              | 0               | 0               | 0              | 0              | XL64    |  |
| •               | •               | •               | •              | • :            | , •                   | •              | •               | •               | •              | •              | . • • • |  |
| 0               | 0               | 0               | 0              | 1              | 0                     | 0              | 1               | 1               | 1              | 1              | XL79    |  |
| 0               | 0               | 0               | 0              | 1              | 0                     | 1              | 1               | 1               | 1              | 1              | XL80    |  |
| •               | •               | , •             | •              | •              | •                     | •              | •               | •               | •              | •              | • • •   |  |
| 0               | 0               | 0               | 0              | 1              | 0                     | 1              | 0               | 0               | 0              | 0              | XL95    |  |
| 0               | 1               | 1               | 1              | 1              | 1                     | 0              | 0               | 0               | 0              | 0              | XL992   |  |
| •               | •               | •               | •              | •              | •                     | •              | •               | •               | •              | •              | • • •   |  |
| 0               | 1.              | 1               | 1              | 1              | 1                     | 0              | 1               | 1               | 1              | 1              | XL1007  |  |
| 0               | 1               | 1               | 1              | . 1            | 1                     | 1              | 1               | 1               | 1              | 1              | XL1008  |  |
| •               | • .             | •               | •              | •              | •                     | •              | •               | •               | •              | •              | • • •   |  |
| 0               | 1               | 1               | 1              | 1              | 1                     | 1              | 0               | 0               | 0              | 0              | XL1023  |  |
| 1               | 1               | 1               | 1              | 1              | 1                     | 1              | 0               | 0               | 0              | 0              | XL2016  |  |
| •               | •               | •               | •              | •              | •                     | •              | • .             | •               | \ ●            | •              | • • •   |  |
| 1               | 1               | 1               | 1              | 1              | 1                     | 0              | 1               | 1               | 1              | 1              | XL2031  |  |
| 1 1             | 1               | 1               | 1              | 1              | 1                     | 1              | 1               | 1               | 1              | 1              | XL2032  |  |
| •               | •               | •               | •              | •              | •                     | •              | •               | •               | •              | •              | • • •   |  |
| 1 `             | 、1              | 1               | 1              | 1              | 1                     | 1              | 0               | 0               | 0              | 0              | XL2047  |  |

Figure 25. 28F020 Wordline Decoding (Continued)



Figure 26. 28F020 Bit Map

## Flash Memory

Since the early 1970s, semiconductor memory devices have helped pave the way for smaller, lighter, more sophisticated computing products. The most compelling of these is flash memory—a technology in which Intel has remained the market-segment leader for over seven years.

Intel Flash offers design engineers an entirely new memory alternative. Because flash is a high density, nonvolatile read/write technology, it is both a cost-effective and reliable replacement for EPROMs, EEPROMs, DRAMs, battery-backed RAM and rotating media. Flash's inherent advantages over these technologies make it especially useful in portable systems that require low power, compact size and ruggedness while maintaining solid-state performance and full functionality.

This databook is devoted to techniques and information to help design flash memory into an application or system. Informative datasheets provide many comprehensive charts, block diagrams, operating characteristics and programming modes. Application notes provide diagrams and hardware design information. Relevant article reprints are also included.

intel

Order Number: .210830-014 Printed in USA/0195/21K/RRD/TS Memory Products



