## Features

- Serial Peripheral Interface (SPI) Compatible
- Supports SPI Modes 0 (0,0) and 3 (1,1)
  - Datasheet describes Mode 0 Operation
- 50 MHz Clock Rate
- Byte Mode and Page Mode Program (1 to 256 Bytes) Operations
- Sector/Block/Page Architecture
  - Sixteen 256 byte Pages per Sector
  - Sixteen 4 Kbyte Sectors per Block
  - Eight uniform 64 Kbyte Blocks
- Self-timed Sector, Block and Chip Erase
- Product Identification Mode with JEDEC Standard
- Low-voltage Operation
  - 2.7V (V<sub>CC</sub> = 2.7V to 3.6V)
- Hardware and Software Write Protection
  - Device protection with Write Protect (WP) Pin
  - Write Enable and Write Disable Instructions
  - Software Write Protection:
    - Upper 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 or Entire Array
- Flexible Op Codes for Maximum Compatibility
- Self-timed Program Cycle
  - 30 µs/Byte Typical
- Single Cycle Reprogramming (Erase and Program) for Status Register
- High Reliability
  - Endurance: 10,000 Write Cycles Typical
- 8-lead JEDEC 150mil SOIC and 8-lead Ultra Thin Small Array Package (SAP)
- Die Sales: Waffer Form, Tape and Reel, and Bumped Wafers

## Description

The AT25FS040 provides 4,194,304 bits of serial reprogrammable Flash memory organized as 524,288 words of 8 bits each. The device is optimized for use in many industrial and commercial applications where low-power and low-voltage operation are essential. The AT25FS040 is available in a space-saving 8-lead JEDEC SOIC and 8-lead Ultra Thin SAP packages.

| Table 0-1. | Pin Configuration        |
|------------|--------------------------|
| Pin Name   | Function                 |
| CS         | Chip Select              |
| SCK        | Serial Data Clock        |
| SI         | Serial Data Input        |
| SO         | Serial Data Output       |
| GND        | Ground                   |
| VCC        | Power Supply             |
| WP         | Write Protect            |
| HOLD       | Suspends Serial<br>Input |





### 8-lead SAP

| VCC  | 8           |   | CS  |  |  |
|------|-------------|---|-----|--|--|
| HOLD | 7           | 2 | SO  |  |  |
| SCK  | 6           | 3 | WP  |  |  |
| SI   | 5           | 4 | GND |  |  |
|      | Bottom View |   |     |  |  |





High Speed Small Sectored SPI Flash Memory

4M (524,288 x 8)

## AT25FS040

5107E-SFLSH-8/07



The AT25FS040 is enabled through the Chip Select pin ( $\overline{CS}$ ) and accessed via a 3-wire interface consisting of Serial Data Input (SI), Serial Data Output (SO), and Serial Clock (SCK). All write cycles are completely self-timed.

BLOCK WRITE protection for upper 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 or the entire memory array is enabled by programming the status register. Separate write enable and write disable instructions are provided for additional data protection. Hardware data protection is provided via the WP pin to protect against inadvertent write attempts to the status register. The HOLD pin may be used to suspend any serial communication without resetting the serial sequence.

## 1. Absolute Maximum Ratings\*

| Operating Temperature                        | –40°C to +85°C  |
|----------------------------------------------|-----------------|
| Storage Temperature                          | –65°C to +150°C |
| Voltage on Any Pin<br>with Respect to Ground | –1.0V to +5.0V  |
| Maximum Operating Voltage                    | 4.2V            |
| DC Output Current                            | 5.0 mA          |

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

### Figure 1-1. Block Diagram



### Table 1-1.Pin Capacitance<sup>(1)</sup>

Applicable over recommended operating range from  $T_A = 25^{\circ}C$ , f = 1.0 MHz,  $V_{CC} = +3.6V$  (unless otherwise noted)

| Symbol           | Test Conditions                                                                      | Max | Units | Conditions     |
|------------------|--------------------------------------------------------------------------------------|-----|-------|----------------|
| C <sub>OUT</sub> | Output Capacitance (SO)                                                              | 8   | pF    | $V_{OUT} = 0V$ |
| C <sub>IN</sub>  | Input Capacitance ( $\overline{CS}$ , SCK, SI, $\overline{WP}$ , $\overline{HOLD}$ ) | 6   | pF    | $V_{IN} = 0V$  |

Note: 1. This parameter is characterized and is not 100% tested.

**Table 1-2.**DC Characteristics (Preliminary – Subject to Change)

Applicable over recommended operating range from:  $T_{AI} = -40^{\circ}C$  to  $+85^{\circ}C$ ,  $V_{CC} = +2.7V$  to +3.6V,  $T_{AC} = 0^{\circ}C$  to  $+70^{\circ}C$ ,  $V_{CC} = +2.7V$  to +3.6V (unless otherwise noted)

