# NX25F080B NX25F160B



# 8M-BIT, AND 16M-bit SERIAL FLASH MEMORIES WITH 4-PIN SPI INTERFACE

PRELIMINARY JUNE 2000

## **FEATURES**

## · Flash Storage for Resource-Limited Systems

 Ideal for portable/mobile and microcontroller-based applications that store voice, text, and data

## • 0.35µ NexFlash Memory Technology

- 8M-bit, AND 16M-bit with 2048 and 4096 sectors
- Small 536-byte sectors
- Erase/Write time of 5 ms/sector (typical)
- 10K (Sector) / 100K (Block) write cycles
- Optional 16KB (32 sector) block erase for faster programming

## • Ultra-low Power for Battery-Operation

- Single 5V or 3V supply for read and erase/write
- 1 μA standby current, 5 mA active @ 3V (typical)
- Low frequency read command for lower power

### 4-pin SPI Serial Interface

- Easily interfaces to popular microcontrollers
- Clock operation as fast as 16 MHz

## • On-chip Serial SRAM

- Dual independent 536-byte Read/Write SRAM buffers
- Use in conjunction with or independent of Flash
- Off-loads RAM-limited microcontrollers

## Special Features for Media-Storage Applications

- Byte-level addressing for reads and SRAM writes
- Transfer or compare sector to SRAM
- Versatile hardware and software write-protection
- In-system electronic part number option
- Removable Serial Flash Module package option
- Auto verify for increased endurance
- Serial Flash Development Kit

#### DESCRIPTION

The NX25F080B and NX25F160B Serial Flash memories provide a storage solution for systems limited in power, pins, space, hardware, and firmware resources. They are ideal for applications that store voice, text, and data in a portable or mobile environment. Using NexFlash's patented single transistor EEPROM cell, the devices offer a high-density, low-voltage, low-power, and cost-effective non-volatile memory solution. The devices operate on a single 5V or 3V (2.7V-3.6V) supply for Read and Erase/Write with typical current consumption as low as 5 mA active and less than 1  $\mu A$  standby. Sector erase/write speeds as fast as 5 ms increase system performance, minimize power-on time, and maximize battery life.

The NX25F080B and NX25F160B provide 8M-bit, and 16M-bit of flash memory organized as 2048 and 4096 sectors of 536 bytes each. Each sector is individually addressable through basic serial-clocked commands. The 4-pin SPI serial interface works directly with popular microcontrollers. Special features include: two on-chip serial SRAMs, byte-level addressing, double-buffered sector writes, transfer/compare sector to SRAM, hardware and software write protection, alternate oscillator frequency, electronic part number, and removable Serial Flash Module package option. Development is supported with the PC-based SFK-SPI Serial Flash Development Kit.

This document contains PRELIMINARY INFORMATION. NexFlash reserves the right to make changes to its product at any time without notice in order to improve design and supply the best possible product. We assume no responsibility for any errors which may appear in this publication. © Copyright 1998, NexFlash Technologies, Inc.



## **FUNCTIONAL OVERVIEW**

An architectural block diagram of the NX25F080B and NX25F160B is shown in Figure 2. Key elements of the architecture include:

- SPI Interface and Command Set Logic
- Serial Flash Memory Array
- Serial SRAMs and Program Buffer
- Write Protection Logic
- Configuration and Status Registers
- Device Information Sector

## **Pin Descriptions**

#### **Package**

The NX25F080B and NX25F160B are available in a 28-pin TSOP (Type I) surface mount package. See Figure 3 and Table 1 for pin assignments. All interface and supply pins are on one side of the TSOP package. The "No Connect" (NC) pins are not connected to the device, allowing the pads and the area around them to be used for routing PCB system traces. The devices are also available in a cost-effective and space-efficient removable Serial Flash Module package.



Figure 2. NX25F080B and NX25F160B Architectural Block Diagram



### Serial Data Input (SI)

The SPI bus Serial Data Input (SI) provides a means for data to be written to (shifted into) the device.

### Serial Data Output (SO)

The SPI bus Serial Data Output (SO) provides a means for data to be read from (shifted out of) the device during a read operation. When the device is deselected ( $\overline{CS}$ =1 or  $\overline{HOLD}$ =0) the SO pin is in a high-impedance state.

## Serial Clock (SCK)

All commands and data written to the Serial Input (SI) are clocked relative to the rising edge of the Serial Clock (SCK). All data read from the Serial Data Output (SO) is clocked relative to the falling or rising edge of SCK as specified in the configuration register. The data output clock edge is factory-programmed to the default condition of the falling edge, allowing compatibility with standard SPI systems. Clock rates of up to 16 MHz are supported.

## Chip Select (CS)

The NX25F080B and NX25F160B are selected for operation when the Chip Select input  $(\overline{CS})$  is asserted low. SCK must be low when  $(\overline{CS})$  is asserted to a low state. Upon power-up, an initial low-to-high transition of  $\overline{CS}$  is required before any command sequence will be acknowledged. The device can be deselected to a non-active state when  $\overline{CS}$  is brought high.

Once deselected, the SO pin will enter a high-impedance state and power consumption will decrease to standby levels unless programming is in process, in which case standby will resume when programming is complete.

## Write Protect (WP)

The Write Protect input ( $\overline{WP}$ ) works in conjunction with the write protect range set in the configuration register bits. When  $\overline{WP}$  is asserted (active low) the entire Flash memory array is write protected. When high, any Flash memory sector can be written to unless its address is within the write protect range that is set in the configuration register.

## Hold or Ready/Busy (HOLD or R/B)

This multifunction pin can serve either as a Hold input  $(\overline{HOLD})$  or as a Ready-Busy output  $(R/\overline{B})$ . The pin function is user-programmable through the non-volatile configuration register. Factory-programmed as a no-connect, the pin can be reconfigured as a Ready-Busy output or as a Hold input by setting the configuration register. See the configuration register section of this data sheet for further details.

## Power Supply Pins (Vcc and GND)

The NX25F080B and NX25F160B support single power supply Read and Erase/Write operations in 5V and 3V versions. Typical active power is as low as 5 mA for the 3V version with standby current less than 1  $\mu$ A.



Figure 3. NX25F080B and NX25F160B Pin Assignments, 28-Pin TSOP (Type I)

**Table 1. Pin Descriptions** 

| SI        | Serial Data Input              |
|-----------|--------------------------------|
| SO        | Serial Data Output             |
| SCK       | Serial Clock Input             |
| CS        | Chip Select Input              |
| WP        | Write Protect Input            |
| Hold, R/B | Hold Input or Read Busy Output |
| Vcc       | Power Supply                   |



## **Serial Flash Memory Array**

The NX25F080B and NX25F160B Serial Flash memory arrays are organized as 2048 and 4096 sectors of 536-bytes (4,288 bits) each, as shown in Figure 4.

The Serial Flash memory of the NX25F080B and NX25F160B are byte-addressable for read operations. This allows a single byte, or specified sequence of bytes, to be read without having to clock an entire 536-byte sector out of the device. Data can be read directly from a sector in the Flash memory array by using a *Read from Sector* command.

