# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



## Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





## S25FS128S S25FS256S

## 1.8 V, Serial Peripheral Interface with Multi-I/O, MirrorBit<sup>®</sup> Non-Volatile Flash

## **Features**

- Density
  - S25FS128S-128 Mbits (16 Mbytes)
  - S25FS256S-256 Mbits (32 Mbytes)
- Serial Peripheral Interface (SPI)
  - SPI Clock polarity and phase modes 0 and 3
  - Double Data Rate (DDR) option
  - Extended Addressing: 24- or 32-bit address options
  - Serial Command subset and footprint compatible with S25FL-A, S25FL-K, S25FL-P, and S25FL-S SPI families
  - Multi I/O Command subset and footprint compatible with S25FL-P, and S25FL-S SPI families
- Read
  - Commands: Normal, Fast, Dual I/O, Quad I/O, DDR Quad I/O
  - Modes: Burst Wrap, Continuous (XIP), QPI
  - Serial Flash Discoverable Parameters (SFDP) and Common Flash Interface (CFI), for configuration information
- Program
  - 256- or 512-byte Page Programming buffer
  - Program suspend and resume
  - Automatic ECC internal hardware Error Correction Code generation with single-bit error correction
- Erase
  - Hybrid sector option
    - Physical set of eight 4-kbyte sectors and one 32-kbyte sector at the top or bottom of address space with all remaining sectors of 64 kbytes
  - Uniform sector option
    - Uniform 64-kbyte or 256-kbyte blocks for software compatibility with higher density and future devices
  - Erase suspend and resume
  - Erase status evaluation
  - 100,000 Program-Erase Cycles, minimum
  - 20 Year Data Retention, minimum

- Security Features
  - One-Time Program (OTP) array of 1024 bytes
  - Block Protection:
    - Status Register bits to control protection against program or erase of a contiguous range of sectors
    - Hardware and software control options
  - Advanced Sector Protection (ASP)
    - Individual sector protection controlled by boot code or password
    - Option for password control of read access
- Technology
  - Cypress 65 nm MirrorBit<sup>®</sup> Technology with Eclipse<sup>™</sup>
     Architecture
- Supply Voltage
  - $-\,1.7V$  to 2.0V
- Temperature Range / Grade
  - Industrial (-40°C to +85°C)
  - Industrial Plus (–40°C to +105°C)
  - Automotive AEC-Q100 Grade 3 (–40°C to +85°C)
  - Automotive AEC-Q100 Grade 2 (–40°C to +105°C)
  - Automotive AEC-Q100 Grade 1 (–40°C to +125°C)
- Packages (All Pb-Free)
  - 8-lead SOIC 208 mil (SOC008) FS128S only
  - WSON 6 × 5 mm (WND008) FS128S only
  - WSON 6 × 8 mm (WNH008)
  - 16-lead SOIC 300 mil (SO3016 FS256S only)
  - BGA-24 6 × 8 mm
    - $-5 \times 5$  ball (FAB024) footprint
    - 4 × 6 ball (FAC024) footprint
  - Known Good Die, and Known Tested Die

198 Champion Court

San Jose, CA 95134-1709 • 408-943-2600 Revised April 21, 2017



## **Performance Summary**

#### **Maximum Read Rates**

| Command   | Clock Rate (MHz) | Mbytes/s |
|-----------|------------------|----------|
| Read      | 50               | 6.25     |
| Fast Read | 133              | 16.5     |
| Dual Read | 133              | 33       |
| Quad Read | 133              | 66       |

#### Maximum Read Rates DDR

| Command           | Clock Rate (MHz) | Mbytes/s |
|-------------------|------------------|----------|
| DDR Quad I/O Read | 80               | 80       |

#### Typical Program and Erase Rates

| Operation                                              | kbytes/s |
|--------------------------------------------------------|----------|
| Page Programming (256-bytes Page Buffer)               | 712      |
| Page Programming (512-bytes Page Buffer)               | 1080     |
| 4-kbyte Physical Sector Erase (Hybrid Sector Option)   | 16       |
| 64-kbyte Physical Sector Erase (Hybrid Sector Option)  | 275      |
| 256-kbyte Sector Erase (Uniform Logical Sector Option) | 275      |

#### Typical Current Consumption (–40°C to +85°C)

| Operation            | Current (mA) |
|----------------------|--------------|
| Serial Read 50 MHz   | 10           |
| Serial Read 133 MHz  | 20           |
| Quad Read 133 MHz    | 60           |
| Quad DDR Read 80 MHz | 70           |
| Program              | 60           |
| Erase                | 60           |
| Standby              | 0.025        |
| Deep Power-Down      | 0.006        |



## Contents