| Symbol                         | Parameter           | Test Condition                                        |                           | Min                   | Тур  | Мах                   | Units |
|--------------------------------|---------------------|-------------------------------------------------------|---------------------------|-----------------------|------|-----------------------|-------|
| V <sub>CC</sub>                | Supply Voltage      |                                                       |                           | 2.7                   |      | 3.6                   | V     |
| I <sub>CC1</sub>               | Supply Current      | V <sub>CC</sub> = 3.6V at 20 MHz,                     | SO = Open Read            |                       | 10.0 | 17.0                  | mA    |
| I <sub>CC2</sub>               | Supply Current      | V <sub>CC</sub> = 3.6V at 20 MHz,                     | SO = Open Write           |                       | 15.0 | 45.0                  | mA    |
| I <sub>SB</sub>                | Standby Current     | $V_{CC} = 2.7V, \overline{CS} = V_{CC}$               |                           |                       | 2.0  | 10.0                  | μA    |
| I <sub>IL</sub>                | Input Leakage       | $V_{IN} = 0V$ to $V_{CC}$                             |                           | -3.0                  |      | 3.0                   | μA    |
| I <sub>OL</sub>                | Output Leakage      | $V_{IN} = 0V$ to $V_{CC}$ , $T_{AC} =$                | 0°C to 70°C               | -3.0                  |      | 3.0                   | μA    |
| V <sub>IL</sub> <sup>(1)</sup> | Input Low Voltage   |                                                       |                           | -0.6                  |      | V <sub>CC</sub> x 0.3 | V     |
| V <sub>IH</sub> <sup>(1)</sup> | Input High Voltage  |                                                       |                           | V <sub>CC</sub> x 0.7 |      | V <sub>CC</sub> + 0.5 | V     |
| V <sub>OL</sub>                | Output Low Voltage  |                                                       | I <sub>OL</sub> = 0.15 mA |                       |      | 0.2                   | V     |
| V <sub>OH</sub>                | Output High Voltage | $2.7 \text{ V} \leq \text{V}_{CC} \leq 3.6 \text{ V}$ | I <sub>OH</sub> = -100 μA | V <sub>CC</sub> - 0.2 |      |                       | V     |

Note: 1.  $V_{IL}$  and  $V_{IH}$  max are reference only and are not tested.





 Table 1-3.
 AC Characteristics (Preliminary – Subject to Change)

Applicable over recommended operating range from  $T_A$  = –40°C to +85°C,  $V_{CC}$  = +2.7V to +3.6V

 $C_L = 1$  TTL Gate and 30 pF (unless otherwise noted)

| Symbol                   | Parameter                              | Min | Тур | Мах | Units                       |
|--------------------------|----------------------------------------|-----|-----|-----|-----------------------------|
| f <sub>SCK</sub>         | SCK Clock Frequency                    | 0   |     | 50  | MHz                         |
| t <sub>RI</sub>          | Input Rise Time                        |     |     | 5   | ns                          |
| t <sub>FI</sub>          | Input Fall Time                        |     |     | 5   | ns                          |
| t <sub>WH</sub>          | SCK High Time                          | 9   |     |     | ns                          |
| t <sub>WL</sub>          | SCK Low Time                           | 9   |     |     | ns                          |
| t <sub>CS</sub>          | CS High Time                           | 100 |     |     | ns                          |
| t <sub>CSS</sub>         | CS Setup Time                          | 5   |     |     | ns                          |
| t <sub>CSH</sub>         | CS Hold Time                           | 5   |     |     | ns                          |
| t <sub>SU</sub>          | Data In Setup Time                     | 5   |     |     | ns                          |
| t <sub>H</sub>           | Data In Hold Time                      | 5   |     |     | ns                          |
| t <sub>HD</sub>          | Hold Setup Time                        | 5   |     |     | ns                          |
| t <sub>CD</sub>          | Hold Hold Time                         | 5   |     |     | ns                          |
| t <sub>v</sub>           | Output Valid                           |     |     | 9   | ns                          |
| t <sub>HO</sub>          | Output Hold Time                       | 0   |     |     | ns                          |
| t <sub>LZ</sub>          | Hold to Output Low Z                   |     |     | 9   | ns                          |
| t <sub>HZ</sub>          | Hold to Output High Z                  |     |     | 9   | ns                          |
| t <sub>DIS</sub>         | Output Disable Time                    |     |     | 9   | ns                          |
| t <sub>SE</sub>          | Sector Erase Time                      |     | 50  | 200 | ms                          |
| t <sub>BE</sub>          | Block Erase Time                       |     | 200 | 500 | ms                          |
| t <sub>CE</sub>          | Chip Erase Time                        |     | 1.6 | 4   | S                           |
| t <sub>SR</sub>          | Status Register Write Cycle Time       |     |     | 60  | ms                          |
| t <sub>BPC</sub>         | Byte Program Cycle Time <sup>(1)</sup> |     | 30  | 50  | μs                          |
| Endurance <sup>(2)</sup> |                                        |     | 10K |     | Write Cycles <sup>(3)</sup> |