Data can be written to the Flash memory array one sector (536-bytes) at a time through the Serial SRAM using a *Write to Sector* command or a *Transfer SRAM to Sector* command. After a sector has been written, the memory array will become busy while it is programming the specified non-volatile memory cells of that sector. This busy time will not exceed two during which time the Flash array is unavailable for read or write access. The device can be

tested to determine the array's availability using the Ready/Busy status that is available during most read commands, through the status register, or on the Ready/Busy pin. Note that the SRAM is generally available, even when the memory array is busy. See the Serial SRAM section for more details.

The NX25F080B and NX25F160B do not require pre-erase. Instead, the device incorporates an auto-erase-before-write feature that automatically erases the addressed sector at the beginning of the write operation. Separate commands for *Erase Sector, Erase Block (32 sectors)*, and *Write Sector Only* are also available to improve performance for applications that can accommodate pre-erase. An internal auto-verify is performed after every erase and write command. The results of the auto-verify are available in the status register. The status register EE and EW bits must be checked to confirm proper erase or write operation.



Figure 4. NX25F080B and NX25F160B Serial Flash Memory Array



## **Serial SRAM**

One of the most powerful features of the NX25F080B and NX25F160B are the dual Serial SRAMs. The main purpose of the Serial SRAMs is to serve as the buffer for sector data to be written into the Serial Flash memory array. Using the *Write to Sector* command, data is first shifted into the SRAM from the SPI bus. When the command sequence has been completed, the entire 536-bytes is written to the selected sector. See Erase/Write cycle timing (twp). While the array is programming the second SRAM can be accessed to allow a continous stream of data to be transfered.

The SRAM is fully byte-addressable. Thus, the entire 536-bytes, a single byte, or a sequence of bytes can be read from, or written to the SRAMs. This allows the SRAMs to be used as a temporary work area for read-modify-write operations prior to a sector write.

The *Transfer Sector to SRAM* command allows the contents of a specified sector of Flash memory to be moved to the SRAM. This can be useful when only a portion of a sector needs to be altered. In this case the sector is first transferred to the SRAM, where modifications are made using the *Write to SRAM* command. Once complete, a *Transfer SRAM to Sector* command is used to update the sector.

The Compare Sector command allows the contents of the SRAM to be compared with the specified sector in memory. The result of the compare is set in the status register. This command can be useful when re-writing multi-sector files that have only minor changes from the previous write. If the new data in the SRAM is the same as the previously written data, the sector write can be skipped. Used in this way, the command saves time that would have been used for re-programming. It also extends the endurance of the Flash memory cells.



Figure 5. Command Relationships of the SPI Interface, Serial Flash Memory Array and SRAM



## Using the SRAM Independent of Flash Memory

The SRAM can be used independently of Flash memory operations for lookup tables, variable storage, or scratch pad purposes. If the Flash memory needs to be written to while SRAM is being used for a different purpose, the contents can be temporarily stored to a sector and then transferred back again when needed. The SRAM can be especially useful for RAM-limited microcontroller-based systems, eliminating the need for external SRAM and freeing pins for other purposes. It can also make it possible to use small pin-count microcontrollers, since only a few pins are needed for the interface instead of the 20-40 pins required for parallel bus-oriented Flash devices.

#### Write Endurance

Standard write endurance rating of the memory array allows for 10,000 erase/write cycles per sector or 100,000 erase/write cycles per block. Extended sector endurance to 100,000 cycles is possible using ECC techniques like those provided in the SFK Development Kit. The rating of the non-volatile configuration register EEPROM cells is 1,000 write cycles. This is more than adequate considering the configuration seldom needs to be changed. To minimize writes to the non-volatile configuration register, the configuration register should be read upon power-up to determine if a change is required. If no change is needed, the write non-volatile configuration command can be skipped. This process will extend the life of the non-volatile configuration register and save processing time (Figure 6).

### **Write Protection**

The NX25F080B and NX25F160B provide advanced software and hardware write protection features. Software-controlled write protection of the entire array is handled using the *Write Enable and Write Disable* commands. Hardware write protection is possible using the Write Protect pin  $(\overline{WP})$ . Write-protecting a portion of Flash memory is accommodated by programming a write protect range in the configuration register. For applications needing a portion of the memory to be permanently write-protected or a fixed configuration register value, a onetime programmable write protection feature is supported. Contact *NexFlash* for further information.

## **Configuration Register**

The Configuration Register stores the current configuration of the  $\overline{\text{HOLD}}$ -R/ $\overline{\text{B}}$  pin, read clock edge, write protect range, and alternate oscillator frequency (Figure 7). The configuration register is accessed using the *Write and Read Configuration Register* commands. The non-volatile configuration register will maintain its setting even when power is removed.



Figure 6. Flow Chart for Checking the Configuration Register upon Power-up



The factory default setting for the non-volatile configuration register is CF8-CF0 is: 0 0000 1001 B (write protect range = none, read uses falling edge of the clock, and pin 1 = no connect). Bits CF15-CF9 are reserved. When writing to the configuration register CF15-CF9 should be 0. When reading, the settings of CF15-CF9 should be ignored.

### Alternate Oscillator Frequency, AF

Flash memory devices have charge pump oscillators to generate internal high-voltages used for programming non-volatile memory cells. In some applications, the oscillator frequency of the charge pump may cause noise interference. To solve this problem, an alternate oscillator frequency (AF) can be selected by setting bit CF[8] of the configuration register. The alternate frequency is a non-harmonic frequency of the standard oscillator. The factory default setting is for the standard oscillator frequency, AF equal to 0.

AF=0 Standard Oscillator Frequency is used. AF=1 Alternate Oscillator Frequency is used.

## Write Protect Range and Direction, WR[3:0], WD

The write protect range and direction bits WR[3:0] and WD are located at configuration bits CF[7:4] and CF[3] respectively. The write protect range and direction bits select how the array is protected. They work in conjunction with the

WP input pin, valid only if WP is inactive (high). WR[3:0] can select write protection of all sectors, none of the sectors, or specific up to 224 KB at the beginning or end of the memory array grouped in blocks of 32 sectors (~16 KB). The WD bit specifies whether the protected block range starts from the first sector, address 0 (000H), or from the last sector (7FFH for the NX25F080B, FFFH for the NX25F160B). Table 2 lists the write protect sector range for both devices. Once protected, all further writes to sectors within the range will be ignored. The factory default setting is with no write protected sectors, WR=[0,0,0,0] and WD=1.

## Read Clock Edge, RCE

The Read Clock Edge bit (RCE) is located at configuration bit location CF[2]. It selects which edge of the clock (SCK) is used while reading data out of the device. Although the SPI protocol specifies that data is written during the rising edge and read on the falling edge of the clock, if required, the output can be driven on the rising edge of the clock by setting the configuration registers RCE bit to a 1. Using the rising edge of clock for data reads is recommended, and likely required, to achieve clock rates greater than 12 MHz. The factory default setting is the falling edge of SCK.

RCE=0 Read data is output on the falling edge of SCK. RCE=1 Read data is output on the rising edge of SCK.



Figure 7. Configuration Register Bit Locations



Table 2. Write Protect Range Sector Selection (Hex)

