# BH95640

## 64K-Bit SPI Serial CMOS E<sup>2</sup>PROM

# FEATURES

- 5 MHz SPI Compatible
- 2.7 to 5.0 Volt Operation
- Hardware and Software Protection
- Zero Standby Current
- Low Power CMOS Technology
- SPI Modes (0,0 &1,1)
- Commercial, Industrial Temperature Ranges

- 1,000,000 Program/Erase Cycles
- 100 Year Data Retention
- Self-Timed Write Cycle
- 8-Pin SOP TSSOP
- 32-Byte Page Write Buffer
- Block Write Protection
  Protect 1/4, 1/2 or all of E<sup>2</sup>PROM Array

## DESCRIPTION

The BH95640 is a 64K-Bit SPI Serial CMOS  $E^2$ PROM internally organized as 8Kx8 bits. reduces device power requirements. The BH95640 features a 32-byte page write buffer. The device operates via the SPI bus serial interface and is enabled though a Chip Select ( $\overline{CS}$ ). In addition to the Chip Select, the clock input (SCK), data in (SI) and data out (SO) are

required to access the device. The HOLD pin may be used to suspend any serial communication without resetting the serial sequence. The BH95640 is designed with software and hardware write protection features including Block write protection. The device is available in 8-pin SOP TSSOP.

# **PIN CONFIGURATION**

#### SOP Package

#### TSSOP Package

| cs∟  | •1 | 8 | ⊐Vcc   |
|------|----|---|--------|
| so⊏  | 2  | 7 |        |
| WPC  | 3  | 6 | _] SCK |
| vss⊏ | 4  | 5 | _] SI  |

#### **PIN FUNCTIONS**

| Pin Name        | Function                    |  |  |  |
|-----------------|-----------------------------|--|--|--|
| SO              | Serial Data Output          |  |  |  |
| SCK             | Serial Clock                |  |  |  |
| WP              | Write Protect               |  |  |  |
| Vcc             | +2.5V to +5.5V Power Supply |  |  |  |
| V <sub>SS</sub> | Ground                      |  |  |  |
| CS              | Chip Select                 |  |  |  |
| SI              | Serial Data Input           |  |  |  |
| HOLD            | Suspends Serial Input       |  |  |  |
| NC              | No Connect                  |  |  |  |

# BLOCK DIAGRAM



# ABSOLUTE MAXIMUM RATINGS\*

| Temperature Under Bias–20°C to +80 $^{\circ}\text{C}$             |
|-------------------------------------------------------------------|
| Storage Temperature65°C to +150°C                                 |
| Voltage on any Pin with Respect to $V_{SS}$ 2.0V to +V_{CC} +2.0V |
| $V_{CC}$ with Respect to $V_{SS}$                                 |
| Package Power Dissipation<br>Capability (Ta = 25°C)1.0W           |
| Lead Soldering Temperature (10 secs)                              |
| Output Short Circuit Current 100 mA                               |

\*COMMENT

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions outside of those listed in the operational sections of this specification is not implied. Exposure to any absolute maximum rating for extended periods may affect device performance and reliability.

### **RELIABILITY CHARACTERISTICS**

| Parameter          | Min.      | Max. | Units       | Reference Test Method |
|--------------------|-----------|------|-------------|-----------------------|
| Endurance          | 1,000,000 |      | Cycles/Byte |                       |
| Data Retention     | 100       |      | Years       |                       |
| ESD Susceptibility | 2000      |      | Volts       |                       |
| Latch-Up           | 100       |      | mA          |                       |

## D.C. OPERATING CHARACTERISTICS

 $V_{CC}$  = +1.8V to +6.0V, unless otherwise specified.

|                  |                                        |                       | Limits |                       |       |                                                               |  |
|------------------|----------------------------------------|-----------------------|--------|-----------------------|-------|---------------------------------------------------------------|--|
| Symbol           | Parameter                              | Min.                  | Тур.   | Max.                  | Units | Test Conditions                                               |  |
| Icc1             | Power Supply Current (Operating Write) |                       |        | 10                    | mA    | V <sub>CC</sub> = 5V @ 10MHz<br>SO=open; CS=Vss               |  |
| I <sub>CC2</sub> | Power Supply Current (Operating Read)  |                       |        | 2                     | mA    | $V_{CC} = 5.0V$<br>$F_{CLK} = 10MHz$                          |  |
| I <sub>SB</sub>  | Power Supply Current (Standby)         |                       |        | 0                     | μA    | $\overline{CS} = V_{CC}$ $V_{IN} = V_{SS} \text{ or } V_{CC}$ |  |
| ILI              | Input Leakage Current                  |                       |        | 2                     | μA    |                                                               |  |
| ILO              | Output Leakage Current                 |                       |        | 3                     | μA    | $V_{OUT} = 0V$ to $V_{CC}$ ,<br>CS = 0V                       |  |
| VIL              | Input Low Voltage                      | -1                    |        | Vcc x 0.3             | V     |                                                               |  |
| VIH              | Input High Voltage                     | V <sub>CC</sub> x 0.7 |        | V <sub>CC</sub> + 0.5 | V     |                                                               |  |
| V <sub>OL1</sub> | Output Low Voltage                     |                       |        | 0.4                   | V     | 4.5V≤V <sub>CC</sub> <5.5V                                    |  |
| Voh1             | Output High Voltage                    | Vcc - 0.8             |        |                       | V     | I <sub>OL</sub> = 3.0mA<br>I <sub>OH</sub> = -1.6mA           |  |
| V <sub>OL2</sub> | Output Low Voltage                     |                       |        | 0.2                   | V     | 1.8V≤V <sub>CC</sub> <2.7V                                    |  |
| V <sub>OH2</sub> | Output High Voltage                    | V <sub>CC</sub> -0.2  |        |                       | V     | l <sub>OL</sub> = 150μΑ<br>l <sub>OH</sub> = -100μΑ           |  |





