# imall

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

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

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



# Contact us

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





# 34AA04

# 4K I<sup>2</sup>C<sup>™</sup> Serial EEPROM with Software Write-Protect

### **Device Selection Table**

| Part<br>Number                               | Vcc<br>Range | Max. Clock<br>Frequency | Temp<br>Ranges |  |  |  |  |  |
|----------------------------------------------|--------------|-------------------------|----------------|--|--|--|--|--|
| 34AA04                                       | 1.7-3.6      | 1 MHz <sup>(1)</sup>    | I, E           |  |  |  |  |  |
| <b>Note 1:</b> 400 kHz for 1.8V ≤ Vcc < 2.2V |              |                         |                |  |  |  |  |  |

100 kHz for Vcc < 1.8V

#### Features

- 4 Kbit EEPROM:
  - Internally organized as two 256 x 8-bit banks
  - Byte or page writes (up to 16 bytes)
  - Byte or sequential reads within a single bank
  - Self-timed write cycle (5 ms max.)
- JEDEC<sup>®</sup> JC42.4 (EE1004-v) Serial Presence Detect (SPD) Compliant for DRAM (DDR4) modules
- High-Speed I<sup>2</sup>C<sup>™</sup> Interface:
  - Industry standard 1 MHz, 400 kHz, and 100 kHz
  - Schmitt Trigger inputs for noise suppression
  - SMBus-compatible bus time out
  - Cascadable up to eight devices
- Write Protection:
  - Reversible software write protection for four individual 128-byte blocks
- Low-Power CMOS Technology:
  - Voltage range: 1.7V to 3.6V
  - Write current: 1.5 mA at 3.6V
  - Read current: 200 µA at 3.6V, 400 kHz
  - Standby current: 1 µA at 3.6V
- · High Reliability:
  - More than one million erase/write cycles
  - Data retention: > 200 years
  - ESD protection: > 4000V
- 8-lead PDIP, SOIC, TSSOP, TDFN, and UDFN Packages
- Available Temperature Ranges:
  - Industrial (I): -40°C to +85°C
  - Automotive (E): -40°C to +125°C

#### Description

The Microchip Technology Inc. 34AA04 is a 4 Kbit Electrically Erasable PROM which utilizes the  $I^2C$  serial interface and is capable of operation across a broad voltage range (1.7V to 3.6V). This device is JEDEC JC42.4 (EE1004-v) Serial Presence Detect (SPD) compliant and includes reversible software write protection for each of four independent 128 x 8-bit blocks. The device features a page write capability of up to 16 bytes of data. Address pins allow up to eight devices on the same bus.

The 34AA04 is available in the 8-lead PDIP, SOIC, TSSOP, TDFN, and UDFN packages.

#### Package Types



#### **Block Diagram**



# 1.0 ELECTRICAL CHARACTERISTICS

# Absolute Maximum Ratings<sup>(†)</sup>

| Vcc                                           | 6.5V           |
|-----------------------------------------------|----------------|
| All Inputs and Outputs (except A0) w.r.t. Vss | -0.3V to 6.5V  |
| A0 Input w.r.t. Vss                           | 0.3 to 12V     |
| Storage Temperature                           | 65°C to +150°C |
| Ambient Temperature with Power Applied        | 40°C to +125°C |
| ESD Protection on All Pins                    | ≥4 kV          |

**† NOTICE:** 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 above those indicated in the operation sections of the specifications is not implied. Exposure to Absolute Maximum Rating conditions for extended periods may affect device reliability.

# TABLE 1-1: DC SPECIFICATIONS

| DC CHARACTERISTICS |           | Vcc = +1.7V to +3.6V<br>Industrial (I): TA = -40°C to +85°C<br>Automotive (E): TA = -40°C to +125°C |           |                    |          |                                                                      |  |
|--------------------|-----------|-----------------------------------------------------------------------------------------------------|-----------|--------------------|----------|----------------------------------------------------------------------|--|
| Param.<br>No.      | Symbol    | Characteristic                                                                                      | Min.      | Max.               | Units    | Conditions                                                           |  |
|                    | —         | A0, A1, A2, SCL, and SDA                                                                            | —         | _                  | _        |                                                                      |  |
| D1                 | VIH       | High-Level Input Voltage                                                                            | 0.7 Vcc   | Vcc + 0.5          | V        |                                                                      |  |
| D2                 | VIL       | Low-Level Input Voltage                                                                             | —         | 0.3 Vcc<br>0.2 Vcc | V<br>V   | Vcc ≥ 2.5V<br>Vcc < 2.5V                                             |  |
| D3                 | VHYS      | Hysteresis of Schmitt<br>Trigger Inputs                                                             | 0.0 Vcc   | —                  | V        | (Note)                                                               |  |
| D4                 | Vol       | Low-Level Output Voltage                                                                            | —         | 0.40<br>0.40       | V<br>V   | IOL = 20.0 mA, VCC = 2.2V<br>IOL = 6.0 mA, VCC = 1.7V                |  |
| DE                 | VHV       | High-Voltage Detect                                                                                 | 7         | 10                 | V        | Vcc < 2.2V                                                           |  |
| D5                 | VHV       | (A0 pin only)                                                                                       | Vcc + 4.8 | 10                 | V        | Vcc ≥ 2.2V                                                           |  |
| D6                 | lu -      | Input Leakage Current                                                                               | _         | ±1                 | μA       | VIN = VSS or VCC                                                     |  |
| D7                 | Ilo       | Output Leakage Current                                                                              | —         | ±1                 | μA       | Vout = Vss or Vcc                                                    |  |
| D8                 | CIN, COUT | Pin Capacitance<br>(all inputs/outputs)                                                             | —         | 10                 | pF       | Vcc = 5.5V <b>(Note)</b><br>TA = 25°C, Fclk = 1 MHz                  |  |
| D9                 | Icc write | Operating Current                                                                                   | _         | 1.5                | mA       | Vcc = 3.6V                                                           |  |
| D10                | Icc read  |                                                                                                     | —         | 200                | μA       | Vcc = 3.6V, SCL = 400 kHz                                            |  |
| D11                | Iccs      | Standby Current                                                                                     | _         | 1<br>5             | μΑ<br>μΑ | Industrial<br>Automotive<br>SDA, SCL, Vcc = 3.6V<br>A0, A1, A2 = Vss |  |