| •   | Write F | rotect  |      |                         | _               |  |
|-----|---------|---------|------|-------------------------|-----------------|--|
| Rar | nge Co  | nfig. E | Bits | Write Protected Sectors |                 |  |
| WR3 | WR2     | WR1     | WR0  | WD=0                    | WD=1            |  |
| 0   | 0       | 0       | 0    | None                    | None            |  |
| 0   | 0       | 0       | 1    | 000-01FH                | xE0-7FF/FFFH    |  |
| 0   | 0       | 1       | 0    | 000-03FH                | xC0-7FF/FFFH    |  |
| 0   | 0       | 1       | 1    | 000-05FH                | xA0-7FF/FFFH    |  |
| 0   | 1       | 0       | 0    | 000-07FH                | x80-7FF/FFFH    |  |
| 0   | 1       | 0       | 1    | 000-09FH                | x60-7FF/FFFH    |  |
| 0   | 1       | 1       | 0    | 000-0BFH                | x40-7FF/FFFH    |  |
| 0   | 1       | 1       | 1    | 000-0DFH                | x20-7FF/FFFH    |  |
| 1   | 0       | 0       | 0    | 000-0FFH                | x00-7FF/FFFH    |  |
| 1   | 0       | 0       | 1    | 000-11FH                | y E0 - 7FF/FFFH |  |
| 1   | 0       | 1       | 0    | 000-13FH                | yC0-7FF/FFFH    |  |
| 1   | 0       | 1       | 1    | 000-15FH                | yA0-7FF/FFFH    |  |
| 1   | 1       | 0       | 0    | 000-17FH                | y80-7FF/FFFH    |  |
| 1   | 1       | 0       | 1    | 000-19FH                | y60-7FF/FFFH    |  |
| 1   | 1       | 1       | 0    | 000-1BFH                | y40-7FF/FFFH    |  |
| 1   | 1       | 1       | 1    | ALL                     | ALL             |  |

#### Note:

1. NX25F160B x=3 y=2, and NX25F080B x=1 y=0

#### HOLD-R/B, HR[1:0]

The Hold-Ready/Busy ( $\overline{HOLD}$ -R/ $\overline{B}$ ) bits HR1 and HR0 are located at bits CF[1:0] of the configuration register. These two bits select one of four possible functions: No Connect,  $\overline{HOLD}$  input, R/ $\overline{B}$  Output, or R/ $\overline{B}$  Output with open drain. The factory setting for the pin is "No Connect".

| HR1 | HR0 | Pin Configuration       |
|-----|-----|-------------------------|
| 0   | 0   | HOLD input              |
| 0   | 1   | No Connect              |
| 1   | 0   | R/B Output (Open Drain) |
| 1   | 1   | R/B Output              |

Configured as a  $R/\overline{B}$  output, the pin can serve as a system interrupt. When  $R/\overline{B}$  is high, the array is ready to be programmed. When  $R/\overline{B}$  is low, it is busy programming. If configured with an open-drain, an external pull-up resistor should be used.

As a  $\overline{\text{HOLD}}$  input, the pin can be used in conjunction with the  $\overline{\text{CS}}$  and SCK pin to suspend a serial command sequence without resetting the command. This can be useful if a command is in process and a higher priority task on the same SPI bus needs to be attended to. To suspend a command,  $\overline{\text{HOLD}}$  must be brought low while  $\overline{\text{CS}}$  and SCK are low. With  $\overline{\text{HOLD}}$  low, further data on the SI pin is ignored (even while SCK is clocked) and the SO pin goes to a high-impedance state. To resume the command sequence,  $\overline{\text{HOLD}}$  must be brought high when  $\overline{\text{CS}}$  and SCK are low. See timing diagrams.

## **Status Register Bit Descriptions**

The status register provides status of the Flash array's Ready/Busy condition ( $R/\overline{B}$ ), transfers between the SRAM and program buffer (TX), Write-Enable/Disable (WE), and Compare Not Equal (CNE). The register can be read using the Read Status Register command (Figure 8).

## Ready/Busy Status, BUSY

The BUSY status bit is located at bit ST[7] of the status register. Testing the BUSY bit is one of several ways to check Ready/Busy status of the array. At power-up the BUSY bit is reset to 0.

BUSY=1 The memory array is busy programming. BUSY=0 The memory array is ready for further use.

### **SRAM Transfer All or Compare All, TR1 and TR2**

The TR status bits are located at ST[6,5] of the status register. The bits provide status primarily for use during the *Transfer All Sector to SRAM* command and *Compare Sector to SRAM* command. An active state 1 indicates a transfer or compare is in process and the SRAM Array is not available for use. The device will indicate a BUSY state while the TR bit is active. Upon power up the TR bits are reset to 0.

TR=1 Transfer or Compare All in Process.
TR=0 Transfer or Compare All not in Process.

#### Write Enable/Disable, WE

The WE status bit is located at bit ST[4] of the status register. The bit provides write protect status of global *Write Enable and Write Disable* commands. Upon power- up the WE bit resets to 0.

WE=1 Write Enabled, array can be written to. WE=0 Write Disabled, array can not be written to.





Figure 8. Status Register Bit Locations

## **Compare Not Equal, CNE**

The CNE status bit is located at bit ST[3] of the status register. The bit provides a cumulative comparison result during a *Compare Sector with SRAM* command. The CNE bit is reset to a 0 upon power-up or after a Clear Compare Bit command is executed.

CNE=1 Sector and SRAM contents are not equal. CNE=0 Sector and SRAM are equal or CNE bit reset.

#### Error Erase, EE

The Error Erase bit provides status of the last erase operation for the Write Sector through SRAM, Transfer SRAM to Sector, Erase Sector and Erase Block commands. If the Erase operation operates correctly the EE bit will be reset to a 0. If an erase error occurs, the EE bit will be set to a 1 and the related command should reissued. If the error bit continues to get set the application firmware should process an error routine and not attempt to use the selected sector any further.

EE=0 Last erase operation was successful EE=1 Last erase operation was not successful

#### **Error Write. EW**

The Error Write bit provides status of the last write operation for the Write Sector through SRAM, Transfer SRAM to Sector, Write Sector Only commands. If the Write operation operates correctly the EW bit will be reset to a 0. If a write error occurs, the EW bit will be set to a 1 and the related command should reissued. If the error bit continues to get set the application firmware should process an error routine and not attempt to use the selected sector any further.

EW=0 Last write operation was successful EW=1 Last write operation was not successful

#### Power Detect, PD

The Power Detect bit works in conjunction with the Set Power Detection and Reset Power Detection Commands and is primarily used for removable media applications. The Set Power Detect Command must be issued before the PD bit can be used for power detection.

PD=0 Power has been removed PD=1 Power has not been removed

### **Command Set**

The NX25F080B and NX25F160B have a powerful command set that is fully controlled through the SPI bus. Command relations are shown in Figure 5 and a list of commands and their associated address, status, clock, and data bytes are shown in Table 3. Detailed clock timing of the *Read Sector* and *Write Sector* command sequences are shown in Figures 10 and 11.

After power up, a device enters an idle state that will maintain until  $\overline{CS}$  pin is asserted low. All commands are entered from the SPI serial data input (SI) pin on the rising edge of SCK while  $\overline{CS}$  is asserted low. All command, address, and configuration bits are shifted into the device with most-significant-bit-first. Data bits read from the device are shifted out with least significant byte first (i.e., byte-00H, byte-01H,...). The bit order within each byte is most-significant-bit first (i.e.,D7,...D0). All commands are completed by asserting the  $\overline{CS}$  pin high.