| Perfo                                               | ormance Summary                                                                                                                                                                                                                                                                                                                                                                                 | . 2                                                                               |
|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| <b>1.</b><br>1.1<br>1.2<br>1.3<br>1.4               | Overview<br>General Description<br>Migration Notes.<br>Glossary<br>Other Resources.                                                                                                                                                                                                                                                                                                             | . 4<br>. 5<br>. 7                                                                 |
| 2.11<br>2.12<br>2.13                                | Signal Descriptions<br>Input/Output Summary<br>Multiple Input / Output (MIO)<br>Serial Clock (SCK)<br>Chip Select (CS#)<br>Serial Input (SI) / IOO<br>Serial Output (SO) / IO1<br>Write Protect (WP#) / IO2<br>IO3 / RESET#<br>Voltage Supply (VCC)<br>Supply and Signal Ground (V <sub>SS</sub> )<br>Not Connected (NC)<br>Reserved for Future Use (RFU)<br>Do Not Use (DNU)<br>Block Diagrams | . 9<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>11<br>11<br>11<br>11<br>11 |
| <b>3.</b><br>3.1<br>3.2<br>3.3<br>3.4<br>3.5        | Signal Protocols.<br>SPI Clock Modes<br>Command Protocol<br>Interface States.<br>Configuration Register Effects on the Interface<br>Data Protection                                                                                                                                                                                                                                             | 13<br>14<br>18<br>21                                                              |
| <b>4.</b><br>4.1<br>4.2<br>4.3<br>4.4<br>4.5<br>4.6 | Electrical Specifications<br>Absolute Maximum Ratings<br>Thermal Resistance<br>Latch-Up Characteristics<br>Operating Ranges<br>Power-Up and Power-Down<br>DC Characteristics                                                                                                                                                                                                                    | 22<br>22<br>23<br>23<br>24                                                        |
| <b>5.</b> 1<br>5.2<br>5.3<br>5.4<br>5.5             | Timing Specifications<br>Key to Switching Waveforms<br>AC Test Conditions<br>Reset<br>SDR AC Characteristics<br>DDR AC Characteristics                                                                                                                                                                                                                                                          | 27<br>27<br>28<br>30                                                              |
| <b>6.</b><br>6.1<br>6.2<br>6.3<br>6.4               | Physical Interface<br>SOIC 16-Lead Package                                                                                                                                                                                                                                                                                                                                                      | 37<br>41                                                                          |
| <b>7.</b><br>7.1<br>7.2<br>7.3<br>7.4               | Address Space Maps<br>Overview<br>Flash Memory Array<br>ID-CFI Address Space<br>JEDEC JESD216 Serial Flash Discoverable Parameter<br>(SFDP) Space                                                                                                                                                                                                                                               |                                                                                   |

| 7.5<br>7.6                                                       | OTP Address Space                                                                                                                                                                                                                                  |                                                                           |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 8.                                                               | Data Protection                                                                                                                                                                                                                                    | . 67                                                                      |
| 8.1                                                              | Secure Silicon Region (OTP)                                                                                                                                                                                                                        | . 67                                                                      |
| 8.2                                                              | Write Enable Command                                                                                                                                                                                                                               |                                                                           |
| 8.3                                                              | Block Protection                                                                                                                                                                                                                                   |                                                                           |
| 8.4                                                              | Advanced Sector Protection                                                                                                                                                                                                                         |                                                                           |
| 8.5                                                              | Recommended Protection Process                                                                                                                                                                                                                     | . 74                                                                      |
| 9.                                                               | Commands                                                                                                                                                                                                                                           | . 76                                                                      |
| 9.1                                                              | Command Set Summary                                                                                                                                                                                                                                | . 78                                                                      |
| 9.2                                                              | Identification Commands                                                                                                                                                                                                                            |                                                                           |
| 9.3                                                              | Register Access Commands                                                                                                                                                                                                                           |                                                                           |
| 9.4                                                              | Read Memory Array Commands                                                                                                                                                                                                                         |                                                                           |
| 9.5                                                              | Program Flash Array Commands                                                                                                                                                                                                                       |                                                                           |
| 9.6                                                              | Erase Flash Array Commands                                                                                                                                                                                                                         |                                                                           |
| 9.7                                                              | One-Time Program Array Commands                                                                                                                                                                                                                    |                                                                           |
| 9.8<br>9.9                                                       | Advanced Sector Protection Commands<br>Reset Commands                                                                                                                                                                                              |                                                                           |
| 9.9                                                              | Reset Commanus                                                                                                                                                                                                                                     | 110                                                                       |
| 0 10                                                             | DPD Commande                                                                                                                                                                                                                                       | -                                                                         |
| 9.10                                                             | DPD Commands                                                                                                                                                                                                                                       | 120                                                                       |
| 9.10<br><b>10.</b>                                               | DPD Commands Embedded Algorithm Performance Tables                                                                                                                                                                                                 | 120                                                                       |
| 10.<br>11.                                                       | Embedded Algorithm Performance Tables                                                                                                                                                                                                              | 120<br>122<br>123                                                         |
| 10.<br>11.                                                       | Embedded Algorithm Performance Tables                                                                                                                                                                                                              | 120<br>122<br>123                                                         |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2                         | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention                                                                                                                                                       | 120<br>122<br>123<br>123<br>123                                           |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2                         | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention<br>Serial Flash Discoverable Parameters (SFDP) Addres                                                                                                 | 120<br>122<br>123<br>123<br>123<br>55                                     |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2<br>11.3                 | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention<br>Serial Flash Discoverable Parameters (SFDP) Address<br>Map                                                                                         | 120<br>122<br>123<br>123<br>123<br>55<br>123                              |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2<br>11.3                 | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention<br>Serial Flash Discoverable Parameters (SFDP) Addres<br>Map<br>Device ID and Common Flash Interface (ID-CFI) Addres                                  | 120<br>122<br>123<br>123<br>123<br>55<br>123<br>ress                      |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2<br>11.3<br>11.4         | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention<br>Serial Flash Discoverable Parameters (SFDP) Addres<br>Map<br>Device ID and Common Flash Interface (ID-CFI) Addres                                  | 120<br>122<br>123<br>123<br>123<br>55<br>123<br>7ess<br>126               |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2<br>11.3<br>11.4<br>11.5 | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention<br>Serial Flash Discoverable Parameters (SFDP) Addres<br>Map<br>Device ID and Common Flash Interface (ID-CFI) Addres<br>Map<br>Initial Delivery State | 120<br>122<br>123<br>123<br>123<br>55<br>123<br>7ess<br>126<br>143        |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2<br>11.3<br>11.4         | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention<br>Serial Flash Discoverable Parameters (SFDP) Addres<br>Map<br>Device ID and Common Flash Interface (ID-CFI) Addres                                  | 120<br>122<br>123<br>123<br>123<br>55<br>123<br>7ess<br>126<br>143        |
| <b>10.</b><br><b>11.</b><br>11.1<br>11.2<br>11.3<br>11.4<br>11.5 | Embedded Algorithm Performance Tables<br>Data Integrity<br>Erase Endurance<br>Data Retention<br>Serial Flash Discoverable Parameters (SFDP) Addres<br>Map<br>Device ID and Common Flash Interface (ID-CFI) Addres<br>Map<br>Initial Delivery State | 120<br>122<br>123<br>123<br>123<br>55<br>123<br>7ess<br>126<br>143<br>144 |



## 1. Overview

## 1.1 General Description

The Cypress S25FS-S family devices are flash non-volatile memory products using:

- MirrorBit technology that stores two data bits in each memory array transistor
- Eclipse architecture that dramatically improves program and erase performance
- 65 nm process lithography

TheS25FS-S family connects to a host system via a Serial Peripheral Interface (SPI). Traditional SPI single bit serial input and output (Single I/O or SIO) is supported as well as optional 2-bit (Dual I/O or DIO) and 4-bit wide Quad I/O (QIO) or Quad Peripheral Interface (QPI) serial commands. This multiple width interface is called SPI Multi-I/O or MIO. In addition, there are Double Data Rate (DDR) read commands for QIO and QPI that transfer address and read data on both edges of the clock.

The FS-S Eclipse architecture features a Page Programming Buffer that allows up to 512 bytes to be programmed in one operation, resulting in faster effective programming and erase than prior generation SPI program or erase algorithms.

Executing code directly from flash memory is often called Execute-In-Place or XIP. By using S25FS-S family devices at the higher clock rates supported, with Quad or DDR Quad commands, the instruction read transfer rate can match or exceed traditional parallel interface, asynchronous, NOR flash memories, while reducing signal count dramatically.

The S25FS-S family products offer high densities coupled with the flexibility and fast performance required by a variety of mobile or embedded applications. They are an excellent solution for systems with limited space, signal connections, and power. They are ideal for code shadowing to RAM, executing code directly (XIP), and storing reprogrammable data.



## 1.2 Migration Notes

## 1.2.1 Features Comparison

The S25FS-S family is command subset and footprint compatible with prior generation FL-S, FL-K, and FL-P families. However, the power supply and interface voltages are nominal 1.8 V.

#### Cypress SPI Families Comparison

| Parameter                    | FS-S                                    | FL-S                                       | FL-K                                | FL-P                       |
|------------------------------|-----------------------------------------|--------------------------------------------|-------------------------------------|----------------------------|
| Technology Node              | 65 nm                                   | 65 nm                                      | 90 nm                               | 90 nm                      |
| Architecture                 | MirrorBit Eclipse                       | MirrorBit Eclipse                          | Floating Gate                       | MirrorBit                  |
| Density                      | 128 Mb, 256 Mb                          | 128 Mb, 256 Mb, 512 Mb, 1<br>Gb            | 4 Mb - 128 Mb                       | 32 Mb - 256 Mb             |
| Bus Width                    | x1, x2, x4                              | x1, x2, x4                                 | x1, x2, x4                          | x1, x2, x4                 |
| Supply Voltage               | 1.7 V–2.0 V                             | 2.7 V–3.6 V / 1.65 V–3.6 V V <sub>IO</sub> | 2.7 V-3.6 V                         | 2.7 V–3.6 V                |
| Normal Read Speed (SDR)      | 6 MB/s (50 MHz)                         | 6 MB/s (50 MHz)                            | 6 MB/s (50 MHz)                     | 6 MB/s (40 MHz)            |
| Fast Read Speed (SDR)        | 16.5 MB/s (133 MHz)                     | 17 MB/s (133 MHz)                          | 13 MB/s (104 MHz)                   | 13 MB/s (104 MHz)          |
| Dual Read Speed (SDR)        | 33 MB/s (133 MHz)                       | 26 MB/s (104 MHz)                          | 26 MB/s (104 MHz)                   | 20 MB/s (80 MHz)           |
| Quad Read Speed (SDR)        | 66 MB/s (133 MHz)                       | 52 MB/s (104 MHz)                          | 52 MB/s (104 MHz)                   | 40 MB/s (80 MHz)           |
| Quad Read Speed (DDR)        | 80 MB/s (80 MHz)                        | 80 MB/s (80 MHz)                           |                                     |                            |
| Program Buffer Size          | 256B / 512B                             | 256B / 512B                                | 256B                                | 256B                       |
| Erase Sector Size            | 64 kB / 256 kB                          | 64 kB / 256 kB                             | 4 kB / 32 kB / 64 kB                | 64 kB / 256 kB             |
| Parameter Sector Size        | 4 kB (option)                           | 4 kB (option)                              | 4 kB                                | 4 kB                       |
| Sector Erase Rate (typ.)     | 500 kB/s                                | 500 kB/s                                   | 136 kB/s (4 kB)<br>437 kB/s (64 kB) | 130 kB/s                   |
| Page Programming Rate (typ.) | 0.71 MB/s (256B)<br>1.08 MB/s (512B)    | 1.2 MB/s (256B)<br>1.5 MB/s (512B)         | 365 kB/s                            | 170 kB/s                   |
| OTP                          | 1024B                                   | 1024B                                      | 768B (3x256B)                       | 506B                       |
| Advanced Sector Protection   | Yes                                     | Yes                                        | No                                  | No                         |
| Auto Boot Mode               | No                                      | Yes                                        | No                                  | No                         |
| Erase Suspend/Resume         | Yes                                     | Yes                                        | Yes                                 | No                         |
| Program Suspend/Resume       | Yes                                     | Yes                                        | Yes                                 | No                         |
| Deep Power-Down              | Yes                                     | No                                         | Yes                                 | Yes                        |
| Operating Temperature        | –40 °C to +85 °C / +105 °C /<br>+125 °C | –40 °C to +85 °C / +105 °C                 | –40 °C to +85 °C                    | –40 °C to +85 °C / +105 °C |

#### Notes:

1. The 256B program page option only for 128-Mb and 256-Mb density FL-S devices.

2. The FL-P column indicates FL129P MIO SPI device (for 128-Mb density), FL128P does not support MIO, OTP, or 4-kB sectors.

3. 64-kB Sector Erase option only for 128-Mb/256-Mb density FL-P, FL-S and FS-S devices.

4. The FL-K family devices can erase 4-kB sectors in groups of 32 kB or 64 kB.

5. 512-Mb/1-Gb FL-S devices support 256-kB sector only.

6. Only 128-Mb/256-Mb density FL-S devices have 4-kB parameter sector option.

7. Refer to individual data sheets for further details.

## **1.2.2** Known Differences from Prior Generations

#### 1.2.2.1 Error Reporting

FL-K and FL-P memories either do not have error status bits or do not set them if program or erase is attempted on a protected sector. The FS-S and FL-S families do have error reporting status bits for program and erase operations. These can be set when there is an internal failure to program or erase, or when there is an attempt to program or erase a protected sector. In these cases the program or erase operation did not complete as requested by the command. The P\_ERR or E\_ERR bits and the WIP bit will be



set to and remain 1 in SR1V. The clear Status Register command must be sent to clear the errors and return the device to standby state.

#### 1.2.2.2 Secure Silicon Region (OTP)

The FS-S size and format (address map) of the One-Time Program area is different from FL-K and FL-P generations. The method for protecting each portion of the OTP area is different. For additional details see *Secure Silicon Region (OTP) on page 67*.

#### 1.2.2.3 Configuration Register Freeze Bit

The Configuration Register 1 Freeze bit CR1V[0], locks the state of the Block Protection bits (SR1NV[4:2] and SR1V[4:2]), TBPARM\_O bit (CR1NV[2]), and TBPROT\_O bit (CR1NV[5]), as in prior generations. In the FS-S and FL-S families the Freeze bit also locks the state of the Configuration Register 1 BPNV\_O bit (CR1NV[3]), and the Secure Silicon Region (OTP) area.

#### 1.2.2.4 Sector Erase Commands

The command for erasing a 4-kbyte sector is supported only for use on 4-kbyte parameter sectors at the top or bottom of the FS-S device address space.

The command for erasing an 8-kbyte area (two 4-kbyte sectors) is not supported.

The command for erasing a 32-kbyte area (eight 4-kbyte sectors) is not supported.

The Sector Erase command (SE) for FS-S 64-kbyte sectors is supported when the configuration option for uniform 64-kbyte sector is selected or, when the hybrid configuration option for 4-kbyte parameter sectors with 64-kbyte uniform sectors is used. When the hybrid option is in use, the 64-kbyte erase command may be used to erase the 32-kbyte of address space adjacent to the group of eight 4-kbyte sectors. The 64-kbyte erase command in this case is erasing the 64-kbyte sector that is partially overlaid by the group of eight 4-kbyte sectors without affecting the 4-kbyte sectors. This provides erase control over the 32 kbytes of address space without also forcing the erase of the 4-kbyte sectors. This is different behavior than implemented in the FL-S family. In the FL-S family, the 64-kbyte Sector Erase command can be applied to a 64-kbyte block of 4-kbyte sectors to erase the entire block of parameter sectors in a single operation. In the FS-S, the parameter sectors do not fill an entire 64-kbyte block so only the 4-kbyte Parameter Sector Erase (20h) is used to erase parameter sectors.

The erase command for a 256-kbyte sector replaces the 64-kbyte erase command when the configuration option for 256-kbyte uniform logical sectors is used.

#### 1.2.2.5 Deep Power-Down

The Deep Power-Down (DPD) function is supported in the FS-S family of devices.

#### 1.2.2.6 WRR Single Register Write

In some legacy SPI devices, a Write Registers (WRR) command with only one data byte would update Status Register 1 and clear some bits in Configuration Register 1, including the Quad Mode bit. This could result in unintended exit from Quad Mode. The S25FS-S family only updates Status Register 1 when a single data byte is provided. The Configuration Register 1 is not modified in this case.

#### 1.2.2.7 Other Legacy Commands Not Supported

- Autoboot Related Commands
- Bank Address Related Commands
- Dual Output Read
- Quad Output Read
- Quad Page Program (QPP) replaced by Page Program in QPI Mode
- DDR Fast Read
- DDR Dual I/O Read



#### 1.2.2.8 New Features

The FS-S family introduces new features to Cypress SPI category memories:

- Single 1.8V power supply for core and I/O voltage.
- Configurable initial read latency (number of dummy cycles) for faster initial access time or higher clock rate read commands
- Quad Peripheral Interface (QPI, 4-4-4) read mode in which all transfers are 4 bits wide, including instructions

■ JEDEC JESD216 standard, Serial Flash Discoverable Parameters (SFDP) that provide device feature and configuration information.

Evaluate Erase Status command to determine if the last erase operation on a sector completed successfully. This command can be used to detect incomplete erase due to power loss or other causes. This command can be helpful to Flash File System software in file system recovery after a power loss.

Advanced Sector Protection (ASP) Permanent Protection. A bit is added to the ASP register to provide the option to make protection of the Persistent Protection Bits (PPB) permanent. Also, when one of the two ASP protection modes is selected, all OTP configuration bits in all registers are protected from further programming so that all OTP configuration settings are made permanent. The OTP address space is not protected by the selection of an ASP protection mode. The Freeze bit (CR1V[0]) may be used to protect the OTP Address Space.

## 1.3 Glossary

| BCD<br>(Binary Coded Decimal)  | A value in which each 4-bit nibble represents a decimal numeral.                                                                                                                                                                              |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Command                        | All information transferred between the host system and memory during one period while CS# is low. This includes the instruction (sometimes called an operation code or opcode) and any required address, mode bits, latency cycles, or data. |
| DDP<br>(Dual Die Package)      | Two die stacked within the same package to increase the memory capacity of a single package. Often also referred to as a Multi-Chip Package (MCP).                                                                                            |
| DDR<br>(Double Data Rate)      | When input and output are latched on every edge of SCK.                                                                                                                                                                                       |
| ECC                            | ECC Unit = 16 byte aligned and length data groups in the main Flash array and OTP array, each of which has its own hidden ECC syndrome to enable error correction on each group.                                                              |
| Flash                          | The name for a type of Electrical Erase Programmable Read Only Memory (EEPROM) that erases large blocks of memory bits in parallel, making the erase operation much faster than early EEPROM.                                                 |
| High                           | A signal voltage level $\ge$ V <sub>IH</sub> or a logic level representing a binary one (1).                                                                                                                                                  |
| Instruction                    | The 8-bit code indicating the function to be performed by a command (sometimes called<br>an operation code or opcode). The instruction is always the first 8 bits transferred from<br>host system to the memory in any command.               |
| Low                            | A signal voltage level $\leq V_{IL}$ or a logic level representing a binary zero (0).                                                                                                                                                         |
| LSB<br>(Least Significant Bit) | Generally the right most bit, with the lowest order of magnitude value, within a group of bits of a register or data value.                                                                                                                   |
| MSB<br>(Most Significant Bit)  | Generally the left most bit, with the highest order of magnitude value, within a group of bits of a register or data value.                                                                                                                   |
| N/A<br>(Not Applicable)        | A value is not relevant to situation described.                                                                                                                                                                                               |
| Non-Volatile                   | No power is needed to maintain data stored in the memory.                                                                                                                                                                                     |
| OPN                            | Ordering Part Number. The alphanumeric string specifying the memory device type, density, package, factory non-volatile configuration, etc. used to select the desired device.                                                                |
| Page                           | 512-byte or 256-byte aligned and length group of data. The size assigned for a page depends on the Ordering Part Number.                                                                                                                      |
| РСВ                            | Printed Circuit Board.                                                                                                                                                                                                                        |
|                                |                                                                                                                                                                                                                                               |



| Register Bit References   | Are in the format: Register_name[bit_number] or Register_name[bit_range_MSB: bit_range_LSB]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDR<br>(Single Data Rate) | When input is latched on the rising edge and output on the falling edge of SCK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Sector                    | Erase unit size; depending on device model and sector location this may be 4 kbytes, 64 kbytes or 256 kbytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Write                     | An operation that changes data within volatile or non-volatile registers bits or non-volatile flash memory. When changing non-volatile data, an erase and reprogramming of any unchanged non-volatile data is done, as part of the operation, such that the non-volatile data is modified by the write operation, in the same way that volatile data is modified – as a single operation. The non-volatile data appears to the host system to be updated by the single write command, without the need for separate commands for erase and reprogram of adjacent, but unaffected data. |

## 1.4 Other Resources

#### 1.4.1 Cypress Flash Memory Roadmap

http://www.cypress.com/Flash-Roadmap

#### 1.4.2 Links to Software

http://www.cypress.com/software-and-drivers-cypress-flash-memory

### 1.4.3 Links to Application Notes

http://www.cypress.com/cypressappnotes



## Hardware Interface Serial Peripheral Interface with Multiple Input / Output (SPI-MIO)

Many memory devices connect to their host system with separate parallel control, address, and data signals that require a large number of signal connections and larger package size. The large number of connections increase power consumption due to so many signals switching and the larger package increases cost.

The S25FS-S family reduces the number of signals for connection to the host system by serially transferring all control, address, and data information over 4 to 6 signals. This reduces the cost of the memory package, reduces signal switching power, and either reduces the host connection count or frees host connectors for use in providing other features.

The S25FS-S family uses the industry standard single-bit Serial Peripheral Interface (SPI) and also supports optional extension commands for 2-bit (Dual) and 4-bit (Quad) wide serial transfers. This multiple width interface is called SPI Multi-I/O or SPI-MIO.

## 2. Signal Descriptions

## 2.1 Input/Output Summary

#### Signal List

| Signal Name     | Туре     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| SCK             | Input    | Serial Clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| CS#             | Input    | Chip Select.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| SI / IO0        | I/O      | Serial Input for single bit data commands or IO0 for Dual or Quad commands.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| SO / IO1        | I/O      | Serial Output for single bit data commands. IO1 for Dual or Quad commands.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|                 |          | Write Protect when not in Quad Mode (CR1V[1] = 0 and SR1NV[7] = 1).<br>IO2 when in Quad Mode (CR1V[1] = 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| WP# / 102       | I/O      | The signal has an internal pull-up resistor and may be left unconnected in the host system if not used for Quad commands or write protection. If write protection is enabled by $SR1NV[7] = 1$ and $CR1V[1] = 0$ , the host system is required to drive WP# high or low during a WRR or WRAR command.                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|                 |          | <b>IO3</b> in Quad-I/O mode, when Configuration Register 1 QUAD bit, CR1V[1] =1, and CS# is low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| IO3 /<br>RESET# | I/O      | <b>RESET#</b> when enabled by CR2V[5]=1 and not in Quad-I/O mode, CR1V[1] = 0, or when enabled in Quad Mode, CR1V[1] = 1 and CS# is high.                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                 |          | The signal has an internal pull-up resistor and may be left unconnected in the host system if not used for Quad commands or RESET#.                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| V <sub>CC</sub> | Supply   | Power Supply.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| V <sub>SS</sub> | Supply   | Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| NC              | Unused   | <b>Not Connected.</b> No device internal signal is connected to the package connector nor is there any future plan to use the connector for a signal. The connection may safely be used for routing space for a signal on a Printed Circuit Board (PCB). However, any signal connected to an NC must not have voltage levels higher than $V_{CC}$ .                                                                                                                                                                                                                     |  |  |  |  |  |  |
| RFU             | Reserved | <b>Reserved for Future Use.</b> No device internal signal is currently connected to the package connector but there is potential future use of the connector for a signal. It is recommended to not use RFU connectors for PCB routing channels so that the PCB may take advantage of future enhanced features in compatible footprint devices.                                                                                                                                                                                                                         |  |  |  |  |  |  |
| DNU             | Reserved | <b>Do Not Use.</b> A device internal signal may be connected to the package connector. The connection may be used by Cypress for test or other purposes and is not intended for connection to any host system signal. Any DNU signal related function will be inactive when the signal is at V <sub>IL</sub> . The signal has an internal pull-down resistor and may be left unconnected in the host system or may be tied to V <sub>SS</sub> . Do not use these connections for PCB signal routing channels. Do not connect any host system signal to this connection. |  |  |  |  |  |  |



## 2.2 Multiple Input / Output (MIO)

Traditional SPI single bit wide commands (Single or SIO) send information from the host to the memory only on the Serial Input (SI) signal. Data may be sent back to the host serially on the Serial Output (SO) signal.

Dual or Quad Input / Output (I/O) commands send instructions to the memory only on the SI/IO0 signal. Address or data is sent from the host to the memory as bit pairs on IO0 and IO1 or four bit (nibble) groups on IO0, IO1, IO2, and IO3. Data is returned to the host similarly as bit pairs on IO0 and IO1 or four bit (nibble) groups on IO0, IO1, IO2, and IO3.

QPI Mode transfers all instructions, address, and data from the host to the memory as four bit (nibble) groups on IO0, IO1, IO2, and IO3. Data is returned to the host similarly as four bit (nibble) groups on IO0, IO1, IO2, and IO3.

## 2.3 Serial Clock (SCK)

This input signal provides the synchronization reference for the SPI interface. Instructions, addresses, or data input are latched on the rising edge of the SCK signal. Data output changes after the falling edge of SCK, in SDR commands, and after every edge in DDR commands.

## 2.4 Chip Select (CS#)

The Chip Select signal indicates when a command is transferring information to or from the device and the other signals are relevant for the memory device.

When the CS# signal is at the logic high state, the device is not selected and all input signals are ignored and all output signals are high impedance. The device will be in the Standby Power mode, unless an internal embedded operation is in progress. An embedded operation is indicated by the Status Register 1 Write-In-Progress bit (SR1V[1]) set to 1, until the operation is completed. Some example embedded operations are: Program, Erase, or Write Registers (WRR) operations.

Driving the CS# input to the logic low state enables the device, placing it in the Active Power mode. After power-up, a falling edge on CS# is required prior to the start of any command.

## 2.5 Serial Input (SI) / IO0

This input signal is used to transfer data serially into the device. It receives instructions, addresses, and data to be programmed. Values are latched on the rising edge of serial SCK clock signal.

SI becomes IO0 - an input and output during Dual and Quad commands for receiving instructions, addresses, and data to be programmed (values latched on rising edge of serial SCK clock signal) as well as shifting out data (on the falling edge of SCK, in SDR commands, and on every edge of SCK, in DDR commands).

## 2.6 Serial Output (SO) / IO1

This output signal is used to transfer data serially out of the device. Data is shifted out on the falling edge of the serial SCK clock signal.

SO becomes IO1 - an input and output during Dual and Quad commands for receiving addresses, and data to be programmed (values latched on rising edge of serial SCK clock signal) as well as shifting out data (on the falling edge of SCK, in SDR commands, and on every edge of SCK, in DDR commands).

## 2.7 Write Protect (WP#) / IO2

When WP# is driven Low ( $V_{IL}$ ), during a WRR or WRAR command and while the Status Register Write Disable (SRWD\_NV) bit of Status Register 1 (SR1NV[7]) is set to a 1, it is not possible to write to Status Register 1 or Configuration Register 1 related registers. In this situation, a WRR command is ignored, a WRAR command selecting SR1NV, SR1V, CR1NV, or CR1V is ignored, and no error is set.

This prevents any alteration of the Block Protection settings. As a consequence, all the data bytes in the memory area that are protected by the Block Protection feature are also hardware protected against data modification if WP# is Low during a WRR or WRAR command with SRWD\_NV set to 1.



The WP# function is not available when the Quad Mode is enabled (CR1V[1] = 1). The WP# function is replaced by IO2 for input and output during Quad Mode for receiving addresses, and data to be programmed (values are latched on rising edge of the SCK signal) as well as shifting out data (on the falling edge of SCK, in SDR commands, and on every edge of SCK, in DDR commands).

WP# has an internal pull-up resistance; when unconnected, WP# is at V<sub>IH</sub> and may be left unconnected in the host system if not used for Quad Mode or protection.

## 2.8 IO3 / RESET#

IO3 is used for input and output during Quad Mode (CR1V[1] = 1) for receiving addresses, and data to be programmed (values are latched on rising edge of the SCK signal) as well as shifting out data (on the falling edge of SCK, in SDR commands, and on every edge of SCK, in DDR commands).

The IO3 / RESET# signal may also be used to initiate the hardware reset function when the reset feature is enabled by writing Configuration Register 2 non-volatile bit 5 (CR2V[5] = 1). The input is only treated as RESET# when the device is not in Quad-I/O mode, CR1V[1] = 0, or when CS# is high. When Quad I/O mode is in use, CR1V[1]=1, and the device is selected with CS# low, the IO3 / RESET# is used only as IO3 for information transfer. When CS# is high, the IO3 / RESET# is not in use for information transfer and is used as the RESET# input. By conditioning the reset operation on CS# high during Quad Mode, the reset function remains available during Quad Mode.

When the system enters a reset condition, the CS# signal must be driven high as part of the reset process and the IO3 / RESET# signal is driven low. When CS# goes high the IO3 / RESET# input transitions from being IO3 to being the RESET# input. The reset condition is then detected when CS# remains high and the IO3 / RESET# signal remains low for  $t_{RP}$ . If a reset is not intended, the system is required to actively drive IO3 / Reset# to high along with CS# being driven high at the end of a transfer of data to the memory. Following transfers of data to the host system, the memory will drive IO3 high during  $t_{CS}$ . This will ensure that IO3 / Reset is not intended reset is not triggered by the IO3 / RESET# not being recognized as high before the end of  $t_{RP}$ .

The IO3 / RESET# signal is unused when the reset feature is disabled (CR2V[5] = 0).

The IO3 / RESET# signal has an internal pull-up resistor and may be left unconnected in the host system if not used for Quad Mode or the reset function. The internal pull-up will hold IO3 / RESET high after the host system has actively driven the signal high and then stops driving the signal.

Note that IO3 / RESET# cannot be shared by more than one SPI-MIO memory if any of them are operating in Quad I/O mode as IO3 being driven to or from one selected memory may look like a reset signal to a second non-selected memory sharing the same IO3 / RESET# signal.

## 2.9 Voltage Supply (V<sub>CC</sub>)

V<sub>CC</sub> is the voltage source for all device internal logic. It is the single voltage used for all device internal functions including read, program, and erase.

## 2.10 Supply and Signal Ground (V<sub>SS</sub>)

V<sub>SS</sub> is the common voltage drain and ground reference for the device core, input signal receivers, and output drivers.

## 2.11 Not Connected (NC)

No device internal signal is connected to the package connector nor is there any future plan to use the connector for a signal. The connection may safely be used for routing space for a signal on a Printed Circuit Board (PCB).

## 2.12 Reserved for Future Use (RFU)

No device internal signal is currently connected to the package connector but there is potential future use of the connector. It is recommended to not use RFU connectors for PCB routing channels so that the PCB may take advantage of future enhanced features in compatible footprint devices.



## 2.13 Do Not Use (DNU)

A device internal signal may be connected to the package connector. The connection may be used by Cypress for test or other purposes and is not intended for connection to any host system signal. Any DNU signal related function will be inactive when the signal is at  $V_{IL}$ . The signal has an internal pull-down resistor and may be left unconnected in the host system or may be tied to  $V_{SS}$ . Do not use these connections for PCB signal routing channels. Do not connect any host system signal to these connections.

## 2.14 Block Diagrams



Figure 2.1 Bus Master and Memory Devices on the SPI Bus - Single Bit Data Path

Figure 2.2 Bus Master and Memory Devices on the SPI Bus — Dual Bit Data Path







Figure 2.3 Bus Master and Memory Devices on the SPI Bus - Quad Bit Data Path

## 3. Signal Protocols

#### 3.1 SPI Clock Modes

#### 3.1.1 Single Data Rate (SDR)

The S25FS-S family can be driven by an embedded microcontroller (bus master) in either of the two following clocking modes.

- Mode 0 with Clock Polarity (CPOL) = 0 and, Clock Phase (CPHA) = 0
- Mode 3 with CPOL = 1 and, CPHA = 1

For these two modes, input data into the device is always latched in on the rising edge of the SCK signal and the output data is always available from the falling edge of the SCK clock signal.

The difference between the two modes is the clock polarity when the bus master is in standby mode and not transferring any data.

- SCK will stay at logic low state with CPOL = 0, CPHA = 0
- SCK will stay at logic high state with CPOL = 1, CPHA = 1



Figure 3.1 SPI SDR Modes Supported

Timing diagrams throughout the remainder of the document are generally shown as both Mode 0 and 3 by showing SCK as both high and low at the fall of CS#. In some cases a timing diagram may show only Mode 0 with SCK low at the fall of CS#. In such a case, Mode 0 timing simply means the clock is high at the fall of CS# so no SCK rising edge set up or hold time to the falling edge of CS# is needed for Mode 0.

SCK cycles are measured (counted) from one falling edge of SCK to the next falling edge of SCK. In Mode 0 the beginning of the first SCK cycle in a command is measured from the falling edge of CS# to the first falling edge of SCK because SCK is already low at the beginning of a command.



### 3.1.2 Double Data Rate (DDR)

Mode 0 and Mode 3 are also supported for DDR commands. In DDR commands, the instruction bits are always latched on the rising edge of clock, the same as in SDR commands. However, the address and input data that follow the instruction are latched on both the rising and falling edges of SCK. The first address bit is latched on the first rising edge of SCK following the falling edge at the end of the last instruction bit. The first bit of output data is driven on the falling edge at the end of the last access latency (dummy) cycle.

SCK cycles are measured (counted) in the same way as in SDR commands, from one falling edge of SCK to the next falling edge of SCK. In Mode 0 the beginning of the first SCK cycle in a command is measured from the falling edge of CS# to the first falling edge of SCK because SCK is already low at the beginning of a command.



## 3.2 Command Protocol

All communication between the host system and S25FS-S family memory devices is in the form of units called commands.

All commands begin with an 8-bit instruction that selects the type of information transfer or device operation to be performed. Commands may also have an address, instruction modifier, latency period, data transfer to the memory, or data transfer from the memory. All instruction, address, and data information is transferred sequentially between the host system and memory device.

Command protocols are also classified by a numerical nomenclature using three numbers to reference the transfer width of three command phases:

- instruction;
- address and instruction modifier (Continuous Read mode bits);
- data.

Single bit wide commands start with an instruction and may provide an address or data, all sent only on the SI signal. Data may be sent back to the host serially on the SO signal. This is referenced as a 1-1-1 command protocol for single bit width instruction, single bit width address and modifier, single bit data.

Dual or Quad Input / Output (I/O) commands provide an address sent from the host as bit pairs on IO0 and IO1 or, four bit (nibble) groups on IO0, IO1, IO2, and IO3. Data is returned to the host similarly as bit pairs on IO0 and IO1 or, four bit (nibble) groups on IO0, IO1, IO2, and IO3. This is referenced as 1-2-2 for Dual I/O and 1-4-4 for Quad I/O command protocols.

The S25FS-S family also supports a QPI Mode in which all information is transferred in 4-bit width, including the instruction, address, modifier, and data. This is referenced as a 4-4-4 command protocol.

Commands are structured as follows:

Each command begins with CS# going low and ends with CS# returning high. The memory device is selected by the host driving the Chip Select (CS#) signal low throughout a command.

The Serial Clock (SCK) marks the transfer of each bit or group of bits between the host and memory.

■ Each command begins with an 8-bit (byte) instruction. The instruction selects the type of information transfer or device operation to be performed. The instruction transfers occur on SCK rising edges. However, some read commands are modified by a prior read command, such that the instruction is implied from the earlier command. This is called Continuous Read mode. When the device is in Continuous Read mode, the instruction bits are not transmitted at the beginning of the command because the instruction is the same as the read command that initiated the Continuous Read mode. In Continuous Read mode the command will begin with the read address. Thus, Continuous Read mode removes eight instruction bits from each read command in a series of same type read commands.



■ The instruction may be stand alone or may be followed by address bits to select a location within one of several address spaces in the device. The instruction determines the address space used. The address may be either a 24-bit or a 32-bit, byte boundary, address. The address transfers occur on SCK rising edge, in SDR commands, or on every SCK edge, in DDR commands.

■ In legacy SPI mode, the width of all transfers following the instruction are determined by the instruction sent. Following transfers may continue to be single bit serial on only the SI or Serial Output (SO) signals, they may be done in two bit groups per (dual) transfer on the IO0 and IO1 signals, or they may be done in 4-bit groups per (quad) transfer on the IO0-IO3 signals. Within the dual or quad groups the least significant bit is on IO0. More significant bits are placed in significance order on each higher numbered IO signal. Single bits or parallel bit groups are transferred in most to least significant bit order.

In QPI Mode, the width of all transfers is a 4-bit wide (Quad) transfer on the IO0-IO3 signals.

Dual and Quad I/O read instructions send an instruction modifier called Continuous Read mode bits, following the address, to indicate whether the next command will be of the same type with an implied, rather than an explicit, instruction. These mode bits initiate or end the Continuous Read mode. In Continuous Read mode, the next command thus does not provide an instruction byte, only a new address and mode bits. This reduces the time needed to send each command when the same command type is repeated in a sequence of commands. The mode bit transfers occur on SCK rising edge, in SDR commands, or on every SCK edge, in DDR commands.

The address or mode bits may be followed by write data to be stored in the memory device or by a read latency period before read data is returned to the host.

Write data bit transfers occur on SCK rising edge, in SDR commands, or on every SCK edge, in DDR commands.

SCK continues to toggle during any read access latency period. The latency may be zero to several SCK cycles (also referred to as dummy cycles). At the end of the read latency cycles, the first read data bits are driven from the outputs on SCK falling edge at the end of the last read latency cycle. The first read data bits are considered transferred to the host on the following SCK rising edge. Each following transfer occurs on the next SCK rising edge, in SDR commands, or on every SCK edge, in DDR commands.

If the command returns read data to the host, the device continues sending data transfers until the host takes the CS# signal high. The CS# signal can be driven high after any transfer in the read data sequence. This will terminate the command.

■ At the end of a command that does not return data, the host drives the CS# input high. The CS# signal must go high after the eighth bit, of a stand alone instruction or, of the last write data byte that is transferred. That is, the CS# signal must be driven high when the number of bits after the CS# signal was driven low is an exact multiple of eight bits. If the CS# signal does not go high exactly at the eight bit boundary of the instruction or write data, the command is rejected and not executed.

All instruction, address, and mode bits are shifted into the device with the Most Significant Bits (MSB) first. The data bits are shifted in and out of the device MSB first. All data is transferred in byte units with the lowest address byte sent first. The following bytes of data are sent in lowest to highest byte address order i.e. the byte address increments.

All attempts to read the flash memory array during a program, erase, or a write cycle (embedded operations) are ignored. The embedded operation will continue to execute without any affect. A very limited set of commands are accepted during an embedded operation. These are discussed in the individual command descriptions.

Depending on the command, the time for execution varies. A command to read status information from an executing command is available to determine when the command completes execution and whether the command was successful.

#### 3.2.1 Command Sequence Examples







Phase

Instruction





Figure 3.6 Single Bit Wide I/O Command without Latency

Data 1

Data2



Figure 3.7 Single Bit Wide I/O Command with Latency







#### Figure 3.9 Quad I/O Command



#### Figure 3.10 Quad I/O Read Command in QPI Mode



#### Figure 3.11 DDR Quad I/O Read



#### Figure 3.12 DDR Quad I/O Read in QPI Mode

| CS#   | 1     |      |    |    |    |      |      |    |   |   |   |     |   |   |       |       |   |   |    |    |   |   |   |   |   |   |   |  |
|-------|-------|------|----|----|----|------|------|----|---|---|---|-----|---|---|-------|-------|---|---|----|----|---|---|---|---|---|---|---|--|
| SCK   |       |      |    |    |    |      |      |    |   |   |   |     |   |   |       | 1     |   |   |    |    |   |   |   |   |   |   |   |  |
| 100 — | 4     | 0    | 28 | 24 | 20 | 16   | 12   | 8  | 4 | 0 | 4 | 0   | H | ) |       | 7     | 6 | 5 | 4  | 3  | 2 | 1 | 0 | 4 | 0 | 4 | 0 |  |
| IO1 — | 5     | 1    | 29 | 25 | 21 | 17   | 13   | 9  | 5 | 1 | 5 | 1   | H | - |       | <br>7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 | 5 | 1 | 5 | 1 |  |
| IO2 — | 6     | 2    | 30 | 26 | 22 | 18   | 14   | 10 | 6 | 2 | 6 | 2   | H | - |       | 7     | 6 | 5 | 4  | 3  | 2 | 1 | 0 | 6 | 2 | 6 | 2 |  |
| IO3 — | 7     | 3    | 31 | 27 | 23 | 19   | 15   | 11 | 7 | 3 | 7 | 3   | H | ) |       | 7     | 6 | 5 | 4  | 3  | 2 | 1 | 0 | 7 | 3 | 7 | 3 |  |
| Phase | Instr | uct. |    |    |    | Addı | ress |    |   |   | Μ | ode |   |   | Dummy |       |   |   | DL | .P |   |   |   | D | 1 | D | 2 |  |