**Note:** This parameter is periodically sampled and not 100% tested.

| AC CHARACTERISTICS |          |                                                                                    | Vcc = +1.7V to +3.6V<br>Industrial (I): TA = -40°C to +85°C<br>Automotive (E): TA = -40°C to +125°C |                    |        |                                                                                                           |  |  |
|--------------------|----------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------------------|--------|-----------------------------------------------------------------------------------------------------------|--|--|
| Param.<br>No.      | Symbol   | Characteristic                                                                     | Min.                                                                                                | Max.               | Units  | Conditions                                                                                                |  |  |
| 1                  | FCLK     | Clock Frequency (Note 2)                                                           | 10<br>10<br>10                                                                                      | 100<br>400<br>1000 | kHz    | $\begin{array}{l} 1.7V \leq Vcc < 1.8V \\ 1.8V \leq Vcc \leq 2.2V \\ 2.2V \leq Vcc \leq 3.6V \end{array}$ |  |  |
| 2                  | Тнідн    | Clock High Time                                                                    | 4000<br>600<br>260                                                                                  |                    | ns     | $\begin{array}{l} 1.7V \leq Vcc < 1.8V \\ 1.8V \leq Vcc \leq 2.2V \\ 2.2V \leq Vcc \leq 3.6V \end{array}$ |  |  |
| 3                  | TLOW     | Clock Low Time                                                                     | 4700<br>1300<br>500                                                                                 |                    | ns     | $\begin{array}{l} 1.7V \leq Vcc < 1.8V \\ 1.8V \leq Vcc \leq 2.2V \\ 2.2V \leq Vcc \leq 3.6V \end{array}$ |  |  |
| 4                  | TR       | SDA and SCL Rise Time (Note 1)                                                     |                                                                                                     | 1000<br>300<br>120 | ns     | $1.7V \le Vcc < 1.8V$<br>$1.8V \le Vcc \le 2.2V$<br>$2.2V \le Vcc \le 3.6V$                               |  |  |
| 5                  | TF       | SDA and SCL Fall Time (Note 1)                                                     |                                                                                                     | 300<br>300<br>120  | ns     | $\begin{array}{l} 1.7V \leq Vcc < 1.8V \\ 1.8V \leq Vcc \leq 2.2V \\ 2.2V \leq Vcc \leq 3.6V \end{array}$ |  |  |
| 6                  | THD:STA  | Start Condition Hold Time                                                          | 4000<br>600<br>260                                                                                  |                    | ns     | $\begin{array}{l} 1.7V \leq Vcc < 1.8V \\ 1.8V \leq Vcc \leq 2.2V \\ 2.2V \leq Vcc \leq 3.6V \end{array}$ |  |  |
| 7                  | TSU:STA  | Start Condition Setup Time                                                         | 4700<br>600<br>260                                                                                  |                    | ns     | $1.7V \le Vcc < 1.8V$<br>$1.8V \le Vcc \le 2.2V$<br>$2.2V \le Vcc \le 3.6V$                               |  |  |
| 8                  | THD:DAT  | Data Input Hold Time                                                               | 0                                                                                                   | —                  | ns     | (Note 3)                                                                                                  |  |  |
| 9                  | TSU:DAT  | Data Input Setup Time                                                              | 250<br>100<br>50                                                                                    |                    | ns     | $1.7V \le Vcc < 1.8V$<br>$1.8V \le Vcc \le 2.2V$<br>$2.2V \le Vcc \le 3.6V$                               |  |  |
| 10                 | Tsu:sto  | Stop Condition Setup Time                                                          | 4000<br>600<br>260                                                                                  |                    | ns     | $1.7V \le Vcc < 1.8V$<br>$1.8V \le Vcc \le 2.2V$<br>$2.2V \le Vcc \le 3.6V$                               |  |  |
| 11                 | ΤΑΑ      | Output Valid from Clock (Note 3)                                                   | 200<br>200<br>—                                                                                     | 3450<br>900<br>350 | ns     | $1.7V \le Vcc < 1.8V$<br>$1.8V \le Vcc \le 2.2V$<br>$2.2V \le Vcc \le 3.6V$                               |  |  |
| 12                 | TBUF     | Bus Free Time: Time the bus must<br>be free before a new transmission<br>can start | 4700<br>1300<br>500                                                                                 |                    | ns     | $1.7V \le Vcc < 1.8V$<br>$1.8V \le Vcc \le 2.2V$<br>$2.2V \le Vcc \le 3.6V$                               |  |  |
| 13                 | TSP      | Input Filter Spike Suppression (SDA and SCL pins)                                  | —                                                                                                   | 50                 | ns     | (Note 1)                                                                                                  |  |  |
| 14                 | Twc      | Write Cycle Time (byte or page)                                                    | _                                                                                                   | 5                  | ms     | —                                                                                                         |  |  |
| 15                 | TTIMEOUT | Bus Timeout Time                                                                   | 25                                                                                                  | 35                 | ms     | —                                                                                                         |  |  |
| 16                 | —        | Endurance                                                                          | 1M                                                                                                  |                    | cycles | Page mode, 25°C, Vcc = 3.6V<br>(Note 4)                                                                   |  |  |