Note that the entire 536-byte contents of a Flash sector or the SRAM does not have to be accessed all at once. Read, Write, Transfer Clocked, and Compare Clocked commands allow for byte addressing. Thus a single byte, or clocked sequence of bytes, can be accessed at any starting location within the 536-byte boundary as specified by the byte-address field.





Figure 10. Read from Sector Command Sequence



Figure 11. Write to Sector Command Sequence



## Command Set for the NX25F080B and NX25F160B Serial Flash Memory

| Command Name                                        | Byte 0      | Byte 1-2        | Byte 3-4     | (Italics in | n- byte          | es<br>evice output) |
|-----------------------------------------------------|-------------|-----------------|--------------|-------------|------------------|---------------------|
| Sector Commands                                     |             |                 |              |             |                  |                     |
| Read From Sector                                    | 52H         | Sector address  | Byte address | 0000H       | R/B <sup>5</sup> | Read Data           |
| Read From Sector w/AutoInc <sup>3</sup>             | 50H         | Sector address  | 0000H        | 0000H       | R/B <sup>5</sup> | Read Data           |
| Read From Sector Low Freq.                          | 51H         | Sector address  | Byte address | 0000H       | R/B <sup>5</sup> | Read Data           |
| Read From Sector<br>w/AutoInc Low Freq <sup>3</sup> | 5BH         | Sector address  | 0000H        | 0000H       | R/B <sup>5</sup> | Read Data           |
| Write Enable 1                                      | 06H         | 00H             |              |             |                  |                     |
| Write Disable 1                                     | 04H         | 00H             |              |             |                  |                     |
| Write to Sector via SRAM 1/2 <sup>2</sup>           | F3H         | Sector address  | Byte address | Write Data  | 00H              |                     |
| Serial SRAM Commands                                |             |                 |              |             |                  |                     |
| Write to SRAM 1/2 2,3                               | 72H/74H     | Byte address    | Write data   | 00H         |                  |                     |
| Read from SRAM1/2 1,3                               | 71H/73H     | Byte address    | 00H          | Read Data   |                  |                     |
| Transfer all of SRAM 1/2 to Sector                  | F3H/94H     | Sector address  | 0000H        |             |                  |                     |
| Transfer all of Sector to SRAM 1/2 3                | 53H/56H     | Sector address  | 0000H        | 0000H       |                  |                     |
| Compare Sector to SRAM 1/2 3                        | 8DH/8EH     | Sector address  | 0000H        | 0000H       |                  |                     |
| Transfer SRAM 1 to SRAM 2                           | 92H         |                 |              |             |                  |                     |
| Transfer SRAM 2 to SRAM 1                           | 55H         |                 |              |             |                  |                     |
| Configuration and Status Command                    | ls          |                 |              |             |                  |                     |
| Read Configuration 1,3                              | 8CH         | Configuration   |              |             |                  |                     |
| Write Non-Volatile<br>Configuration 1 Register      | 8AH         | Configuration   | 0000H        |             |                  |                     |
| Read Status Register 1,3                            | 84H         | Status (8 bits) |              |             |                  |                     |
| Clear Compare Status 1                              | 89H         |                 |              |             |                  |                     |
| Set Power Detection Bit 1,3                         | 03H         |                 |              |             |                  |                     |
| Reset Power Detection Bit 1,3                       | 09H         |                 |              |             |                  |                     |
| Read Device Information Sector                      | 15H         | 0000H           | Byte address | 0000H       | R/B <sup>5</sup> | DIS Data            |
| Special Sector Commands 3,4                         |             |                 |              |             |                  |                     |
| Erase Sector                                        | F1H         | Sector address  | 0000H        |             |                  |                     |
| Erase Block                                         | F4H         | Block address   | 0000H        |             |                  |                     |
| Write-Only to Sector via SRAM 1                     | F2H         | Sector address  | Byte address | Write Data  | 00H              |                     |
| Compatibility Commands for 25xxx                    | A Series De | vices           |              |             |                  |                     |
| Read from SRAM                                      | 81H         | 0000H           | Byte address | 0000H       | R/B <sup>5</sup> | Read Data           |
| Write to SRAM                                       | 82H         | 0000H           | Byte address | Write data  | 00H              |                     |
| Read Configuration Register                         | 8BH         | 0000H           | 0000H        | 0000H       | R/B⁵             | Configuration       |
| Read Status Register                                | 83H         | 0000H           | 0000H        | 0000H       | R/B⁵             | Status              |
| Transfer Sector to SRAM Clocked                     | 54H         | Sector address  | Byte address | N*00H       | 00H              |                     |
| Compare Sector to SRAM Clocked                      | 86H         | Sector address  | Byte address | 0000H       | R/B <sup>5</sup> | Bit compare of data |

Notes:

- 1. Command may be used when device is busy
- 2. Command may not be used when device is busy and TR bit=0
- 3. New "B" series command
- 4. Warning: Read description of these commands before using to ensure reliable operation.
- 5. R/B = Ready/Busy

## SERIAL FLASH SECTOR COMMANDS

## Read From Sector (52H)

Reading from a sector is accomplished by first bringing  $\overline{\text{CS}}$  low then shifting in the *Read from Sector* command (52H) followed by its 16-bit "sector-address" field. Although the sector-address field is 16-bits, only bits S[10:0] for the NX25F080B (0-7FFH), S[11:0] for the NX25F160B (0-FFFH) are used. The uppermost sector address bits are not used but must be clocked using 0 for data. Next a 16-bit "byte-address" field is clocked into the device to designate the starting location within the 536-byte sector. Only B[0] of the byte-address field are used; the uppermost bits are not used but must be clocked in (use 0 for data). Only byte-addresses of 0 to 107H (536 bytes) are valid. Following the byte-address field, 16 control clocks are required with data=0.

The Serial Data Output (SO) will change from a high-impedance state and begin to drive the output with Ready/Busy status RB[15:0]. If SO uses the rising edge of clock (configuration register RCE=1), the output will be driven after the last control clock. If SO uses the falling edge of clock (RCE=0), the output will be driven on the next falling edge of clock. If the array is not busy, the output status will be 9999H, followed by the sector data on the SO pin. If the array is busy, the status will be 6666H, and the command should be terminated and restarted after a ready state occurs. The data field is shifted out with the least significant byte first (i.e., byte-00H, byte-01H, ...). The bit order within each byte is the most significant bit first (i.e., D7,...D0). The

byte-address is internally incremented to the next higher byte address as the clock continues. When the highest byte-address (107H) is reached, the address counter rolls over to byte-0H and continues to increment. Asserting the  $\overline{CS}$  pin high completes (or terminates) the command. Detailed timing for the *Read from Sector* command is shown in Figure 10.

## Read From Sector with Auto Increment (50H)

The Read from sector with Auto Increment command operates similar to the standard Read from Sector command except that after the last bit of the current sector is clocked the next sequentially addressed sector will be automatically selected for reading without requiring the nine byte command sequence to be issued. This allows the entire device or a large number of sectors to be read out with a single command.