Note: Dashed Line= mode (1, 1) -----

## A.C. CHARACTERISTICS

|                                |                             | Limits            |      |                                |      |                                |      |       |               |
|--------------------------------|-----------------------------|-------------------|------|--------------------------------|------|--------------------------------|------|-------|---------------|
|                                |                             | Vcc=<br>2.5V-3.3V |      | V <sub>CC</sub> =<br>2.5V-5.5V |      | V <sub>CC</sub> =<br>4.5V-5.5V |      |       | Test          |
| SYMBOL                         | PARAMETER                   | Min.              | Max. | Min.                           | Max. | Min.                           | Max. | UNITS | Conditions    |
| t <sub>SU</sub>                | Data Setup Time             | 50                |      | 50                             |      | 20                             |      | ns    |               |
| t <sub>H</sub>                 | Data Hold Time              | 50                |      | 50                             |      | 20                             |      | ns    |               |
| t <sub>WH</sub>                | SCK High Time               | 250               |      | 125                            |      | 40                             |      | ns    |               |
| t <sub>WL</sub>                | SCK Low Time                | 250               |      | 125                            |      | 40                             |      | ns    |               |
| fscк                           | Clock Frequency             | DC                | 1    | DC                             | 3    | DC                             | 10   | MHz   |               |
| t <sub>LZ</sub>                | HOLD to Output Low Z        |                   | 50   |                                | 50   |                                | 50   | ns    |               |
| t <sub>RI</sub>                | Input Rise Time             |                   | 2    |                                | 2    |                                | 2    | μs    |               |
| t <sub>FI</sub> <sup>(1)</sup> | Input Fall Time             |                   | 2    |                                | 2    |                                | 2    | μs    | $C_L = 50 pF$ |
| t <sub>HD</sub>                | HOLD Setup Time             | 100               |      | 100                            |      | 40                             |      | ns    |               |
| t <sub>CD</sub>                | HOLD Hold Time              | 100               |      | 100                            |      | 40                             |      | ns    |               |
| t <sub>WC</sub>                | Write Cycle Time            |                   | 10   |                                | 10   |                                | 5    | ms    |               |
| t <sub>V</sub>                 | Output Valid from Clock Low |                   | 250  |                                | 250  |                                | 80   | ns    |               |
| t <sub>HO</sub>                | Output Hold Time            | 0                 |      | 0                              |      | 0                              |      | ns    |               |
| t <sub>DIS</sub>               | Output Disable Time         |                   | 250  |                                | 250  |                                | 75   | ns    |               |
| t <sub>HZ</sub>                | HOLD to Output High Z       |                   | 150  |                                | 100  |                                | 50   | ns    |               |
| t <sub>CS</sub>                | CS High Time                | 500               |      | 250                            |      | 200                            |      | ns    |               |
| tcss                           | CS Setup Time               | 500               |      | 250                            |      | 100                            |      | ns    |               |
| tcsн                           | CS Hold Time                | 500               |      | 250                            |      | 100                            |      | ns    |               |

# FUNCTIONAL DESCRIPTION

The BH95640 supports the SPI bus data transmission protocol. The synchronous Serial Peripheral Interface (SPI) helps the BH95640 to interface directly with many of today's popular microcontrollers. The BH95640 contains an 8-bit instruction register. (The instruction set and the operation codes are detailed in the instruction set table)

After the device is selected with  $\overline{CS}$  going low, the first byte will be received. The part is accessed via the SI pin, with data being clocked in on the rising edge of SCK. The first byte contains one of the six op-codes that define the operation to be performed.

# **PIN DESCRIPTION**

### SI: Serial Input

SI is the serial data input pin. This pin is used to input all opcodes, byte addresses, and data to be written to the BH95640. Input data is latched on the rising edge of the serial clock.

### **SO: Serial Output**

SO is the serial data output pin. This pin is used to transfer data out of the BH95640. During a read cycle, data is shifted out on the falling edge of the serial clock.

#### SCK: Serial Clock

SCK is the serial clock pin. This pin is used to synchronize the communication between the microcontroller and the BH95640. Opcodes, byte addresses, or data present on the SI pin are latched on the rising edge of the SCK. Data on the SO pin is updated on the falling edge of the SCK.