# TABLE 1-2: AC SPECIFICATIONS

Note 1: Not 100% tested.

2: The minimum clock frequency of 10 kHz is to prevent the bus timeout from occurring.

**3:** As a transmitter, the device must provide an internal minimum delay time to bridge the undefined region (minimum 200 ns) of the falling edge of SCL to avoid unintended generation of Start or Stop conditions.

**4:** This parameter is not tested but ensured by characterization. For endurance estimates in a specific application, please consult the Total Endurance<sup>™</sup> Model which can be obtained from Microchip's web site at www.microchip.com.

# 34AA04

# FIGURE 1-1: BUS TIMING DATA



# 2.0 PIN DESCRIPTIONS

The descriptions of the pins are listed in Table 2-1.

| Symbol | PDIP | SOIC | TSSOP | UDFN | TDFN | Description                            |  |  |
|--------|------|------|-------|------|------|----------------------------------------|--|--|
| A0/VHV | 1    | 1    | 1     | 1    | 1    | Chip Address Input, High-Voltage Input |  |  |
| A1     | 2    | 2    | 2     | 2    | 2    | Chip Address Input                     |  |  |
| A2     | 3    | 3    | 3     | 3    | 3    | Chip Address Input                     |  |  |
| Vss    | 4    | 4    | 4     | 4    | 4    | Ground                                 |  |  |
| SDA    | 5    | 5    | 5     | 5    | 5    | Serial Address/Data I/O                |  |  |
| SCL    | 6    | 6    | 6     | 6    | 6    | Serial Clock                           |  |  |
| NC     | 7    | 7    | 7     | 7    | 7    | Not Connected                          |  |  |
| Vcc    | 8    | 8    | 8     | 8    | 8    | +1.7V to 3.6V Power Supply             |  |  |

#### TABLE 2-1: PIN FUNCTION TABLE

Note: Exposed pad on TDFN/UDFN can be connected to Vss or left floating.

### 2.1 A0, A1, A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.

Up to eight 34AA04 devices may be connected to the same bus by using different Chip Select bit combinations. These inputs must be connected to either Vss or Vcc.

The A0 pin also serves as the high-voltage input for enabling the SWPn and CWP instructions.

| Note: | The comparison between the A0, A1, and      |  |  |  |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|--|--|--|
|       | A2 pins and the corresponding Chip          |  |  |  |  |  |  |  |  |  |
|       | Select bits is disabled for software Write- |  |  |  |  |  |  |  |  |  |
|       | Protect and Bank Select commands.           |  |  |  |  |  |  |  |  |  |

# 2.2 Serial Address/Data Input/Output (SDA)

This is a bidirectional pin used to transfer addresses and data into and data out of the device. It is an open drain terminal. Therefore, the SDA bus requires a pull-up resistor to Vcc (typical 10 k $\Omega$  for 100 kHz, 2 k $\Omega$  for 400 kHz and 1 MHz).

For normal data transfer, SDA is allowed to change only during SCL low. Changes during SCL high are reserved for indicating the Start and Stop conditions.

# 2.3 Serial Clock (SCL)

This input is used to synchronize the data transfer to and from the device.

# 3.0 FUNCTIONAL DESCRIPTION

The 34AA04 supports a bidirectional 2-wire bus and data transmission protocol. A device that sends data onto the bus is defined as a transmitter, and a device receiving data, as a receiver. The bus has to be controlled by a master device, which generates the Serial Clock (SCL), controls the bus access and generates the Start and Stop conditions, while the 34AA04 works as slave. Both master and slave can operate as transmitter or receiver, but the master device determines which mode is activated.

The 4 Kbit array of the 34AA04 is divided into two separate banks of 2 Kbits each. The 34AA04 also offers reversible software write protection for each of four 1 Kbit blocks.