Additional sequence diagrams, specific to each command, are provided in *Commands on page 76*.



## 3.3 Interface States

This section describes the input and output signal levels as related to the SPI interface behavior.

#### Interface States Summary

| Interface State                                  | V <sub>CC</sub>             | SCK | CS# | IO3 /<br>RESET# | WP# / IO2 | SO / 101 | SI / 100 |
|--------------------------------------------------|-----------------------------|-----|-----|-----------------|-----------|----------|----------|
| Power-Off                                        | <v<sub>CC (low)</v<sub>     | Х   | Х   | Х               | Х         | Z        | Х        |
| Low-Power Hardware Data Protection               | <v<sub>CC (cut-off)</v<sub> | Х   | х   | Х               | Х         | Z        | Х        |
| Power-On (Cold) Reset                            | ≥V <sub>CC</sub> (min)      | Х   | HH  | Х               | Х         | Z        | Х        |
| Hardware (Warm) Reset Non-Quad Mode              | ≥V <sub>CC</sub> (min)      | Х   | х   | HL              | Х         | Z        | Х        |
| Hardware (Warm) Reset Quad Mode                  | ≥V <sub>CC</sub> (min)      | Х   | HH  | HL              | Х         | Z        | Х        |
| Interface Standby                                | ≥V <sub>CC</sub> (min)      | Х   | НН  | х               | Х         | Z        | Х        |
| Instruction Cycle (Legacy SPI)                   | ≥V <sub>CC</sub> (min)      | HT  | HL  | HH              | HV        | Z        | HV       |
| Single Input Cycle<br>Host to Memory Transfer    | ≥V <sub>CC</sub> (min)      | HT  | HL  | НН              | х         | Z        | HV       |
| Single Latency (Dummy) Cycle                     | ≥V <sub>CC</sub> (min)      | HT  | HL  | НН              | Х         | Z        | Х        |
| Single Output Cycle<br>Memory to Host Transfer   | ≥V <sub>CC</sub> (min)      | HT  | HL  | НН              | х         | MV       | х        |
| Dual Input Cycle<br>Host to Memory Transfer      | ≥V <sub>CC</sub> (min)      | HT  | HL  | НН              | х         | HV       | HV       |
| Dual Latency (Dummy) Cycle                       | ≥V <sub>CC</sub> (min)      | HT  | HL  | НН              | Х         | Х        | Х        |
| Dual Output Cycle<br>Memory to Host Transfer     | ≥V <sub>CC</sub> (min)      | HT  | HL  | НН              | х         | MV       | MV       |
| Quad Input Cycle<br>Host to Memory Transfer      | ≥V <sub>CC</sub> (min)      | HT  | HL  | HV              | HV        | HV       | HV       |
| Quad Latency (Dummy) Cycle                       | ≥V <sub>CC</sub> (min)      | HT  | HL  | х               | Х         | Х        | Х        |
| Quad Output Cycle<br>Memory to Host Transfer     | ≥V <sub>CC</sub> (min)      | HT  | HL  | MV              | MV        | MV       | MV       |
| DDR Quad Input Cycle<br>Host to Memory Transfer  | ≥V <sub>CC</sub> (min)      | HT  | HL  | HV              | HV        | HV       | HV       |
| DDR Latency (Dummy) Cycle                        | ≥V <sub>CC</sub> (min)      | HT  | HL  | MV or Z         | MV or Z   | MV or Z  | MV or Z  |
| DDR Quad Output Cycle<br>Memory to Host Transfer | ≥V <sub>CC</sub> (min)      | HT  | HL  | MV              | MV        | MV       | MV       |