## CS: Chip Select

 $\overline{CS}$  is the Chip select pin.  $\overline{CS}$  low enables the BH95640 and  $\overline{CS}$  high disables the BH95640.  $\overline{CS}$  high takes the SO output pin to high impedance and forces the devices into a Standby Mode (unless an internal write operation is underway). The BH95640 draws ZERO current in the Standby mode. A high to low transition on  $\overline{CS}$  is required prior to any sequence being initiated. A low to high transition on  $\overline{CS}$  after a valid write sequence is what initiates an internal write cycle.

## WP: Write Protect

 $\overline{\text{WP}}$  is the Write Protect pin. The Write Protect pin will allow normal read/write operations when held high. When  $\overline{\text{WP}}$  is tied low and the WPEN bit in the status register is set to "1", all write operations to the status register are inhibited.  $\overline{\text{WP}}$  going low while  $\overline{\text{CS}}$  is still low will interrupt a write to the status register. If the internal write cycle has already been initiated,  $\overline{\text{WP}}$  going low will have no effect on any write operation to the status register. The  $\overline{\text{WP}}$  pin function is blocked when the WPEN bit is set to 0.

## HOLD: Hold

The  $\overline{HOLD}$  pin is used to pause transmission to the BH95640 while in the middle of a serial sequence without having to re-transmit entire sequence at a later time. To pause,  $\overline{HOLD}$  must be brought low while SCK is low. The SO pin is in a high impedance state during the time the part is paused, and transitions on the SI pins will be ignored. To resume communication,  $\overline{HOLD}$  is brought high, while SCK is low. ( $\overline{HOLD}$  should be held high any time this function is not being used.)  $\overline{HOLD}$  may be tied high directly to V<sub>cc</sub> or tied to V<sub>cc</sub> through a resistor.

| Instruction | Opcode    | Operation                |
|-------------|-----------|--------------------------|
| WREN        | 0000 0110 | Enable Write Operations  |
| WRDI        | 0000 0100 | Disable Write Operations |
| RDSR        | 0000 0101 | Read Status Register     |
| WRSR        | 0000 0001 | Write Status Register    |
| READ        | 0000 0011 | Read Data from Memory    |
| WRITE       | 0000 0010 | Write Data to Memory     |

## **INSTRUCTION SET**

## **DEVICE OPERATION**

#### Write Enable and Disable

The BH95640 contains a write enable latch. This latch must be set before any write operation. The device powers up in a write disable state when  $V_{cc}$  is applied. WREN instruction will enable writes (set the latch) to the device. WRDI instruction will disable writes (reset the latch) to the device. Disabling writes will protect the device against inadvertent writes.

#### **READ Sequence**

The part is selected by pulling  $\overline{CS}$  low. The 8-bit read instruction is transmitted to the BH95640, followed by the 16-bit address



HIGH IMPEDANCE

Note: Dashed Line= mode (1, 1) -----

SO

#### **WRITE Sequence**

The BH95640 powers up in a Write Disable state. Prior to any write instructions, the WREN instruction must be sent to BH95640. The device goes into Write enable state by pulling the  $\overline{CS}$  low and then clocking the WREN instruction into BH95640. The  $\overline{CS}$  must be brought high after the WREN instruction to enable writes to the device. If the write operation is initiated immediately after the WREN instruction without  $\overline{CS}$  being brought high, the data will not be written to the array because the write enable latch will not have been properly set. Also, for a successful write operation the address of the memory location(s) to be programmed must be outside the protected address field location selected by the block protection level.

#### **Byte Write**

Once the device is in a Write Enable state, the user may proceed with a write sequence by setting the  $\overline{CS}$  low, issuing a write instruction via the SI line, followed by the 16-bit address and then the data to be written. Programming will start after the  $\overline{CS}$  is brought high. Figure 6 illustrates byte write sequence.



\*Please check the instruction set table for address

Note: Dashed Line= mode (1, 1) -----





Note: Dashed Line= mode (1, 1) -----

During an internal write cycle, all commands will be ignored except the RDSR (Read Status Register) instruction.

The Status Register can be read to determine if the write cycle is still in progress. If Bit 0 of the Status Register is set at 1, write cycle is in progress. If Bit 0 is set at 0, the device is ready for the next instruction.

#### Page Write

The BH95640 features page write capability. After the first initial byte the host may continue to write up to 32 bytes of data to the BH95640. After each byte of data is received, six lower order address bits are internally incremented by one; the high order bits of address will remain constant. The only restriction is that the 32 bytes must reside on the same page. If the address counter reaches the end of the page and clock continues, the counter will "roll over" to the first address of the page and overwrite any data that may have been written. The BH95640 is automatically returned to the write disable state at the completion of the write cycle.

To write to the status register, the WRSR instruction should be sent. Only Bit 2, Bit 3 and Bit 7 of the status register can be written using the WRSR instruction. Figure 7 illustrates the sequence of writing to status register.





Note: Dashed Line= mode (1, 1) - - - - -