# 4.0 BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is high. Changes in the data line while the clock line is high will be interpreted as a Start or Stop condition.

Accordingly, the following bus conditions have been defined (Figure 4-1).

# 4.1 Bus Not Busy (A)

Both data and clock lines remain high.

# 4.2 Start Data Transfer (B)

A high-to-low transition of the SDA line while the clock (SCL) is high determines a Start condition. All commands must be preceded by a Start condition.

# 4.3 Stop Data Transfer (C)

A low-to-high transition of the SDA line while the clock (SCL) is high determines a Stop condition. All operations must be ended with a Stop condition.

# 4.4 Data Valid (D)

The state of the data line represents valid data when, after a Start condition, the data line is stable for the duration of the high period of the clock signal.

The data on the line must be changed during the low period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a Start condition and terminated with a Stop condition. The number of data bytes transferred between the Start and Stop conditions is determined by the master device and is, theoretically, unlimited; although only the last sixteen will be stored when doing a write operation. When an overwrite does occur, it will replace data in a first-in, first-out (FIFO) fashion.

# 4.5 Acknowledge

Each receiving device, when addressed, is obliged to generate an Acknowledge after the reception of each byte. Exceptions to this rule relating to software write protection are described in Section 9.0 "Software Write Protection". The master device must generate an extra clock pulse, which is associated with this Acknowledge bit.

| Note: | The 34AA04  | does     | not   | gene  | rate any |
|-------|-------------|----------|-------|-------|----------|
|       | Acknowledge | bits     | if    | an    | internal |
|       | programming | cycle is | in pr | ogres | S.       |

The device that acknowledges has to pull down the SDA line during the Acknowledge clock pulse in such a way that the SDA line is stable low during the high period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. During reads, a master must signal an end-of-data to the slave by not generating an Acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave (34AA04) will leave the data line high to enable the master to generate the Stop condition.

# 4.6 Bus Timeout

If SCL remains low for the time specified by TTIMEOUT, the 34AA04 will reset the serial interface and ignore all further communication until another Start condition is detected (Figure 4-2). This dictates the minimum clock speed as defined by FCLK.







# 4.7 Device Addressing

A control byte is the first byte received following the Start condition from the master device. The first part of the control byte consists of a 4-bit control code which is set to '1010' for normal read and write operations and '0110' for accessing the software write-protect features and bank selection. The control byte is followed by three Chip Select bits (A2, A1, A0). The Chip Select bits allow the use of up to eight 34AA04 devices on the same bus and are used to determine which device is accessed. The Chip Select bits in the control byte must correspond to the logic levels on the corresponding A2, A1 and A0 pins for the device to respond.

The eighth bit of slave address determines if the master device wants to read or write to the 34AA04 (Figure 4-3). When set to a one, a read operation is selected. When set to a zero, a write operation is selected.

| Operation                           | Control<br>Code | Chip<br>Select | R/W |
|-------------------------------------|-----------------|----------------|-----|
| Read                                | 1010            | A2 A1 A0       | 1   |
| Write                               | 1010            | A2 A1 A0       | 0   |
| Read Write-Protect/<br>Bank Address | 0110            | A2 A1 A0       | 1   |
| Set Write-Protect/<br>Bank Address  | 0110            | A2 A1 A0       | 0   |

FIGURE 4-3: CO

CONTROL BYTE ALLOCATION



# 5.0 BANK ADDRESSING

To support backwards-compatibility with DDR2/3 (JEDEC EE1002) SPD EEPROMs, the memory array of the 34AA04 is divided into two separate 256-byte banks. The Set Bank Address (SBA) commands are used to set the bank address to either 0 or 1. The Read Bank Address (RBA) command is used to determine which bank is currently selected.

- Note 1: The bank address is volatile and is reset to Bank 0 upon power-up.
  - 2: The comparison between the A0, A1, and A2 pins and the corresponding Chip Select bits is disabled for Bank Select commands.

Note: Sequential read operations cannot cross a bank boundary and will roll over back to the beginning of the selected bank.

TABLE 5-1:BANK ADDRESS RANGE

| Bank   | Logical Array Address |
|--------|-----------------------|
| Bank 0 | 000h-0FFh             |
| Bank 1 | 100h-1FFh             |

| TABLE 5-2: | BANK ADDRESSING INSTRUCTION SET |
|------------|---------------------------------|
|------------|---------------------------------|

|                       |      | Control Byte |       |       |                  |       |       |       |        |                      |
|-----------------------|------|--------------|-------|-------|------------------|-------|-------|-------|--------|----------------------|
| Function              | Abbr | Control Code |       |       | Chip Select Bits |       |       | R/W   | A0 Pin |                      |
|                       |      | Bit 7        | Bit 6 | Bit 5 | Bit 4            | Bit 3 | Bit 2 | Bit 1 | Bit 0  |                      |
| Set Bank Address to 0 | SBA0 |              |       |       |                  | 1     | 1     | 0     | 0      | 0, 1, <b>or V</b> HV |
| Set Bank Address to 1 | SBA1 | 0            | 1     | 1     | 0                | 1     | 1     | 1     | 0      | 0, 1, <b>or V</b> HV |
| Read Bank Address     | RBA  |              |       |       |                  | 1     | 1     | 0     | 1      | 0, 1, <b>or V</b> HV |