Legend

Z = No driver - floating signal

- $HL = Host driving V_{IL}$
- $HH = Host driving V_{IH}$
- HV = Either HL or HH
- X = HL or HH or Z
- HT = Toggling between HL and HH
- $ML = Memory driving V_{IL}$
- $MH = Memory driving V_{IH}$
- MV = Either ML or MH

## 3.3.1 Power-Off

When the core supply voltage is at or below the  $V_{CC (Low)}$  voltage, the device is considered to be powered off. The device does not react to external signals, and is prevented from performing any program or erase operation.

#### 3.3.2 Low-Power Hardware Data Protection

When  $V_{CC}$  is less than  $V_{CC (Cut-off)}$  the memory device will ignore commands to ensure that program and erase operations can not start when the core supply voltage is out of the operating range.



## 3.3.3 Power-On (Cold) Reset

When the core voltage supply remains at or below the  $V_{CC (Low)}$  voltage for  $\geq t_{PD}$  time, then rises to  $\geq V_{CC (Minimum)}$  the device will begin its Power-On Reset (POR) process. POR continues until the end of  $t_{PU}$ . During  $t_{PU}$  the device does not react to external input signals nor drive any outputs. Following the end of  $t_{PU}$  the device transitions to the Interface Standby state and can accept commands. For additional information on POR see *Power-On (Cold) Reset on page 28* 