Notes: 1. The programming time for n bytes will be equal to n x  $t_{\text{BPC}}$ 

2. This parameter is characterized at 3.0V.

3. One write cycle consists of erasing a sector, followed by programming the same sector.

4

### 2. Serial Interface Description

**MASTER:** The device that generates the serial clock.

**SLAVE:** Because the Serial Clock pin (SCK) is always an input, the AT25FS040 always operates as a slave.

**TRANSMITTER/RECEIVER:** The AT25FS040 has separate pins designated for data transmission (SO) and reception (SI).

MSB: The Most Significant Bit (MSB) is the first bit transmitted and received.

**SERIAL OP-CODE:** After the device is selected with  $\overline{CS}$  going low, the first byte will be received. This byte contains the op-code that defines the operations to be performed.

**INVALID OP-CODE:** If an invalid op-code is received, no data will be shifted into the AT25FS040, and the serial output pin (SO) will remain in a high impedance state until the falling edge of  $\overline{CS}$  is detected again. This will reinitialize the serial communication.

**CHIP SELECT:** The AT25FS040 is selected when the  $\overline{CS}$  pin is low. When the device is not selected, data will not be accepted via the SI pin, and the serial output pin (SO) will remain in a high impedance state.

**HOLD:** The HOLD pin is used in conjunction with the  $\overline{CS}$  pin to select the AT25FS040. When the device is selected and a serial sequence is underway, HOLD can be used to pause the serial communication with the master device without resetting the serial sequence. To pause, the HOLD pin must be brought low while the SCK pin is low. To resume serial communication, the HOLD pin is brought high while the SCK pin is low (SCK may still toggle during HOLD). Inputs to the SI pin will be ignored while the SO pin is in the high impedance state.

**WRITE PROTECT:** The AT25FS040 has a write lockout feature that can be activated by asserting the write protect pin ( $\overline{WP}$ ). When the lockout feature is activated, locked-out sectors will be READ only. The write protect pin will allow normal read/write operations when held high. When the  $\overline{WP}$  is brought low and WPEN bit is "1", all write operations to the status register are inhibited.  $\overline{WP}$  going low while  $\overline{CS}$  is still low will interrupt a write to the status register. If the internal status register write cycle has already been initiated,  $\overline{WP}$  going low will have no effect on any write operation to the status register. The  $\overline{WP}$  pin function is blocked when the WPEN bit in the status register is "0". This will allow the user to install the AT25FS040 in a system with the  $\overline{WP}$  pin tied to ground and still be able to write to the status register. All  $\overline{WP}$  pin functions are enabled when the WPEN bit is set to "1".





## 3. Operating Features

### 3.1 Recommended Power-up

When the power supply is turned on, the Vcc to the device rises monotonically from ground to the full operating Vcc. During this time, the Chip Select (CS) signal is not allowed to float and must follow Vcc. For this reason, it is recommended to use a suitable pull-up resistor connected between CS and Vcc. The device is ready for communication once a stable Vcc is reached within the specified operating voltage range.

### 3.2 Recommended Power-down

The device must be deselected and in standby and write disabled mode prior to Vcc power down sequence. This means there should be no write operation/internal write cycle or read operation in progress during power down. The Vcc decay should be monotonic from Vcc to ground and the Chip Select (CS) line must be allowed to follow Vcc during power down. After power down, it is recommended Vcc should be held at ground level for at least 0.5 seconds before power up again.

### 3.3 Power On Reset Protection

In order to prevent data corruption and inadvertent write operations during device power-up and power down, a Power On Reset (POR) circuit is enabled. At Power-up (continuous rise of Vcc from 0v), the device will not respond to any instruction and will be held in reset (which puts the device in standby mode) until the Vcc has reached the Power On Reset threshold voltage. This threshold is lower than the minimum specified Vcc operating voltage.

At power down (continuous fall of Vcc), when Vcc drops from the operating voltage below the POR threshold, all operations are disabled and the device will not respond to any command. A stable and valid Vcc must be applied before executing any communication. **Please note:** The POR threshold trip point is ~1.8V for Serial Flash products and is ensured by design to have a reset during power-up and power down and is not 100% tested.

### Figure 3-1. SPI Serial Interface







## 4. Functional Description

The AT25FS040 is designed to interface directly with the synchronous serial peripheral interface (SPI) of the 6800 type series of microcontrollers.

The AT25FS040 utilizes an 8-bit instruction register. The list of instructions and their operation codes are contained in Table 4-1. All instructions, addresses, and data are transferred with the MSB first and start with a high-to-low transition.

Write is defined as program and/or erase in this specification. The following commands, PRO-GRAM, SECTOR ERASE, BLOCK ERASE, CHIP ERASE, and WRSR are write instructions for AT25FS040.