# Read From Sector Low Frequency (51H) and Read From Sector Low Frequency with Auto Increment (5BH)

The Read From Sector at Low Frequency command (51H) and Read From Sector Low Frequency with Auto Increment command (5BH) can reduce power consumption during read operations by 25%-40% when the system clock frequency is 1 MHz or lower. The command sequences are identical to the standard commands.



<sup>\*</sup>The sector address only uses bits [10:0] or [11:0] Depending on the density

<sup>\*\*</sup>The byte address only uses bits [0]. Byte address must be 0000h for Auto Increment commands



# Write Enable (06H)

Upon power-up, the Flash memory array is write-protected until the Write Enable command (06H) has been issued. The  $\overline{WP}$  pin must be inactive while writing the command for the write enable to be accepted. The status of the device's write protect state can be read in the status register. The Write Enable command sequence is completed by asserting  $\overline{CS}$  high after eight additional clocks.



# Write Disable (04H)

The *Write Disable* command (04H) protects the Flash memory array from being programmed. Once issued, further *Write to Sector* or *Transfer SRAM to Sector* commands will be ignored. The status of the write protect state can be read in the status register. The *Write Disable* command sequence is completed by asserting  $\overline{CS}$  high after eight additional clocks.





Before writing to a sector in the Flash memory array, all hardware and software write protection must be in an enabled state. This means that the  $\overline{WP}$  pin must be in a high state, a *Write Enable* command must have previously been issued, and the sector location that is to be written to must be outside the write protect range set in the configuration register. Additionally, the Ready/Busy status should be checked to confirm that the memory array is available to be written to.

Writing to a sector is accomplished by first bringing  $\overline{CS}$  low and shifting in the *Write to Sector* command (F3H/94H) followed by a 16-bit "sector-address" field. Although the sector-address field is 16-bits, only bits S[10:0] for the NX25F080B (0-7FFH), S[11:0] for the NX25F160B (0-FFFH) are used. The uppermost sector address bits are not used but must be clocked in (use 0 data). Following the sector address, a 16-bit "byte-address" field is clocked into the device to designate the starting location within the 536-byte sector. Only bits B[8:0] of the byte-address field are used and only values of 0-107H (536 bytes) are valid. After the byte-address has been loaded, data is shifted into the 536-byte SRAM,

which serves as a temporary storage buffer. Existing data in the SRAM will be written over. The byte order of the data shifted into the SRAM is least significant byte first (i.e., byte-00H, byte-01H,...). The bit order within each byte is most significant bit first (i.e., D7,...D0). The yte-address is automatically incremented to the next higher byte address as the clock continues. When the last byte address to be written is reached, the command can be completed with an additional eight control clocks (with data=0) followed by asserting  $\overline{CS}$  high. If the clock continues to increment past the highest byte-address (107H), the address counter will roll over to byte 0H.

After the  $\overline{\text{CS}}$  pin is brought high, the data in the SRAM is transferred to the specified sector in memory array. See twp timing specifications. During this time the array and the specific SRAM used will be "busy" and will ignore further array-related commands until complete. All Ready/Busy status indicators will indicate a busy status. Detailed clock timing for the *Write to Sector* command is shown in Figure 11. The EE and EW bits in the status register must be checked after the write is complete ("ready" state) to confirm proper operation.

|    | Write to<br>Sector<br>Command | Sector<br>Address* | Byte<br>Address** | Write Sector Data      | 8 Clocks | Program<br>Time |
|----|-------------------------------|--------------------|-------------------|------------------------|----------|-----------------|
| SI | F3H/94H                       | S[15:0]            | B[15:0]           | First Byte - Last Byte | 00H      | (twp)           |
| so |                               |                    |                   |                        |          |                 |

<sup>\*</sup>The sector address only uses bits [10:0] or [11:0]

<sup>\*\*</sup>The byte address only uses bits [9:0]



### SERIAL SRAM COMMANDS

## Write to SRAM 1 (72H) or SRAM 2 (74H)

The Write to SRAM command (72H/74H) provides access to the 536-byte SRAM independently of any Flash memory array operation. When  $\overline{CS}$  is asserted high to complete the command, the contents of the SRAM will be maintained until overwritten through another command or the power is removed. Using the Write to SRAM command,

data can be loaded in preparation of writing to a sector in memory and then transferred to a selected sector using the *Transfer SRAM to Sector* command. The TR bit in the status register should be checked first if *Transfer Sector to SRAM* or *Compare Sector to SRAM* commands are in use.



<sup>\*</sup>The byte address only uses bits [9:0]

# Read from SRAM 1 (71H) or SRAM 2 (73H)

The Read from SRAM command (71H/73H) provides access to the 536-byte SRAM independent of any Flash memory array operations. The TR bit in the status register should be checked first if *Transfer Sector to SRAM* or Compare Sector to SRAM commands are used.





# Transfer All of SRAM 1 (F3H) or SRAM 2 (94H) to Sector

The Transfer SRAM to Sector command (F3H/94H) will write the existing contents of the SRAM to the specified sector in memory. The command sequence is identical to that of the Write to Sector command except that immediately after the sector address field S[15:0] and 16 control clocks, the  $\overline{\text{CS}}$  pin is asserted high. This automatically transfers the 536-bytes of SRAM data to the specified sector in the memory array. During this time, the array will be busy.



<sup>\*</sup>The sector address only uses bits [10:0] or [11:0] Depending on device density

# Transfer All of Sector to SRAM 1 (53H) or SRAM 2 (56H)

The *Transfer Sector to SRAM* command (53H/56H) allows the contents of a sector to be transferred directly to the SRAM without having to clock or read the sector out of the device and rewrite it into the SRAM. During the transfer, the SO output is in a high-impedance state and the TR bit in the status register will be set to a "1" state. When the last byte address is transferred the TR bit in the status register will be cleared. Note that *the Transfer Sector to SRAM Clocked* command (54H/8FH) can also be used if partial transfers are required.



<sup>\*</sup>The sector address only uses bits [10:0] or [11:0] Depending on device density



# Compare Sector to SRAM 1 (8DH) or SRAM 2 (8EH)

The Compare Sector to SRAM command (8DH/8EH) does a bit-by-bit comparison of the data stored in the addressed sector against data in the SRAM. The TR bit will be 1 during the transfer compare operation. If any of the compared bits are not equal, then the Compare Not Equal (CNE) bit in the

Status Register is set to a 1. This bit will stay set until a *Clear Compare Status* command has been issued. Note that the *Compare Sector to SRAM Clocked* command can be used if partial compares are required.



<sup>\*</sup>The sector address only uses bits [10:0] or [11:0] Depending on device density

# CONFIGURATION AND STATUS COMMANDS

## Read Configuration Register (8CH)

The Read Configuration Register command provides access to the configuration register, which stores the current configuration of the HOLD-R/B pin, read clock edge, write protect range, and alternate oscillator frequency (Figure 7). A 16-bit Configuration Data field CF[15:0] provides the contents of the Configuration Register. Although the field is 16-bits long, only bits CF[8:0] are used. All other upper bits are reserved for future features. For compatability with older "A" series devices please use command (8BH).



\*The CF Register only uses bits [8:0]



# Write Non-Volatile Configuration Register (8AH)