## 3.3.4 Hardware (Warm) Reset

A configuration option is provided to allow IO3 to be used as a hardware reset input when the device is not in Quad Mode or when it is in Quad Mode and CS# is high. When IO3 / RESET# is driven low for  $t_{RP}$  time the device starts the hardware reset process. The process continues for  $t_{RPH}$  time. Following the end of both  $t_{RPH}$  and the reset hold time following the rise of RESET# ( $t_{RH}$ ) the device transitions to the Interface Standby state and can accept commands. For additional information on hardware reset see *Reset on page 28* 

#### 3.3.5 Interface Standby

When CS# is high the SPI interface is in standby state. Inputs other than RESET# are ignored. The interface waits for the beginning of a new command. The next interface state is Instruction Cycle when CS# goes low to begin a new command.

While in interface standby state the memory device draws standby current (I<sub>SB</sub>) if no embedded algorithm is in progress. If an embedded algorithm is in progress, the related current is drawn until the end of the algorithm when the entire device returns to standby current draw.

A Deep Power-Down (DPD) mode is supported by the FS-S family of devices. If the device has been placed in DPD mode by the DPD (B9h) command, the interface standby current is  $I_{DPD}$ . The DPD command is accepted only while the device is not performing an embedded operation, as indicated by the Status Register-1 volatile Write In Progress (WIP) bit being cleared to zero (SR1V[0]=0). While in DPD mode, the device ignores all commands except the Release from DPD (RES ABh) command, that will return the device to the Interface Standby state after a delay of  $t_{RES}$ .