#### 5.1 Set Bank Address (SBA)

The Set Bank Address (SBA) commands are used to select the array bank for future read and write operations.

The master generates a Start condition followed by the corresponding control byte for the chosen SBA command (Table 5-2), with the R/W bit set to a logic '0'. Note that Chip Select bit A0 of the control byte effectively determines which bank is selected. The

34AA04 will respond with an Acknowledge, and then the master transmits two dummy bytes. The 34AA04 will not acknowledge either dummy byte. Finally, the master generates a Stop condition to end the operation (Figure 5-1).

Array Read and Write commands will operate in the newly-selected bank until another SBA command is executed, or the 34AA04 experiences a POR or BOR event.

#### FIGURE 5-1: SET BANK ADDRESS



## 5.2 Read Bank Address (RBA)

The Read Bank Address (RBA) command allows the 34AA04 to indicate which array bank is currently selected.

The master generates a Start condition and transmits the RBA control byte (Table 5-2), with the R/W bit set to logic '1'. If Bank 0 is currently selected, the 34AA04 will respond with an Acknowledge signal. If Bank 1 is currently selected, an Acknowledge will not be generated. Regardless of the result, the master must read at least one dummy byte from the 34AA04, transmitting a Not Acknowledge signal after each byte, and generate a Stop condition to end the command (Figure 5-2).





# 6.0 WRITE OPERATIONS

# 6.1 Byte Write

Following the Start signal from the master, the control code (4 bits), the Chip Select bits (3 bits) and the R/W bit, which is a logic low, are placed onto the bus by the master transmitter. This indicates to the addressed slave receiver that the array address byte will follow, once it has generated an Acknowledge bit during the ninth clock cycle. Therefore, the next byte transmitted by the master is the array address and will be written into the Address Pointer of the 34AA04.

After receiving another Acknowledge signal from the 34AA04, the master device will transmit the data byte to be written into the addressed memory location. The 34AA04 acknowledges again and the master generates a Stop condition. This initiates the internal write cycle, which means that during this time, the 34AA04 will not generate Acknowledge signals (Figure 6-1).

Note: It is recommended to perform a Set Bank Address command before initiating a Write command to ensure the desired bank is selected.

If an attempt is made to write to a software write-protected portion of the array, the 34AA04 will not acknowledge the data byte, no data will be written, and the device will immediately accept a new command.

#### 6.2 Page Write

The write control byte, array address and the first data byte are transmitted to the 34AA04 in the same way as in a byte write. Instead of generating a Stop condition, the master transmits up to 15 additional data bytes to the 34AA04, which are temporarily stored in the onchip page buffer and will be written into the memory after the master has transmitted a Stop condition. Upon receipt of each word, the four lower order Address Pointer bits are internally incremented by one. The higher order four bits of the array address, as well as the bank selection, remain constant. If the master should transmit more than 16 bytes prior to generating the Stop condition, the address counter will roll over and the previously received data will be overwritten. As with the byte write operation, once the Stop condition is received, an internal write cycle will begin (Figure 6-2). If an attempt is made to write to a software write-protected portion of the array, the 34AA04 will not acknowledge the data byte, no data will be written, and the device will immediately accept a new command.

- **Note:** When doing a write of less than 16 bytes, the data in the rest of the page is refreshed along with the data bytes being written. This will force the entire page to endure a write cycle. For this reason, endurance is specified per page.
- Note: Page write operations are limited to writing bytes within a single physical page, regardless of the number of bytes actually being written. Physical page boundaries start at addresses that are integer multiples of the page buffer size (or 'page size') and end at addresses that are integer multiples of [page size - 1]. If a Page Write command attempts to write across a physical page boundary, the result is that the data wraps around to the beginning of the current page (overwriting data previously stored there), instead of being written to the next page, as might be expected. It is, therefore, necessary for the application software to prevent page write operations that would attempt to cross a page boundary.

**BYTE WRITE** 

| Status              | Command                                  | ACK | Address | ACK | Data Byte | ACK   | Write Cycle |
|---------------------|------------------------------------------|-----|---------|-----|-----------|-------|-------------|
| Protected with SWPn | Page or Byte Write in<br>Protected Block | ACK | Address | ACK | Data      | NoACK | No          |
| Not Protected       | Page or Byte Write                       | ACK | Address | ACK | Data      | ACK   | Yes         |

#### FIGURE 6-1:





# 7.0 ACKNOWLEDGE POLLING

Since the device will not acknowledge during a write cycle, this can be used to determine when the cycle is complete (this feature can be used to maximize bus throughput). Once the Stop condition for a Write command has been issued from the master, the device initiates the internally timed write cycle. ACK polling can be initiated immediately. This involves the master sending a Start condition followed by the control byte for a Write command (R/W = 0). If the device is still busy with the write cycle, then no ACK will be returned. If the cycle is complete, then the device will return the ACK and the master can then proceed with the next Read or Write command. See Figure 7-1 for flow diagram.