The Write Configuration Register command provides access to the configuration register which stores the current configuration of the HOLD-R/B pin, read-data clock edge, write protect range, and alternate oscillator frequency. The configuration register is non-volatile. Once set using the Write Configuration Register command, the contents will maintain even when power is removed. Because the register's state is stored in non-volatile memory, there is a finite endurance limit to the number of times it can be written to. To limit the number of writes, it is recommended that before writing to the configuration register it should first be read from using the Read Configuration Register command. If no change is required, the Write Configuration Register command can be skipped. This process will help

extend the endurance of the configuration register bits and eliminate additional programming "busy" time.

The Write Configuration Register command sequence starts with the command byte (8AH) followed by a 16-bit field that specifies configuration register bit settings. Although the field is 16-bits long, only bits CF[8:0] are used. All other upper bits are reserved and must be clocked using 0 for data. After an additional 16 control clocks using  $\overline{0}$  for data, the command can be completed by asserting  $\overline{CS}$  high. The device will become busy for a short time (twp) while the non-volatile memory cells of the configuration register are programmed.



\*The CF Register only uses bits [8:0]

# Read Status Register (84H)

The Read Status Register command provides access to the status register and its status flags for Ready/Busy (R/ $\overline{B}$ ), SRAM transfer and compare operations (TR), Write Enable/Disable ( $\overline{WE}$ ), and Compare Not Equal (CNE) (Figure 8). An 8-bit Status field ST[7:0] provides the contents of the Status Register.





# **Clear Compare Status (89H)**

The Clear Compare Status command (89H) works in conjunction with the Compare Sector to SRAM command and the Status Register. If any of the compared bits are not equal, then the Compare Not Equal (CNE) bit in the Status Register is set to a 1. The Clear Compare Status command must be executed to reset the CNE bit to a 0.



# **Set Power Detection Bit (03H)**

The Set Power Detection Bit command (03H) can be used to detect if power has been removed from the device. The command works in conjunction with the Power Detect (PD) status bit. Upon power up the PD bit is cleared to 0. The PD bit can be set to a 1 using the Set Power Detection Bit command. Once set, if a power down condition occurs (Vcc voltage < 2V) the PD bit will reset to 0. This function is especially useful for applications using NexFlash Serial Flash Modules or other removable media.



# **Reset Power Detection Bit (09H)**