## 3.3.6 Instruction Cycle (Legacy SPI Mode)

When the host drives the MSB of an instruction and CS# goes low, on the next rising edge of SCK the device captures the MSB of the instruction that begins the new command. On each following rising edge of SCK the device captures the next lower significance bit of the 8-bit instruction. The host keeps CS# low, and drives the Write Protect (WP#) and IO3/RESET signals as needed for the instruction. However, WP# is only relevant during instruction cycles of a WRR or WRAR command and is otherwise ignored. IO3/RESET# is driven high when the device is not in Quad Mode (CR1V[1] = 0) or QPI Mode (CR2V[6] = 0) and hardware reset is not required.

Each instruction selects the address space that is operated on and the transfer format used during the remainder of the command. The transfer format may be Single, Dual I/O, Quad I/O, or DDR Quad I/O. The expected next interface state depends on the instruction received.

Some commands are stand alone, needing no address or data transfer to or from the memory. The host returns CS# high after the rising edge of SCK for the eighth bit of the instruction in such commands. The next interface state in this case is Interface Standby.

## 3.3.7 Instruction Cycle (QPI Mode)

In QPI Mode, when CR2V[6]=1, instructions are transferred 4 bits per cycle. In this mode, instruction cycles are the same as a Quad Input Cycle. See *Quad Input Cycle - Host to Memory Transfer on page 20*.