# 8.0 READ OPERATION

Read operations are initiated in the same way as write operations, with the exception that the R/W bit of the slave address is set to '1'. There are three basic types of read operations: current address read, random read and sequential read.

# 8.1 Current Address Read

The 34AA04 contains an address counter that maintains the address of the last byte accessed, internally incremented by '1'. Therefore, if the previous access (either a read or write operation) was to address n, the next current address read operation would access data from address n+1. Upon receipt of the slave address with R/W bit set to '1', the 34AA04 issues an acknowledge and transmits the 8-bit data value. The master will not acknowledge the transfer, but does generate a Stop condition and the 34AA04 discontinues transmission (Figure 8-1).

### 8.2 Random Read

Random read operations allow the master to access any memory location in a random manner. To perform this type of read operation, the array address must first be set. This is done by sending the array address to the 34AA04 as part of a write operation. Once the array address is sent, the master generates a Start condition following the acknowledge. This terminates the write operation, but not before the internal Address Pointer is set. The master then issues the control byte again, but with the R/W bit set to a '1'. The 34AA04 then issues an acknowledge and transmits the 8-bit data word. The

FIGURE 8-1: CURRENT ADDRESS READ

master will not acknowledge the transfer, but does generate a Stop condition and the 34AA04 discontinues transmission (Figure 8-2).

| Note: | It is recommended to perform a Set Bank |
|-------|-----------------------------------------|
|       | Address command before initiating a     |
|       | Read command to ensure the desired      |
|       | bank is selected.                       |

# 8.3 Sequential Read

Sequential reads are initiated in the same way as a random read, with the exception that after the 34AA04 transmits the first data byte, the master issues an acknowledge, as opposed to a Stop condition in a random read. This directs the 34AA04 to transmit the next sequentially addressed 8-bit word (Figure 8-3).

To provide sequential reads, the 34AA04 contains an internal Address Pointer, which is incremented by one at the completion of each operation. Sequential reads are limited to a single bank per operation, so the Address Pointer allows the entire memory contents of the current bank to be serially read during one operation.

# 8.4 Noise Protection and Brown-Out

The 34AA04 employs a Vcc threshold detector circuit which disables the internal erase/write logic if the Vcc is below 1.35V at nominal conditions.

The SCL and SDA inputs have Schmitt Trigger and filter circuits which suppress noise spikes to assure proper device operation, even on a noisy bus.



# 34AA04



# FIGURE 8-3: SEQUENTIAL READ



# 9.0 SOFTWARE WRITE PROTECTION

The 34AA04 has a reversible software write-protect feature that allows each of four 128-byte blocks to be individually write-protected. The write protection is set by executing the Set Write Protect (SWPn) commands. The Clear All Write Protect (CWP) command is used to unprotect all of the blocks at once. It is not possible to unprotect blocks individually. The Read Protection Status (RPS) commands are used to determine if a given block is currently write-protected.

The 34AA04 will not respond with an Acknowledge following the data bytes of write operations that are attempted within a write-protected block.

**Note:** The write-protect state of each block is stored in nonvolatile bits.

# TABLE 9-1: BLOCK ADDRESS RANGE

| Block   | Logical Array Address |
|---------|-----------------------|
| Block 0 | 000h - 07Fh           |
| Block 1 | 080h - 0FFh           |
| Block 2 | 100h - 17Fh           |
| Block 3 | 180h - 1FFh           |

| Note: | The comparison between the A0, A1, and      |  |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|--|
|       | A2 pins and the corresponding Chip          |  |  |  |  |  |  |  |
|       | Select bits is disabled for software Write- |  |  |  |  |  |  |  |
|       | Protect commands.                           |  |  |  |  |  |  |  |

# TABLE 9-2: SOFTWARE WRITE PROTECTION INSTRUCTION SET

|                                 |      | Control Byte |        |        |       |       |        |       |       |                      |
|---------------------------------|------|--------------|--------|--------|-------|-------|--------|-------|-------|----------------------|
| Function                        | Abbr |              | Contro | l Code |       | Chip  | Select | Bits  | R/W   | A0 Pin               |
|                                 |      | Bit 7        | Bit 6  | Bit 5  | Bit 4 | Bit 3 | Bit 2  | Bit 1 | Bit 0 |                      |
| Set Write Protection, block 0   | SWP0 |              |        |        |       | 0     | 0      | 1     | 0     | VHV                  |
| Set Write Protection, block 1   | SWP1 |              |        |        |       | 1     | 0      | 0     | 0     | Vнv                  |
| Set Write Protection, block 2   | SWP2 |              |        |        |       | 1     | 0      | 1     | 0     | Vнv                  |
| Set Write Protection, block 3   | SWP3 |              |        |        |       | 0     | 0      | 0     | 0     | Vнv                  |
| Clear All Write Protection      | CWP  | 0            | 1      | 1      | 0     | 0     | 1      | 1     | 0     | Vнv                  |
| Read Protection Status, block 0 | RPS0 |              |        |        |       | 0     | 0      | 1     | 1     | 0, 1, <b>or V</b> HV |
| Read Protection Status, block 1 | RPS1 |              |        |        |       | 1     | 0      | 0     | 1     | 0, 1, <b>or V</b> HV |
| Read Protection Status, block 2 | RPS2 |              |        |        |       | 1     | 0      | 1     | 1     | 0, 1, <b>or V</b> HV |
| Read Protection Status, block 3 | RPS3 |              |        |        |       | 0     | 0      | 0     | 1     | 0, 1, <b>or V</b> HV |