The Reset Power Detection Bit command (09H) can be used to force the Power Detect Status bit in the status register to a 0 state. (see Set Power Detection Bit command (03H).





# Read Device Information Sector (15H)

The Read Device Information command provides access to a read-only sector that can be used to electronically identify the NexFlash Serial Flash device being interfaced to. Information available includes: part number, density, voltage, temperature range, package type, and any special options. This can be extremely useful for systems that need to accommodate optional densities

(e.g., both 8M-bit or 16M-bit). In this case the firmware can interrogate the Device Information Sector and determine the density. The Device Information Sector also includes a list of any restricted sectors that might exist in the device. Contact *NexFlash* for more detailed information on the Device Information Sector format.



## SPECIAL SECTOR COMMANDS

# **Erase Sector (F1H)**

The *Erase Sector* command (F1H) will erase a sector to an "all 1s" state, during this time the array will be "busy." This command can be used in conjunction with the *Write only to Sector through SRAM* command (F2H) to achieve faster program performance in applications that can accommodate pre-erase. (see TEO in AC Characteristics for erase timing). The EE bit in the status register must be checked after the erase is complete ("ready" state) to confirm proper operation.



\*The sector address only uses bits [10:0] or [11:0] Depending on device density



## **Erase Block (F4H)**

The *Erase Block* command (F4H) will erase a block of 32 sectors to an "all 1s" state, during this time the array will be "busy." This command can be used in conjunction with the *Write only to Sector through SRAM* command (F2H) to achieve faster program performance in applications that can accommodate pre-erase. (see TEO in AC Characteristics for erase and write timing). The EE bit in the status register must be checked after the erase is complete ("ready" state) to confirm proper operation.



<sup>\*</sup>The Block address only uses bits [10:5] or [11:5] Depending on device density. Lowest four bit [4:0] must be 0h

# Write-only to Sector Through SRAM 1 (F2H) and SRAM 2 (97H)

The Write-Only to Sector through SRAM command (F2H/97H) will write a pre-erased sector in about half the time of the standard Write to Sector through SRAM command (F3H/94H), during this time the array will be "busy." This command can be used in conjunction with the Erase Sector command (F1H) or Erase Block command (F4H) to achieve faster program performance in applications that

can accommodate pre-erase. (see Two inAC Characteristics for erase and write timing). The EW bit in the status register must be checked after the erase is complete ("ready" state) to confirm proper operation. **Warning**; to ensure data integrity this command should only be issued after an erase command.



<sup>\*</sup>The sector address only uses bits [10:0] or [11:0] Depending on device density

<sup>\*\*</sup>The byte address only uses bits [9:0]



## COMPATIBILITY COMMANDS FOR 25xxxA SERIES DEVICES

# Read from SRAM 1 (81H) or SRAM 2 (91H)

The Read from SRAM command (81H/91H) provides access to the 536-byte SRAM independent of any Flash memory array operations. The command is similar to the Read from Sector command except for the sector address field S[15:0] which is replaced with all 0 bits.



# Write to SRAM 1 (82H) or SRAM 2 (93H)

The Write to SRAM command (82H/93H) provides access to the 536-byte SRAM independently of any Flash memory array operation. The command is similar to the Write to Sector command sequence except that the sector address field S[15:0] is replaced by all 0 bits. When  $\overline{CS}$ is asserted high to complete the command, the contents

of the SRAM will be maintained until overwritten through another command or the power is removed. Using the Write to SRAM command, data can be loaded in preparation of writing to a sector in memory and then transferred to a selected sector using the Transfer SRAM to Sector command.



\*The byte address only uses bits [9:0]



# **Read Configuration Register (8BH)**

The Read Configuration Register command provides access to the configuration register, which stores the current configuration of the HOLD-R/B pin, read clock edge, write protect range, and alternate oscillator frequency (Figure 7). The command sequence is similar to the Read from Sector command except that the sector address field S[15:0] and the byte-address field B[15:0]

are replaced with all 0 bits. After 16 control clocks and after the Ready/Busy status field has been clocked through, a 16-bit Configuration Data field CF[15:0] provides the contents of the Configuration Register. Although the field is 16-bits long, only bits CF[8:0] are used. All other upper bits are reserved for future features.



# Read Status Register (83H)

The Read Status Register command provides access to the status register and its status flags for Ready/Busy (R/ $\overline{B}$ ), SRAM transfer and compare operations (TR), Write Enable/Disable ( $\overline{WE}$ ), and Compare Not Equal (CNE) (Figure 8). The command sequence is similar to the Read From

Sector command except that the sector address field S[15:0] and the byte-address field B[15:0] are replaced by all 0 bits. After 16 clocks and the Ready/Busy status field RB[15:0] has been read, an 8-bit Status field ST[7:0] provides the contents of the Status Register.





## Transfer Sector to SRAM 1 Clocked (54H)

The *Transfer Sector to SRAM Clocked* command (54H) allows the contents of a sector to be transferred directly to the SRAM without having to read the sector out of the device and rewrite it into the SRAM. The command is similar to the *Write to Sector* command except that instead of inputting data from the SI pin, the data is taken from the specified sector and is transferred to the SRAM. Every eight clocks on SCK, a byte from the specified sector to the SRAM will be transferred. Although data on SI is ignored, it is recom-

mended to write data bytes of 00H in order to support the clocking requirements. During the transfer, the SO output is in a high-impedance state. When the last byte address is transferred, the command can be completed by issuing eight more control clocks and asserting  $\overline{CS}$  high. If the clock continues to increment past the highest byte-address (107H), the address counter will roll over to byte-0H. This command can also be used to load partial sectors into SRAM

|    | Transfer Sector<br>to SRAM<br>Command | Sector<br>Address* | Byte<br>Address** | 8 Clocks per Byte Trasnfered<br>from First Byte to Last Byte | 8 Clocks |
|----|---------------------------------------|--------------------|-------------------|--------------------------------------------------------------|----------|
| SI | 54H                                   | S[15:0]            | B[15:0]           | SI=00H During Byte Ttansfers                                 | 00H      |
| so |                                       |                    |                   |                                                              |          |

<sup>\*</sup>The sector address only uses bits [10:0] or [11:0] Depending on device density

# Compare Sector to SRAM 1 Clocked (86H)

The Compare Sector to SRAM command does a bit-by-bit comparison of the data stored in the addressed sector against data in the SRAM. The command is similar to the Read from Sector command except that data is not read out of the Serial Output pin (SO). Instead, the SO pin provides a bit-by-bit compare of each sector and SRAM bit. A high (1) per bit will be output if the bit compare is equal. A low (0) per bit will be output if the bit compare is not equal (XNOR). The

compare can start from any location in the 536-byte range as specified by the byte-address field B[15:0]. The byte-address counter is automatically incremented and will wrap around to the first address (0H) if it passes the last address (107H). If any of the compared bits are not equal, then the Compare Not Equal (CNE) bit in the Status Register is set to a 1. This bit will stay set until a Clear Compare Status command has been issued.



<sup>\*</sup>The sector address only uses bits [10:0] or [11:0] Depending on device density

<sup>\*\*</sup>The byte address only uses bits [9:0]

<sup>\*\*</sup>The byte address only uses bits [9:0]



## Sector Format and Tag/Sync Bytes

The first byte of each sector is pre-programmed during manufacturing with a tag/sync value of C9H. Although this byte location of the sector can be changed, it is recommended that it be maintained and incorporated into the application's sector formatting.

The tag/sync values serve two purposes. First, they provide a sync-detect that can help verify if the command sequence was clocked into the device properly. Secondly, they serve as a tag to identify a fully functional (valid) sector. This is especially important if "restricted sector" (-R) devices are ever to be used. Restricted sector devices provide a more cost effective alternative to standard devices with 100% valid sectors. Restricted sector devices have a limited number of sectors that do not meet manufacturing programming criteria over the specified operating range. When such a sector is detected, the first byte is tagged with a pattern other than C9H. In addition to individual sector tagging, all restricted sectors for a given device are listed in the Device Information Sector. For more information see the Device Information Sector Application Note SFAN-02.

# **High Data Integrity Applications**

Data storage applications that use Flash memory or other non-volatile media must take into consideration the possibility of noise or other adverse system conditions that may affect data integrity. For those applications that require higher levels of data integrity it is a recommended practice to use Error Correcting Code (ECC) techniques. The NX-SFK-NXS Serial Flash Development Kit provides a software routine for a 32-bit ECC that can detect up to two bit errors and correct one. The ECC not only minimizes problems caused by system noise but can also extend Flash memory endurance.



## **ABSOLUTE MAXIMUM RATINGS (1)**

| Symbol    | Parameters                 | Conditions           | Range             | Unit |
|-----------|----------------------------|----------------------|-------------------|------|
| Vcc       | Supply Voltage             |                      | 0 to 7.0          | V    |
| VIN, VOUT | Voltage Applied to Any Pin | Relative to Ground   | -0.5 to Vcc + 0.5 | V    |
| Тѕтс      | Storage Temperature        |                      | -65 to +150       | °C   |
| TLEAD     | LeadTemperature            | Soldering 10 Seconds | +300              | °C   |

#### Note:

1. This device has been designed and tested for the specified operation ranges. Proper operation outside of these levels is not guaranteed. Exposure beyond absolute maximum ratings (listed above) may cause permanent damage.

## **OPERATING RANGES**

| Symbol | Parameter                      | Conditions | Min             | Max | Unit |
|--------|--------------------------------|------------|-----------------|-----|------|
| Vcc    | Supply Voltage                 | 5.0V       | 4.5             | 5.5 | V    |
|        |                                | 3.0V       | 2.7             | 3.6 | V    |
| TA     | Ambient Temperature, Operating | Commercial | 0               | +70 | °C   |
|        |                                | Extended   | -20             | +70 | °C   |
|        |                                | Industrial | <del>-4</del> 0 | +85 | °C   |

## DC ELECTRICAL CHARACTERISTICS (PRELIMINARY) 2

| Symbol                      | Parameter                          | Conditions                                                             |                      | Min     | Тур     | Max      | Unit     |
|-----------------------------|------------------------------------|------------------------------------------------------------------------|----------------------|---------|---------|----------|----------|
| VIL                         | Input Low Voltage                  |                                                                        |                      | -0.4    | _       | Vccx0.2  | V        |
| Vih                         | Input High Voltage                 |                                                                        |                      | Vccx0.6 | _       | Vcc+0.5  | V        |
| Vol                         | Output Low Voltage                 | IoL = 2 mA                                                             | Vcc = 4.5V           | _       | _       | 0.45     | V        |
| Vон                         | Output High Voltage                | Іон = –400 µА                                                          | Vcc = 4.5V           | 2.4     | _       | _        | V        |
| Volc                        | Output Low Voltage CMOS            | Vcc = Min, lo <sub>L</sub> = 10 μ                                      | A                    | _       | _       | 0.15     | V        |
| Vонс                        | Output High Voltage CMOS           | Vcc = Min, Iон = -10                                                   | μA                   | Vcc-0.3 | _       | _        | V        |
| lı∟                         | Input Leakage                      | 0 < VIN < VCC                                                          |                      | -10     | _       | +10      | μA       |
| loL                         | I/O Leakage                        | 0 < VIN < VCC                                                          |                      | -10     | _       | +10      | μA       |
| lcc<br>(active)             | Active Power Supply Current        | fclk @ 8 MHz (1/tcp)                                                   | Vcc = 5V<br>Vcc = 3V | _       | 10<br>5 | 15<br>10 | mA<br>mA |
| Icclf<br>(low<br>frequency) | Active Current Low Frequency. Read | fclk @1 MHz (1/tcp)                                                    | Vcc = 5V<br>Vcc = 3V | _       | 7<br>4  | 10<br>7  | mA<br>mA |
| Iccsb<br>(standby)          | Standby Vcc Supply Current         | CS = Vcc, Vin = Vcc or 0                                               |                      | _       | <1      | 10       | μA       |
| Cin                         | Input Capacitance (1)              | T <sub>A</sub> = 25°C, V <sub>CC</sub> = 5V or 3V<br>Frequency = 1 MHz |                      | _       | _       | 10       | pF       |
| Соит                        | Output Capacitance (1)             | TA = 25°C, Vcc = 5V<br>Frequency = 1 MHz                               | _                    | _       | 10      | pF       |          |

#### Notes

- 1. Tested on a sample basis or specified through design or characterization data.
- 2. See Preliminary Designation page 30.



## AC ELECTRICAL CHARACTERISTICS (Preliminary) 4

|             | 16 MHz                                 |     |     |     |      |  |  |
|-------------|----------------------------------------|-----|-----|-----|------|--|--|
| Symbol      | Description                            | Min | Тур | Max | Unit |  |  |
| tcyc        | SCK Serial Clock Period (1)            | 62  | _   | _   | ns   |  |  |
| twн         | SCK Serial Clock High or Low Time      | 24  | _   | _   | ns   |  |  |
| twL         |                                        |     |     |     |      |  |  |
| trı         | SCK Serial Clock Rise or Fall Time (2) | _   | _   | 5   | ns   |  |  |
| trı         |                                        |     |     |     |      |  |  |
| tsu         | Data Input Setup Time to SCLK          | 25  | _   | _   | ns   |  |  |
| tıн         | Data Input Hold Time from SCLK         | 0   | _   | _   | ns   |  |  |
| toн         | Data Output Hold Time from SCLK        | 0   | _   | _   | ns   |  |  |
| tv          | Data Output Valid after SCLK (1,3)     | _   | _   | 40  | ns   |  |  |
| tcss        | CS Setup Time to Command               | 100 | _   | _   | ns   |  |  |
| tcsh        | CS Hold Time after Command             | 100 | _   | _   | ns   |  |  |
| twp         | Erase/Write Program Time               | _   | 5   | 10  | ms   |  |  |
|             | (see Write to Sector Command)          |     |     |     |      |  |  |
| teo         | Erase Only Time                        | _   | 2   | 4   | ms   |  |  |
|             | (see Erase Sector/Block Commands)      |     |     |     |      |  |  |
| two         | Write Only Time                        | _   | 3   | 6   | ms   |  |  |
|             | (see Write Only to Sector Command)     |     |     |     |      |  |  |
| txs         | Transfer or Compare Sector             | _   | 100 | 150 | μs   |  |  |
|             | (see Transfer/Compare All Command)     |     |     |     |      |  |  |
| thd         | SCK Setup Time to HOLD                 | 10  | _   | _   | ns   |  |  |
| tcd         | SCK Hold Time from HOLD                | 30  | _   | _   | ns   |  |  |
| tcs         | CS Deselect Time                       | 160 | _   | _   | ns   |  |  |
| <b>t</b> RB | READY / BUSY Valid Time                | 160 | _   | _   | ns   |  |  |
| tdis        | Data Output Disable Time               | _   | _   | 60  | ns   |  |  |
| tHZ         | Data Disable/Enable from HOLD          | _   | _   | 60  | ns   |  |  |

### Notes:

<sup>1.</sup> To achieve maximum clock performance, the read clock edge will need to be set for rising edge operation in the configuration register (RCE=1).

2. Test points are 10% and 90% points for rise/fall times. All others timings are measured at 50% point.

3. With 30 pF (16 MHz) load SO to GND.

<sup>4.</sup> See Preliminary Designation page 30.

# SERIAL OUTPUT TIMING



## **SERIAL INPUT TIMING**



## **HOLD TIMING**





## **PACKAGING INFORMATION**

Plastic TSOP-28-pins Package Code: Type I (V)



| Plastic TSOP Type I (V) |        |       |    |       |       |
|-------------------------|--------|-------|----|-------|-------|
|                         | Millim | eters |    | Inc   | hes   |
| Symbol                  | Min    | Max   |    | Min   | Max   |
| No. Lead                | S      |       | 28 |       |       |
| Α                       | 1.00   | 1.20  |    | 0.039 | 0.047 |
| A1                      | 0.05   | 0.20  |    | 0.002 | 0.008 |
| В                       | 0.15   | 0.25  |    | 0.006 | 0.010 |
| С                       | 0.10   | 0.20  |    | 0.004 | 0.008 |
| D                       | 7.90   | 8.10  |    | 0.311 | 0.319 |
| Е                       | 11.60  | 11.80 |    | 0.457 | 0.465 |
| Н                       | 13.30  | 13.50 |    | 0.524 | 0.531 |
| е                       | 0.55   | BSC   |    | 0.022 | BSC   |
| L                       | 0.50   | 0.70  |    | 0.020 | 0.028 |
| α                       | 0°     | 5°    |    | 0°    | 5°    |

#### Notes:

- Controlling dimension: millimeters, unless otherwise specified.
- BSC = Basic lead spacing between centers.
   Dimensions D and E do not include mold flash protrusions and should be measured from the bottom of the package.
- 4. Formed leads shall be planar with respect to one another within 0.004 inches at the seating plane.



## PRELIMINARY DESIGNATION

The "Preliminary" designation on an *NexFlash* data sheet indicates that the product is not fully characterized. The specifications are subject to change and are not guaranteed. *NexFlash* or an authorized sales representative should be consulted for current information before using this product.

## **IMPORTANT NOTICE**

NexFlash reserves the right to make changes to the products contained in this publication in order to improve design, performance or reliability. NexFlash assumes no responsibility for the use of any circuits described herein, conveys no license under any patent or other right, and makes no representation that the circuits are free of patent infringement. Charts and schedules contained herein reflect representative operating parameters, and may vary depending upon a user's specific application. While the information in this publication has been carefully checked, NexFlash shall not be liable for any damages arising as a result of any error or omission.

### LIFE SUPPORT POLICY

NexFlash does not recommend the use of any of it's products in life support applications where the failure or malfunction of the product can reasonably be expected to cause failure in the life support system or to significantly affect its safety or effectiveness. Products are not authorized for use in such applications unless NexFlash receives written assurances, to it's satisfaction, that:

- (a) the risk of injury or damage has been minimized;
- (b) the user assumes all such risks; and
- (c) potential liability of *NexFlash* is adequately protected under the circumstances.

#### Trademarks:

NexFlash is a trademark of NexFlash Technologies, Inc. All other marks are the property of their respective owner.

## ORDERING INFORMATION

| Size    | Order Part No. | Package                                          |
|---------|----------------|--------------------------------------------------|
| 8M-bit  | NX25F080B-3V-R | SPI, 28-pin, TSOP (Type I) 3V, Restricted Sector |
| 8M-bit  | NX25F080B-5V-R | SPI, 28-pin, TSOP (Type I) 5V, Restricted Sector |
| 16M-bit | NX25F160B-3V-R | SPI, 28-pin, TSOP (Type I) 3V, Restricted Sector |
| 16M-bit | NX25F160B-5V-R | SPI, 28-pin, TSOP (Type I) 5V, Restricted Sector |

Note: Contact NexFlash for availability on non-restricted sector devices





3114 Scott Blvd • Santa Clara, CA 95054 Phone: 408-969-4700 • Fax: 408-588-0819 sales@nexflash.com • www.nexflash.com