#### 3.3.8 Single Input Cycle - Host to Memory Transfer

Several commands transfer information after the instruction on the single Serial Input (SI) signal from host to the memory device. The host keeps RESET# high, CS# low, and drives SI as needed for the command. The memory does not drive the Serial Output (SO) signal.

The expected next interface state depends on the instruction. Some instructions continue sending address or data to the memory using additional Single Input Cycles. Others may transition to Single Latency, or directly to Single, Dual, or Quad Output Cycle states.



## 3.3.9 Single Latency (Dummy) Cycle

Read commands may have zero to several latency cycles during which read data is read from the main flash memory array before transfer to the host. The number of latency cycles are determined by the Latency Code in the Configuration Register (CR2V[3:0]). During the latency cycles, the host keeps RESET# high, CS# low. The Write Protect (WP#) signal is ignored. The host may drive the SI signal during these cycles or the host may leave SI floating. The memory does not use any data driven on SI / I/O0 or other I/O signals during the latency cycles. The memory does not drive the Serial Output (SO) or I/O signals during the latency cycles.

The next interface state depends on the command structure i.e. the number of latency cycles, and whether the read is single, dual, or quad width.

### 3.3.10 Single Output Cycle - Memory to Host Transfer

Several commands transfer information back to the host on the single Serial Output (SO) signal. The host keeps RESET# high, CS# low. The Write Protect (WP#) signal is ignored. The memory ignores the Serial Input (SI) signal. The memory drives SO with data.

The next interface state continues to be Single Output Cycle until the host returns CS# to high ending the command.

#### 3.3.11 Dual Input Cycle - Host to Memory Transfer

The Read Dual I/O command transfers two address or mode bits to the memory in each cycle. The host keeps RESET# high, CS# low. The Write Protect (WP#) signal is ignored. The host drives address on SI / IO0 and SO / IO1.

The next interface state following the delivery of address and mode bits is a Dual Latency Cycle if there are latency cycles needed or Dual Output Cycle if no latency is required.

### 3.3.12 Dual Latency (Dummy) Cycle

Read commands may have zero to several latency cycles during which read data is read from the main flash memory array before transfer to the host. The number of latency cycles are determined by the Latency Code in the Configuration Register (CR2V[3:0]). During the latency cycles, the host keeps RESET# high, CS# low. The Write Protect (WP#) signal is ignored. The host may drive the SI / IO0 and SO / IO1 signals during these cycles or the host may leave SI / IO0 and SO / IO1 floating. The memory does not use any data driven on SI / IO0 and SO / IO1 during the latency cycles. The host must stop driving SI / IO0 and SO / IO1 on the falling edge at the end of the last latency cycle. It is recommended that the host stop driving them during all latency cycles so that there is sufficient time for the host drivers to turn off before the memory begins to drive at the end of the latency cycles. This prevents driver conflict between host and memory when the signal direction changes. The memory does not drive the SI / IO0 and SO / IO1 signals during the latency cycles.

The next interface state following the last latency cycle is a Dual Output Cycle.

#### 3.3.13 Dual Output Cycle - Memory to Host Transfer

The Read Dual Output and Read Dual I/O return data to the host two bits in each cycle. The host keeps RESET# high, CS# low. The Write Protect (WP#) signal is ignored. The memory drives data on the SI / IO0 and SO / IO1 signals during the Dual Output Cycles.

The next interface state continues to be Dual Output Cycle until the host returns CS# to high ending the command.

#### 3.3.14 Quad Input Cycle - Host to Memory Transfer

The Quad I/O Read command transfers four address or mode bits to the memory in each cycle. In QPI Mode the Quad I/O Read and Page Program commands transfer four data bits to the memory in each cycle, including the instruction cycles. The host keeps CS# low, and drives the IO signals.

For Quad I/O Read the next interface state following the delivery of address and mode bits is a Quad Latency Cycle if there are latency cycles needed or Quad Output Cycle if no latency is required. For QPI Mode Page Program, the host returns CS# high following the delivery of data to be programmed and the interface returns to standby state.

## 3.3.15 Quad Latency (Dummy) Cycle

Read commands may have zero to several latency cycles during which read data is read from the main flash memory array before transfer to the host. The number of latency cycles are determined by the Latency Code in the Configuration Register (CR2V[3:0]). During the latency cycles, the host keeps CS# low. The host may drive the IO signals during these cycles or the host may leave the



IO floating. The memory does not use any data driven on IO during the latency cycles. The host must stop driving the IO signals on the falling edge at the end of the last latency cycle. It is recommended that the host stop driving them during all latency cycles so that there is sufficient time for the host drivers to turn off before the memory begins to drive at the end of the latency cycles. This prevents driver conflict between host and memory when the signal direction changes. The memory does not drive the IO signals during the latency cycles.

The next interface state following the last latency cycle is a Quad Output Cycle.

#### 3.3.16 Quad Output Cycle - Memory to Host Transfer

The Quad I/O Read returns data to the host four bits in each cycle. The host keeps CS# low. The memory drives data on IO0–IO3 signals during the Quad Output Cycles.

The next interface state continues to be Quad Output Cycle until the host returns CS# to high ending the command.

#### 3.3.17 DDR Quad Input Cycle - Host to Memory Transfer

The DDR Quad I/O Read command sends address, and mode bits to the memory on all the IO signals. Four bits are transferred on the rising edge of SCK and four bits on the falling edge in each cycle. The host keeps CS# low.

The next interface state following the delivery of address and mode bits is a DDR Latency Cycle.

#### 3.3.18 DDR Latency Cycle

DDR Read commands may have one to several latency cycles during which read data is read from the main flash memory array before transfer to the host. The number of latency cycles are determined by the Latency Code in the Configuration Register (CR2V[3:0]). During the latency cycles, the host keeps CS# low. The host may not drive the IO signals during these cycles. So that there is sufficient time for the host drivers to turn off before the memory begins to drive. This prevents driver conflict between host and memory when the signal direction changes. The memory has an option to drive all the IO signals with a Data Learning Pattern (DLP) during the last 4 latency cycles. The DLP option should not be enabled when there are fewer than five latency cycles so that there is at least one cycle of high impedance for turn around of the IO signals before the memory begins driving the DLP. When there are more than 4 cycles of latency the memory does not drive the IO signals until the last four cycles of latency.