# 9.1 Set Write Protection (SWPn)

The Set Write Protection (SWP) commands are used to set the reversible write protection for individual array blocks. There are four different SWP commands, one for each block.

VHV must be applied to the A0 pin for the entire SWP command. Then, the command is executed in a manner similar to an array byte Write command. Following the Start condition, the '0110' control code and the three Chip Select bits that correspond to the desired SWP command (Table 9-2) are transmitted by the master, along with the R/W bit as a logic '0'. After the 34AA04 responds with an Acknowledge, the master transmits two dummy bytes, after each of which the 34AA04 responds with an Acknowledge. Finally, the master generates a Stop condition, which initiates the internal write cycle and, during this time, the 34AA04 will not generate Acknowledge signals (Figure 9-1).

If the specified block is already write-protected, the SWP command is ignored, no Acknowledges will be sent, and the internal write cycle will not be executed.

### FIGURE 9-1: SET WRITE PROTECTION



TABLE 9-3: DEVICE RESPONSE WHEN DEFINING WRITE PROTECTION

| Status               | Command     | ACK   | Address    | ACK   | Data Byte  | ACK   | Write Cycle |
|----------------------|-------------|-------|------------|-------|------------|-------|-------------|
| Drotootod with SM/Dn | SWPn        | NoACK | Don't Care | NoACK | Don't Care | NoACK | No          |
| Protected with SWPn  | CWP         | ACK   | Don't Care | ACK   | Don't Care | ACK   | Yes         |
| Not Protected        | SWPn or CWP | ACK   | Don't Care | ACK   | Don't Care | ACK   | Yes         |

# 9.2 Clear All Write Protection (CWP)

The Clear All Write Protection (CWP) command resets all of the write protection in a single operation. It is executed in the same manner as a SWP command, except using the CWP control byte (Table 9-2).

The 34AA04 will always acknowledge and execute a CWP command if an internal write cycle is not in progress, regardless of the state of write protection.

# 9.3 Read Protection Status (RPS)

The Read Protection Status (RPS) commands provide a way of determining whether or not the specified block is currently write-protected. Following the Start condition, the master transmits the control byte for the desired RPS command (Table 9-2), with the R/W bit set to logic '1'. If the specified block is not write-protected, the 34AA04 will respond with an Acknowledge signal. If the block is currently write-protected, an Acknowledge will not be generated. Regardless of the result, the master must read at least one dummy byte from the 34AA04, transmitting a Not Acknowledge signal after each byte, and generate a Stop condition to end the command (Figure 9-3).



# FIGURE 9-2: CLEAR ALL WRITE PROTECTION

#### FIGURE 9-3: READ PROTECTION STATUS



#### TABLE 9-4: DEVICE RESPONSE WHEN READING WRITE PROTECTION STATUS

| Status              | Command | ACK   | Data Byte  | ACK   |
|---------------------|---------|-------|------------|-------|
| Protected with SWPn | RPSn    | NoACK | Don't Care | NoACK |
| Not Protected       | RPSn    | ACK   | Don't Care | NoACK |

# **10.0 PACKAGING INFORMATION**

# 10.1 Package Marking Information



8-Lead SOIC (3.90 mm)



# 8-Lead TSSOP

| XXX<br>YWW |  |
|------------|--|
|            |  |

# 8-Lead 2x3 TDFN



# 8-Lead 2x3 UDFN





### Example:



Example:



Example:



| 1st Line Marking Codes |        |        |       |      |      |  |  |
|------------------------|--------|--------|-------|------|------|--|--|
| Part Number            | PDIP   | SOIC   | TSSOP | TDFN | UDFN |  |  |
| 34AA04                 | 34AA04 | 34AA04 | AACK  | ACB  | CAC  |  |  |

DS20005271B-page 18

| Legend | I: XXX       Part number or part number code         Y       Year code (last digit of calendar year)         YY       Year code (last 2 digits of calendar year)         WW       Week code (week of January 1 is week '01')         NNN       Alphanumeric traceability code (2 characters for small packages)         (e3)       JEDEC <sup>®</sup> designator for Matte Tin (Sn) |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note:  | For very small packages with no room for the JEDEC designator<br>(e3), the marking will only appear on the outer carton or reel label.                                                                                                                                                                                                                                              |
| Note:  | In the event the full Microchip part number cannot be marked on one line, it will<br>be carried over to the next line, thus limiting the number of available<br>characters for customer-specific information.                                                                                                                                                                       |

\*Standard OTP marking consists of Microchip part number, year code, week code, and traceability code.

# 8-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging









END VIEW