| Instruction Name | One Byte Op( | Code | Operation                                       |
|------------------|--------------|------|-------------------------------------------------|
|                  | Binary       | Hex  |                                                 |
| WREN             | 0000 X110    | 06   | Set Write Enable Latch                          |
| WRDI             | 0000 X100    | 04   | Reset Write Enable Latch                        |
| RDSR             | 0000 X101    | 05   | Read Status Register                            |
| WRSR             | 0000 X001    | 01   | Write Status Register                           |
| READ             | 0000 0011    | 03   | Read Data from Memory Array                     |
| FAST READ        | 0000 1011    | 0B   | Read Data from Memory Array (with dummy cycles) |
| PROGRAM          | 0000 X010    | 02   | Program Data Into Memory Array                  |
|                  | 0010 0000    | 20   | Erase One 4kbyte Sector in Memory Array         |
| SECTOR ERASE (1) | 1101 0111    | D7   |                                                 |
|                  | 0101 0010    | 52   | Erase One 64kbyte Block in Memory Array         |
| BLOCK ERASE(1)   | 1101 1000    | D8   |                                                 |
|                  | 0110 0000    | 60   | Erase All Memory Array                          |
| CHIP ERASE(1)    | 1100 0111    | C7   |                                                 |
|                  | 1001 1111    | 9F   | Read Manufacturer and Product ID                |
| RDID(1)          | 1010 1011    | AB   |                                                 |

 Table 4-1.
 Instruction Set for the AT25FS040

Note: 1. Either one of the OP CODES will execute the instruction.

**WRITE ENABLE (WREN):** The device will power up in the write disable state when  $V_{CC}$  is applied. All write instructions must therefore be preceded by the WREN instruction.

**WRITE DISABLE (WRDI):** To protect the device against inadvertent writes, the WRDI instruction disables all write commands. The WRDI instruction is independent of the status of the  $\overline{WP}$  pin.

**READ STATUS REGISTER (RDSR):** The RDSR instruction provides access to the status register. The READY/BUSY and write enable status of the device can be determined by the RDSR instruction. Similarly, the Block Write Protection bits indicate the extent of protection employed.

8

These bits are set by using the WRSR instruction. During internal write cycles, all other commands will be ignored except the RDSR instruction.

 Table 4-2.
 Status Register Format

|       |       | 0     |       |       |       |       |       |
|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| WPEN  | BP4   | BP3   | BP2   | BP1   | BP0   | WEN   | RDY   |

 Table 4-3.
 Read Status Register Bit Definition

| Bit                    | Definition                                                                                                       |  |  |  |  |  |
|------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit 0 (RDY)            | Bit $0 = 0$ (RDY) indicates the device is READY. Bit $0 = 1$ indicates the write cycle is in progress.           |  |  |  |  |  |
| Bit 1 (WEN)            | Bit $1 = 0$ indicates the device <i>is not</i> WRITE ENABLED. Bit $1 = 1$ indicates the device is WRITE ENABLED. |  |  |  |  |  |
| Bit 2 (BP0)            | See Table 4-5.                                                                                                   |  |  |  |  |  |
| Bit 3 (BP1)            | See Table 4-5.                                                                                                   |  |  |  |  |  |
| Bit 4 (BP2)            | See Table 4-5.                                                                                                   |  |  |  |  |  |
| Bit 5 (BP3)            | See Table 4-5.                                                                                                   |  |  |  |  |  |
| Bit 6 (BP4)            | See Table 4-5.                                                                                                   |  |  |  |  |  |
| Bit 7 (WPEN)           | See Table 4-6.                                                                                                   |  |  |  |  |  |
| Bits 0-7 are 1s during | Bits 0-7 are 1s during an internal write cycle.                                                                  |  |  |  |  |  |

**READ PRODUCT ID (RDID):** The RDID instruction allows the user to read the manufacturer ID byte followed by two device ID bytes. The manufacturer ID is assigned by JEDEC and is 1Fh for Atmel (see Table 4-4). The first device ID byte indicates the memory type (66h=AT25FS040) followed by the device memory capacity byte (04h). For maximum compatibility and flexibility, two RDID opcodes (9Fh and ABh) are supported and will perform the same operation.

 Table 4-4.
 Read Product ID (RDID)

| Manufacturer ID | Device ID                   |     |  |  |  |
|-----------------|-----------------------------|-----|--|--|--|
|                 | Memory Type Memory Capacity |     |  |  |  |
| 1Fh             | 66h                         | 04h |  |  |  |

The device is first selected by driving Chip Select ( $\overline{CS}$ ) low then the RDID opcode is shifted in on Serial In (SI) during rising edge of clock. The 24-bit Manufacturer and Device Identification Codes stored in memory are clocked out on Serial Output (SO) starting on the falling edge of clock (see Figure 5-13). If  $\overline{CS}$  stays low after the last bit of second device ID byte is shifted out, the manufacturer ID and 2 byte device ID will continue to be clocked out until  $\overline{CS}$  goes high. The RDID sequence is terminated any time  $\overline{CS}$  is driven high and the device will go into standby mode.

**WRITE STATUS REGISTER (WRSR):** The WRSR instruction allows the user to select one of eight levels of protection for the AT25FS040. The AT25FS040 is divided into eight blocks where the top 1/64, 1/32, 1/16, 1/8, top quarter (1/4), top half (1/2), or all of the memory blocks can be protected (locked out) from write. Any of the locked-out blocks will therefore be READ only. The locked-out sector/block and the corresponding status register control bits are shown in Table 4-5 on page 10.





The six bits, BP0, BP1, BP2, BP3, BP4 and WPEN, are nonvolatile cells that have the same properties and functions as the regular memory cells.

| Level      | Status Register Bits |     |     |     |     | A                 | T25FS040                        |
|------------|----------------------|-----|-----|-----|-----|-------------------|---------------------------------|
|            | BP4                  | BP3 | BP2 | BP1 | BP0 | Array Address     |                                 |
| locked Out | Locked-out<br>Blocks |     |     |     |     |                   |                                 |
| 0(none)    | 0                    | 0   | 0   | 0   | 0   | None              | None                            |
| 1(1/64)    | 0                    | 1   | 0   | 0   | 0   | 07E000H - 07FFFFH | Sector 15-16 of Block 8         |
| 2(1/32)    | 1                    | 0   | 0   | 0   | 0   | 07C000H - 07FFFFH | Sector 13-16 of Block 8         |
| 3(1/16)    | 1                    | 1   | 0   | 0   | 0   | 078000H - 07FFFFH | Sector 9-16 of Block 8          |
| 4(1/8)     | x                    | x   | 0   | 0   | 1   | 070000H - 07FFFFH | All sectors of Block 8          |
| 5(1/4)     | x                    | x   | 0   | 1   | 0   | 060000H - 07FFFFH | All Sectors of Block 7,8        |
| 6(1/2)     | x                    | x   | 0   | 1   | 1   | 040000H - 07FFFFH | All Sectors of Block 5,6,7,8    |
| 7(ALL)     | x                    | x   | 1   | х   | x   | 000000H - 07FFFFH | All Sectors of All Blocks (1-8) |

 Table 4-5.
 Sector/Block Write Protect Bits

#### Note: 1. x = don't care

The WRSR instruction also allows the user to enable or disable the Write Protect ( $\overline{WP}$ ) pin through the use of the Write Protect Enable (WPEN) bit. Hardware write protection is enabled when the  $\overline{WP}$  pin is low and the WPEN bit is "1". Hardware write protection is disabled when either the  $\overline{WP}$  pin is high or the WPEN bit is "0." When the device is hardware write protected, writes to the Status Register, including the Block Protect bits and the WPEN bit, and the locked-out sectors in the memory array are disabled. Write is only allowed to sectors of the memory which are not locked out. The WRSR instruction is self-timed to automatically erase and program BP0, BP1, BP2, BP3, BP4 and WPEN bits. In order to write the status register, two separate instructions must be executed. First, the device must be write enabled via the WREN instruction. Then,  $\overline{CS}$  must be low and the WRSR instruction and data for the six bits are entered. The WRSR write cycle will begin once  $\overline{CS}$  goes high. During the internal write cycle, all instructions will be ignored except RDSR instructions. The AT25FS040 will automatically return to write disable state at the completion of the WRSR cycle. The status register is factory programmed to all 0's.

Note: When the WPEN bit is hardware write protected, it cannot be changed back to "0", as long as the WP pin is held low.

| WPEN | WP   | WEN | ProtectedBlocks | UnprotectedBlocks | Status Register |
|------|------|-----|-----------------|-------------------|-----------------|
| 0    | х    | 0   | Protected       | Protected         | Protected       |
| 0    | х    | 1   | Protected       | Writable          | Writable        |
| 1    | Low  | 0   | Protected       | Protected         | Protected       |
| 1    | Low  | 1   | Protected       | Writable          | Protected       |
| х    | High | 0   | Protected       | Protected         | Protected       |
| х    | High | 1   | Protected       | Writable          | Writable        |

Table 4-6.WPEN Operation

**READ** (**READ**): The READ instruction sequence reads the memory array up to the maximum speed of 50MHz. Reading the AT25FS040 via the SO (Serial Output) pin requires the following sequence. After the CS line is pulled low to select the device, the READ instruction is clocked in on the SI line, followed by the byte address to be read. Upon completion, any data on the SI line will be ignored. The data (D7-D0) at the specified address is then shifted out onto the SO line (see Figure 5-6). If only one byte is to be read, the  $\overline{CS}$  line should be driven high after the least significant data bit. To continue read operation and sequentially read subsequent byte addresses from the device by simply keeping  $\overline{CS}$  low and provide a clock signal. The device incorporates an internal address counter that automatically increments to the next byte address during sequential read operation. The READ instruction can be continued since the byte address is automatically incremented and data will continue to be shifted out of the AT25FS040 until the highest byte address is reached. When the last bit of the memory has been read, the device will continue reading back at the beginning of the array (000000h) without delay. The data is always output from the device with the most significant bit (MSB) of a byte first. The READ sequence is terminated any time CS is driven high and the device will go into standby mode.

FAST READ (FAST READ): The FAST READ instruction sequence reads the memory array up to the maximum speed of 50MHz (same as standard READ sequence). The FAST READ is an alternate command for the READ and allows for FAST READ instruction compatibility support. The difference between the two is FAST READ requires a "dummy byte" and READ does not. Reading the AT25FS040 via the SO (Serial Output) pin requires the following sequence. After the CS line is pulled low to select the device, the FAST READ instruction is clocked in on the SI line, followed by the byte address to be read and the dummy byte (the SO line output will be high Z state). Upon completion, any data on the SI line will be ignored. The data (D7-D0) at the specified address is then shifted out onto the SO line (see Figure 5-7). If only one byte is to be read, the CS line should be driven high after the least significant data bit. To continue read operation and sequentially read subsequent byte addresses from the device by simply keeping CS low and provide a clock signal. The device incorporates an internal address counter that automatically increments to the next byte address during sequential read operation. The FAST READ instruction can be continued since the byte address is automatically incremented and data will continue to be shifted out of the AT25FS040 until the highest address is reached. When the last bit of the memory has been read, the device will continue reading back at the beginning of the array (000000h) without delay. The data is always output from the device with the most significant bit (MSB) of a byte first. The FAST READ sequence is terminated any time  $\overline{CS}$  is driven high and the device will go into standby mode.

**PROGRAM (PROGRAM):** The PROGRAM instruction allows up to 256 data bytes to be written to each page in the memory in one-operation changing data bits from a logic 1 to 0 state. The AT25FS040 memory array contains 524,288 programmable data bytes internally organized into 256 bytes per page with a total of 2048 pages in the memory.

In order to program the AT25FS040, two separate instructions must be executed. First, the device must be write enabled via the WREN instruction. Then the PROGRAM instruction can be executed and requires the following sequence. After the  $\overline{CS}$  line is pulled low to select the device, the PROGRAM instruction is clocked in via the SI line followed by the byte address (see Figure 5-8) and the data byte(s) to be programmed. Programming will start after  $\overline{CS}$  pin is brought high. Please note: The low to high transition of the  $\overline{CS}$  pin must occur during the SCK low time immediately after clocking in the D0 (LSB) data bit to initiate programming cycle. Also, a WREN instruction must precede each and every PROGRAM instruction. The Ready/Busy status of the device can be determined by initiating a RDSR instruction. If bit 0=1, the program cycle is





still in progress. If Bit 0=0, the programming cycle has ended. Only the RDSR instruction is enabled during the programming cycle and all other opcode instructions are ignored until programming cycle has completed.

A single PROGRAM instruction programs 1 to 256 consecutive bytes within a page if it is not write protected. The starting byte address can be anywhere within the page. When the end of the page is reached, the address will wrap around to the beginning of the same page. If the data to be programmed is less than a full page, the data of all other bytes on the same page will remain unchanged meaning that the unwritten address locations within the page will not be changed. If more than 256 bytes of data are provided, the address counter will roll over on the same page and the previous data provided will be replaced. The same byte cannot be reprogrammed without erasing the whole sector or block first. The AT25FS040 will automatically return to the write disable state at the completion of the programming cycle.

Note: If the device is not write enabled (WREN), the device will ignore the Write instruction and will return to the standby state when  $\overline{CS}$  is brought high. A new  $\overline{CS}$  falling edge is required to re-initiate the serial communication.

Table 4-7.Address Key

| Address         | AT25FS040                         |
|-----------------|-----------------------------------|
| A <sub>N</sub>  | A <sub>18</sub> - A <sub>0</sub>  |
| Don't Care Bits | A <sub>23</sub> - A <sub>19</sub> |

ERASE OPERATION: The AT25FS040 memory array is internally organized into uniform 4K byte sectors or uniform 64K byte uniform blocks (see Table 4-8). Before data can be reprogrammed, the sector or block that contains the data must be erased first. In order to erase the AT25FS040, there are three flexible erase instructions that can be executed as follows: SECTOR ERASE, BLOCK ERASE and CHIP ERASE instructions. A SECTOR ERASE instruction allows erasing any individual 4K sector without changing data in rest of memory. The BLOCK ERASE instruction allows erasing any individual block and CHIP ERASE allows erasing the entire memory array.

**SECTOR ERASE (SECTOR ERASE):** The SECTOR ERASE instruction sets all 4K bytes in the selected sector to logic 1 or erased state. In order to sector erase the AT25FS040, two separate instructions must be executed. First, the device must be write enabled via the WREN instruction. Then the SECTOR ERASE instruction can be executed and will erase every byte in the selected sector if the sector is not locked out. The sector address is automatically determined if any address within the sector is selected (see Figure 5-10). The SECTOR ERASE instruction is internally controlled and self timed to completion. During this time, all commands will be ignored except RDSR instruction. The progress or completion of the erase operation can be determined by reading ready/busy bit (bit 0) through RDSR instruction. If Bit 0=1, sector erase cycle is in progress. If Bit 0=0, the erase operation has been completed. The AT25FS040 will automatically return to the write disable state at the completion of the SECTOR ERASE cycle.

07FFFFH Sector 16 Block 8 07F000H 1/64 07EFFFH Sector 15 1/32 07E000H 07DFFFH Sector 14 07D000H 07CFFFH Sector 13 1/16 07C000H 07BFFFH Sector 12 07B000H 07AFFFH Sector 11 07A000H 079FFFH 1/8 Sector 10 079000H 078FFFH Sector 9 078000H 077FFFH Sector 8 077000H 076FFFH Sector 7 076000H 075FFFH Sector 6 075000H 074FFFH Sector 5 074000H 073FFFH Sector 4 073000H 072FFFH Sector 3 072000H 071FFFH Sector 2 071000H 070FFFH Sector 1 070000H 06FFFFH Block 7 060000H

|  | Table 4-8. | Sector and Block Address |
|--|------------|--------------------------|
|--|------------|--------------------------|



Block 6

05FFFFH

050000H



| Diack 5  |  |  | 04FFFFH |
|----------|--|--|---------|
| DIUCK D  |  |  | 040000H |
| Block 4  |  |  | 03FFFFH |
| DIUCK 4  |  |  | 030000H |
| Block 3  |  |  | 02FFFFH |
|          |  |  | 020000H |
| Block 0  |  |  | 01FFFFH |
| DIUCK 2  |  |  | 010000H |
| Diagle 1 |  |  | 00FFFFH |
| BIOCK 1  |  |  | 000000H |

### **Table 4-8.**Sector and Block Address (Continued)

BLOCK ERASE (BLOCK ERASE): The BLOCK ERASE instruction sets all 64K bytes in the selected block to logic 1 or erased state. In order to block erase the AT25FS040, two separate instructions must be executed. First, the device must be write enabled via the WREN instruction. Then the BLOCK ERASE instruction can be executed and will erase every byte in the selected block if the block is not locked out. The block address is automatically determined if any address within the block is selected (see Figure 5-11). The BLOCK ERASE instruction is internally controlled and self timed to completion. During this time, all commands will be ignored except RDSR instruction. The progress or completion of the erase operation can be determined by reading ready/busy bit (bit 0) through RDSR instruction. If Bit 0=1, block erase cycle is in progress. If Bit0=0, the erase operation has been completed. The AT25FS040 will automatically return to the write disable state at the completion of the BLOCK ERASE cycle.

**CHIP ERASE (CHIP ERASE):** As an alternative to the SECTOR ERASE/BLOCK ERASE, the CHIP ERASE instruction will erase every byte in all sectors that are not locked out. First, the device must be write enabled via the WREN instruction. Then the CHIP ERASE instruction can be executed. The CHIP ERASE instruction is internally controlled; it will automatically be timed to completion. The CHIP ERASE cycle time typically is 4 seconds. During the internal erase cycle, all instructions will be ignored except RDSR. The AT25FS040 will automatically return to the write disable state at the completion of the CHIP ERASE cycle.

## 5. Timing Diagrams (for SPI Mode 0 (0, 0))



Figure 5-1. Synchronous Data Timing









AT25FS040









# AT25FS040







## **Ordering Information**

| Ordering Code                     | Volltage | Package | Operation Range         |
|-----------------------------------|----------|---------|-------------------------|
| AT25FS040N-SH27-B <sup>(1)</sup>  | 2.7      | 8S1     | Lead-Free/Halogen-Free/ |
| AT25FS040N-SH27-T <sup>(2)</sup>  | 2.7      | 8S1     | NiPdAu Lead Finish      |
| AT25FS040Y7-YH27-T <sup>(2)</sup> | 2.7      | 8Y7     | (–40°C to 85°C)         |

Notes: 1. "-B" denotes bulk.

2. "-T" denotes tape and reel, SOIC = 4K per reel and SAP = 3K per reel.

|      | Package Type                                                                                      |  |  |  |  |
|------|---------------------------------------------------------------------------------------------------|--|--|--|--|
| 8S1  | 8-lead, 0.150" Wide, Plastic Gull Wing Small outline (JEDEC SOIC)                                 |  |  |  |  |
| 8Y7  | 8-lead, 6.00 mm x 4.90 mm Body, Ultra Thin, Dual Footprint, Non-leaded, Small Array Package (SAP) |  |  |  |  |
|      | Options                                                                                           |  |  |  |  |
| -2.7 | Low Voltage (2.7V to 3.6V)                                                                        |  |  |  |  |

#### Part Marking Scheme 6.

#### 6.1 8-SOIC

TOP MARK Seal Year Seal Week |---|---|---|---|---| A T M L H Y W W |---|---|---|---|---| S 4 3 |---|---|---|---|---| \* Lot Number |---|---|---|---|---| Pin 1 Indicator (Dot)

| Y = | SEAL  | YEAR  |      |     | - WW | - 5 | SEAL W | IEEK |   |
|-----|-------|-------|------|-----|------|-----|--------|------|---|
| 6:  | 2006  | 0:    | 2010 | C   | 02   | =   | Week   | 2    |   |
| 7:  | 2007  | 1:    | 2011 | L   | 04   | =   | Week   | 4    |   |
| 8:  | 2008  | 2:    | 2012 | 2   | ::   | :   | ::::   | :    |   |
| 9:  | 2009  | 3:    | 2013 | 3   | ::   | :   | ::::   | ::   |   |
|     |       |       |      |     | 50   | =   | Week   | 50   |   |
|     |       |       |      |     | 52   | =   | Week   | 52   |   |
|     |       |       |      |     |      |     |        |      |   |
| Lot | Numbe | er to | Use  | ALL | Cha  | ra  | cters  | in   | ľ |

Lo Marking

#### BOTTOM MARK

No Bottom Mark

#### 6.2 8-Ultra Thin SAP

TOP MARK Seal Year WW = SEAL WEEK Seal Week Y = SEAL YEAR 6: 2006 0: 2010 02 = Week 2|---|---|---|---|---| 7: 2007 1: 2011 04 = Week 4A T M L H Y W W 8: 2008 2: 2012 :: : :::: : |---|---|---|---|---| 9: 2009 3: 2013 :: : :::: :: S 4 50 = Week 503 |---|---|---|---|---| 52 = Week 52Lot Number |---|---|---|---|---| \* BOTTOM MARK Pin 1 Indicator (Dot) No Bottom Mark





## 7. Package Information

### 8S1 – JEDEC SOIC



# AT25FS040

## 8Y7 – UT SAP







# 8. Revision History

| Doc. Rev. | Date   | Comments                                                                                                               |
|-----------|--------|------------------------------------------------------------------------------------------------------------------------|
| 5107E     | 8/2007 | Added Die Sales Info to Features<br>Modified Order Code Table<br>Updated to new template<br>Added Parts Marking tables |
| 5107D     | 9/2006 | Implemented Revision History.                                                                                          |



### Headquarters

*Atmel Corporation* 2325 Orchard Parkway San Jose, CA 95131 USA Tel: 1(408) 441-0311 Fax: 1(408) 487-2600

### International

Atmel Asia Room 1219 Chinachem Golden Plaza 77 Mody Road Tsimshatsui East Kowloon Hong Kong Tel: (852) 2721-9778 Fax: (852) 2722-1369 Atmel Europe Le Krebs 8, Rue Jean-Pierre Timbaud BP 309 78054 Saint-Quentin-en-Yvelines Cedex France Tel: (33) 1-30-60-70-00 Fax: (33) 1-30-60-71-11

#### Atmel Japan

9F, Tonetsu Shinkawa Bldg. 1-24-8 Shinkawa Chuo-ku, Tokyo 104-0033 Japan Tel: (81) 3-3523-3551 Fax: (81) 3-3523-7581

#### **Product Contact**

Web Site www.atmel.com *Technical Support* s\_eeprom@atmel.com Sales Contact www.atmel.com/contacts

Literature Requests www.atmel.com/literature

Disclaimer: The information in this document is provided in connection with Atmel products. No license, express or implied, by estoppel or otherwise, to any intellectual property right is granted by this document or in connection with the sale of Atmel products. EXCEPT AS SET FORTH IN ATMEL'S TERMS AND CONDI-TIONS OF SALE LOCATED ON ATMEL'S WEB SITE, ATMEL ASSUMES NO LIABILITY WHATSOEVER AND DISCLAIMS ANY EXPRESS, IMPLIED OR STATUTORY WARRANTY RELATING TO ITS PRODUCTS INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, CONSEQUENTIAL, PUNITIVE, SPECIAL OR INCIDEN-TAL DAMAGES (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF PROFITS, BUSINESS INTERRUPTION, OR LOSS OF INFORMATION) ARISING OUT OF THE USE OR INABILITY TO USE THIS DOCUMENT, EVEN IF ATMEL HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. Atmel makes no representations or warranties with respect to the accuracy or completeness of the contents of this document and reserves the right to make changes to specifications and product descriptions at any time without notice. Atmel does not make any commitment to update the information contained herein. Unless specifically provided otherwise, Atmel products are not suitable for, and shall not be used in, automotive applications. Atmel's products are not intended, or warranted for use as components in applications intended to support or sustain life.

© 2007 Atmel Corporation. All rights reserved. Atmel<sup>®</sup>, logo and combinations thereof, and others, are registered trademarks or trademarks of Atmel Corporation or its subsidiaries. Other terms and product names may be trademarks of others.