The next interface state following the last latency cycle is a DDR Single, or Quad Output Cycle, depending on the instruction.

#### 3.3.19 DDR Quad Output Cycle - Memory to Host Transfer

The DDR Quad I/O Read command returns bits to the host on all the IO signals. Four bits are transferred on the rising edge of SCK and four bits on the falling edge in each cycle. The host keeps CS# low.

The next interface state continues to be DDR Quad Output Cycle until the host returns CS# to high ending the command.

#### 3.4 Configuration Register Effects on the Interface

The Configuration Register 2 volatile bits 3 to 0 (CR2V[3:0]) select the variable latency for all array read commands except Read and Read SDFP (RSFDP). Read always has zero latency cycles. RSFDP always has 8 latency cycles. The variable latency is also used in the OTPR, ECCRD, and RDAR commands.

The Configuration Register bit 1 (CR1V[1]) selects whether Quad Mode is enabled to switch WP# to IO2 function, RESET# to IO3 function, and thus allow Quad I/O Read and QPI Mode commands. Quad Mode must also be selected to allow DDR Quad I/O Read commands.

#### 3.5 Data Protection

Some basic protection against unintended changes to stored data are provided and controlled purely by the hardware design. These are described below. Other software managed protection methods are discussed in the software section of this document.



#### 3.5.1 Power-Up

When the core supply voltage is at or below the  $V_{CC (Low)}$  voltage, the device is considered to be powered off. The device does not react to external signals, and is prevented from performing any program or erase operation. Program and erase operations continue to be prevented during the Power-On Reset (POR) because no command is accepted until the exit from POR to the Interface Standby state.

#### 3.5.2 Low Power

When  $V_{CC}$  is less than  $V_{CC (Cut-off)}$  the memory device will ignore commands to ensure that program and erase operations can not start when the core supply voltage is out of the operating range.

#### 3.5.3 Clock Pulse Count

The device verifies that all non-volatile memory and register data modifying commands consist of a clock pulse count that is a multiple of eight bit transfers (byte boundary) before executing them. A command not ending on an 8-bit (byte) boundary is ignored and no error status is set for the command.

#### 3.5.4 Deep Power-Down (DPD)

In DPD mode, the device responds only to the Release from DPD command (RES ABh). All other commands are ignored during DPD mode, thereby protecting the memory from program and erase operations.

## 4. Electrical Specifications

## 4.1 Absolute Maximum Ratings

#### Absolute Maximum Ratings

| Storage Temperature Plastic Packages                       | –65 °C to +150 °C                 |  |  |
|------------------------------------------------------------|-----------------------------------|--|--|
| Ambient Temperature with Power Applied                     | –65 °C to +125 °C                 |  |  |
| V <sub>cc</sub>                                            | -0.5 V to +2.5 V                  |  |  |
| Input voltage with respect to Ground ( $V_{SS}$ ) (Note 1) | –0.5 V to V <sub>CC</sub> + 0.5 V |  |  |
| Output Short Circuit Current (Note 2)                      | 100 mA                            |  |  |

Notes:

1. See Section 4.4.3, Input Signal Overshoot on page 23 for allowed maximums during signal transition.

2. No more than one output may be shorted to ground at a time. Duration of the short circuit should not be greater than one second.

3. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions above those indicated in the operational sections of this data sheet is not implied. Exposure of the device to absolute maximum rating conditions for extended periods may affect device reliability.

## 4.2 Thermal Resistance

#### **Thermal Resistance**

| Parameter | Description                              | SOC008 | WND008 | FAB024 | FAC024 | Unit |
|-----------|------------------------------------------|--------|--------|--------|--------|------|
| Theta JA  | Thermal resistance (junction to ambient) | 75     | 18     | 39     | 39     | °C   |



## 4.3 Latch-Up Characteristics

#### Latch-Up Specification

| Description                                                          | Min  | Max                   | Unit |
|----------------------------------------------------------------------|------|-----------------------|------|
| Input voltage with respect to $V_{SS}$ on all input only connections | -1.0 | V <sub>CC</sub> + 1.0 | V    |
| Input voltage with respect to V <sub>SS</sub> on all I/O connections | -1.0 | V <sub>CC</sub> + 1.0 | V    |
| V <sub>CC</sub> Current                                              | -100 | +100                  | mA   |

Note:

1. Excludes power supply V<sub>CC</sub>. Test conditions: V<sub>CC</sub> = 1.8 V, one connection at a time tested, connections not being tested are at V<sub>SS</sub>.

## 4.4 Operating Ranges

Operating ranges define those limits between which the functionality of the device is guaranteed.

#### 4.4.1 **Power Supply Voltages**

V<sub>CC</sub> ..... 1.7 V to 2.0 V

### 4.4.2 Temperature Ranges

| Parameter           | Symbol         | Device                           | Spec |      | Unit |
|---------------------|----------------|----------------------------------|------|------|------|
| Farameter           |                | Device                           | Min  | Max  | onit |
| Ambient Temperature | T <sub>A</sub> | Industrial (I)                   | -40  | +85  | °C   |
|                     |                | Industrial Plus (V)              | -40  | +105 | °C   |
|                     |                | Automotive, AEC-Q100 Grade 3 (A) | -40  | +85  | °C   |
|                     |                | Automotive, AEC-Q100 Grade 2 (B) | -40  | +105 | °C   |
|                     |                | Automotive, AEC-Q100 Grade 1 (M) | -40  | +125 | °C   |

Note:

1. Industrial Plus operating and performance parameters will be determined by device characterization and may vary from standard industrial temperature range devices as currently shown in this specification.

#### 4.4.3 Input Signal Overshoot

During DC conditions, input or I/O signals should remain equal to or between  $V_{SS}$  and  $V_{CC}$ . During voltage transitions, inputs or I/Os may overshoot  $V_{SS}$  to -1.0V or overshoot to  $V_{CC}$  + 1.0 V, for periods up to 20 ns.











## 4.5 Power-Up and Power-Down

The device must not be selected at power-up or power-down (that is, CS# must follow the voltage applied on  $V_{CC}$ ) until  $V_{CC}$  reaches the correct value as follows:

- V<sub>CC</sub> (min) at power-up, and then for a further delay of t<sub>PU</sub>
- V<sub>SS</sub> at power-down

A simple pull-up resistor on Chip Select (CS#) can usually be used to insure safe and proper power-up and power-down.

The device ignores all instructions until a time delay of  $t_{PU}$  has elapsed after the moment that  $V_{CC}$  rises above the minimum  $V_{CC}$  threshold (see Figure 4.3). However, correct operation of the device is not guaranteed if  $V_{CC}$  returns below  $V_{CC}$  (min) during  $t_{PU}$ . No command should be sent to the device until the end of  $t_{PU}$ .

The device draws  $I_{POR}$  during  $t_{PU}$ . After power-up ( $t_{PU}$ ), the device is in Standby mode, draws CMOS standby current ( $I_{SB}$ ), and the WEL bit is reset.

During power-down or voltage drops below  $V_{CC}$  (cut-off), the voltage must drop below  $V_{CC}$  (low) for a period of  $t_{PD}$  for the part to initialize correctly on power-up. See Figure 4.4. If during a voltage drop the  $V_{CC}$  stays above  $V_{CC}$  (cut-off) the part will stay initialized and will work correctly when  $V_{CC}$  is again above  $V_{CC}$  (min). In the event Power-On Reset (POR) did not complete correctly after power-up, the assertion of the RESET# signal or receiving a software reset command (RESET) will restart the POR process.

Normal precautions must be taken for supply rail decoupling to stabilize the  $V_{CC}$  supply at the device. Each device in a system should have the  $V_{CC}$  rail decoupled by a suitable capacitor close to the package supply connection (this capacitor is generally of the order of 0.1 µF).

| Symbol                    | Parameter                                                   | Min  | Max | Unit |
|---------------------------|-------------------------------------------------------------|------|-----|------|
| V <sub>CC</sub> (min)     | V <sub>CC</sub> (minimum operation voltage)                 | 1.7  |     | V    |
| V <sub>CC</sub> (cut-off) | V <sub>CC</sub> (Cut 0ff where re-initialization is needed) | 1.5  |     | V    |
| V <sub>CC</sub> (low)     | $V_{\text{CC}}$ (low voltage for initialization to occur)   | 0.7  |     | V    |
| t <sub>PU</sub>           | V <sub>CC</sub> (min) to Read operation                     |      | 300 | μs   |
| t <sub>PD</sub>           | V <sub>CC</sub> (low) time                                  | 10.0 |     | μs   |

FS-S Power-Up / Power-Down Voltage and Timing