Microchip Technology Drawing No. C04-018D Sheet 1 of 2

# 8-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging





|                            |    | INCHES |          |      |
|----------------------------|----|--------|----------|------|
| Dimension Limits           |    | MIN    | NOM      | MAX  |
| Number of Pins             | N  |        | 8        |      |
| Pitch                      | е  |        | .100 BSC |      |
| Top to Seating Plane       | Α  | -      | -        | .210 |
| Molded Package Thickness   | A2 | .115   | .130     | .195 |
| Base to Seating Plane      | A1 | .015   | -        | -    |
| Shoulder to Shoulder Width | E  | .290   | .310     | .325 |
| Molded Package Width       | E1 | .240   | .250     | .280 |
| Overall Length             | D  | .348   | .365     | .400 |
| Tip to Seating Plane       | L  | .115   | .130     | .150 |
| Lead Thickness             | С  | .008   | .010     | .015 |
| Upper Lead Width           | b1 | .040   | .060     | .070 |
| Lower Lead Width           | b  | .014   | .018     | .022 |
| Overall Row Spacing §      | eВ | -      | -        | .430 |

Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. § Significant Characteristic
- 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side.
- 4. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-018D Sheet 2 of 2

# 8-Lead Plastic Small Outline (SN) - Narrow, 3.90 mm Body [SOIC]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



Microchip Technology Drawing No. C04-057C Sheet 1 of 2

#### 8-Lead Plastic Small Outline (SN) - Narrow, 3.90 mm Body [SOIC]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                          | MILLIMETERS |          |          |      |  |
|--------------------------|-------------|----------|----------|------|--|
| Dimension Limi           |             | MIN      | NOM      | MAX  |  |
| Number of Pins           | Ν           |          | 8        |      |  |
| Pitch                    | е           |          | 1.27 BSC |      |  |
| Overall Height           | Α           | -        | -        | 1.75 |  |
| Molded Package Thickness | A2          | 1.25     | -        | -    |  |
| Standoff §               | A1          | 0.10     | -        | 0.25 |  |
| Overall Width            | E           | 6.00 BSC |          |      |  |
| Molded Package Width     | E1          | 3.90 BSC |          |      |  |
| Overall Length           | D           |          | 4.90 BSC |      |  |
| Chamfer (Optional)       | h           | 0.25     | -        | 0.50 |  |
| Foot Length              | L           | 0.40     | -        | 1.27 |  |
| Footprint                | L1          | 1.04 REF |          |      |  |
| Foot Angle               | φ           | 0°       | -        | 8°   |  |
| Lead Thickness           | С           | 0.17     | -        | 0.25 |  |
| Lead Width               | b           | 0.31     | -        | 0.51 |  |
| Mold Draft Angle Top     | α           | 5°       | -        | 15°  |  |
| Mold Draft Angle Bottom  | β           | 5°       | -        | 15°  |  |

#### Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. § Significant Characteristic

3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15mm per side.

4. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing No. C04-057C Sheet 2 of 2

# 8-Lead Plastic Small Outline (SN) – Narrow, 3.90 mm Body [SOIC]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



RECOMMENDED LAND PATTERN

|                         | Units MILLIMETERS |          | S    |      |
|-------------------------|-------------------|----------|------|------|
| Dimension               | Dimension Limits  |          | NOM  | MAX  |
| Contact Pitch           | E                 | 1.27 BSC |      |      |
| Contact Pad Spacing     | С                 |          | 5.40 |      |
| Contact Pad Width (X8)  | X1                |          |      | 0.60 |
| Contact Pad Length (X8) | Y1                |          |      | 1.55 |

#### Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2057A



For the most current package drawings, please see the Microchip Packaging Specification located at

#### 8-Lead Plastic Thin Shrink Small Outline (ST) – 4.4 mm Body [TSSOP]

http://www.microchip.com/packaging

|                          | Units | MILLIMETERS |      |      |  |
|--------------------------|-------|-------------|------|------|--|
| Dimension Limits         |       | MIN         | NOM  | MAX  |  |
| Number of Pins           | N     | 8           |      |      |  |
| Pitch                    | е     | 0.65 BSC    |      |      |  |
| Overall Height           | А     | _           | -    | 1.20 |  |
| Molded Package Thickness | A2    | 0.80        | 1.00 | 1.05 |  |
| Standoff                 | A1    | 0.05        | -    | 0.15 |  |
| Overall Width            | E     | 6.40 BSC    |      |      |  |
| Molded Package Width     | E1    | 4.30        | 4.40 | 4.50 |  |
| Molded Package Length    | D     | 2.90        | 3.00 | 3.10 |  |
| Foot Length              | L     | 0.45        | 0.60 | 0.75 |  |
| Footprint                | L1    | 1.00 REF    |      |      |  |
| Foot Angle               | ф     | 0°          | -    | 8°   |  |
| Lead Thickness           | С     | 0.09        | -    | 0.20 |  |
| Lead Width               | b     | 0.19        | -    | 0.30 |  |

#### Notes:

Note:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15 mm per side.

- 3. Dimensioning and tolerancing per ASME Y14.5M.
  - BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-086B