

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









## 16K-128K I<sup>2</sup>C Serial EEPROM with Software Write Protection Family Data Sheet

#### **Device Selection Table**

| Part Number | Density  | Page Size | Vcc Range | Package                   | Temp. Ranges |
|-------------|----------|-----------|-----------|---------------------------|--------------|
| 24CW16X     | 16-Kbit  | 32-byte   | 1.6-5.5   | SN, OT, ST, MUY           | I            |
| 24CW32X     | 32-Kbit  | 32-byte   | 1.6-5.5   | SN, OT, ST, MUY           | I            |
| 24CW64X     | 64-Kbit  | 32-byte   | 1.6-5.5   | SN, OT, ST, MUY, CS0, CS1 | 1            |
| 24CW128X    | 128-Kbit | 32-byte   | 1.6-5.5   | SN, OT, ST, MUY, CS0, CS1 | I            |

Note: 'X' in the part number refers to the preset hardware slave address. Refer to Table 3-2 for additional information.

#### **Features**

- 16/32/64/128-Kbit EEPROM:
  - Internally organized as one 2048/4096/8192/16384 x 8 bit block
  - Byte or page writes up to 32 bytes
  - Byte or sequential reads within a block
  - Self-timed write cycle (5 ms maximum)
- High-Speed I<sup>2</sup>C Interface:
  - Industry standard: 1 MHz, 400 kHz and 100 kHz
  - Output slope control to eliminate ground bounce
  - Schmitt trigger inputs for noise suppression
- · Programmable Hardware Slave Address Bits:
  - Configurable via the Hardware Address Register (HAR)
- · Versatile Data Protection Options:
  - Software write protection via the Write Protection Register (WPR)
- · Operating Voltage Range of 1.6V to 5.5V
- · Low-Power CMOS Technology:
  - Write current: 1.0 mA maximum at 5.5V
  - Read current: 1.0 mA maximum at 5.5V, 1 MHz
  - Standby Current: 1 μA at 5.5V
- · High Reliability:
  - More than one million erase/write cycles
  - Data retention: >200 years
  - ESD protection: >4000V
- · RoHS Compliant

#### **Packages**

 8-Lead SOIC, 8-Lead TSSOP, 8-Pad UDFN, 5-Lead SOT-23 and Two 4-Ball CSP options

#### Package Types (not to scale)



#### **Pin Function Table**

| Name | Function           |
|------|--------------------|
| Vss  | Ground             |
| SDA  | Serial Data Pin    |
| SCL  | Serial Clock Input |
| Vcc  | Supply Voltage     |

#### **Description**

The 24CW16X/24CW32X/24CW64X/24CW128X (24CW Series) devices provide 16-128 Kbits of Serial EEPROM utilizing an I $^2$ C (2-wire) serial interface. The 24CW Series is organized as 2048/4096/8192/16384 bytes of 8 bits each (2-16 Kbytes). The 24CW Series is optimized for use in consumer and industrial applications, where reliable and dependable nonvolatile memory storage is essential. The 24CW Series allows up to eight devices to share a common I $^2$ C (2-wire) bus and is capable of operation across a broad voltage range (1.6V to 5.5V).

The 24CW Series contains a pair of programmable Configuration registers which allow certain device behaviors to be modified. These registers are the Write Protection Register and the Hardware Address Register.

The Write Protection Register (WPR) controls the valid address ranges of the EEPROM array that can be written. This allows the user to select the write protection behavior to be configured for software write protection.

The Hardware Address Register (HAR) controls the three hardware slave address bits. These bits determine which device addresses the 24CW Series will Acknowledge. Because the 24CW Series is a 4-pin device, the cascadable feature is controlled by the HAR.

Once the desired software write protection and hardware slave address bits are set, these Configuration registers can be permanently locked, thereby preventing any further changes to the device operation.

#### **System Configuration Using Serial EEPROMs**



### **Block Diagram**



#### 1.0 ELECTRICAL CHARACTERISTICS

### Absolute Maximum Ratings(†)

| Vcc                               | 6.5V           |
|-----------------------------------|----------------|
| All inputs and outputs w.r.t. Vss | 0.6V to 6.5V   |
| Storage temperature               | 65°C to +150°C |
| Ambient temperature under bias    | -40°C to +85°C |
| ESD protection on all pins        | >4 kV          |

**† NOTICE:** Stresses above those listed under 'Maximum ratings' may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for an extended period of time may affect device reliability.

#### TABLE 1-1: DC CHARACTERISTICS

| DC CHA        | ARACTERISTICS    Electrical Characteristics:   Industrial (I):   Vcc = 1.6V to 5.5V |                                               |           | 5.5V TA = -40°C to +85°C |       |                                                    |
|---------------|-------------------------------------------------------------------------------------|-----------------------------------------------|-----------|--------------------------|-------|----------------------------------------------------|
| Param.<br>No. | Symbol                                                                              | Characteristic                                | Min.      | Max.                     | Units | Test Conditions                                    |
| D1            | VIH                                                                                 | High-Level Input Voltage                      | Vcc x 0.7 | Vcc + 0.5                | V     |                                                    |
| D2            | VIL                                                                                 | Low-Level Input Voltage                       | -0.6      | Vcc x 0.3                | V     |                                                    |
| D3            | Vol                                                                                 | Low-Level Output Voltage                      | _         | 0.4                      | V     | IOL = 2.1 mA, VCC = 3.0V                           |
|               |                                                                                     |                                               | _         | 0.2                      | V     | IOL = 0.15 mA, VCC = 1.8V                          |
| D4            | ILI                                                                                 | Input Leakage Current                         | _         | ±1                       | μΑ    | VIN = Vss or Vcc                                   |
| D5            | ILO                                                                                 | Output Leakage Current                        | _         | ±1                       | μΑ    | Vout = Vss or Vcc                                  |
| D6            | CINT                                                                                | Internal Capacitance (all inputs and outputs) | _         | 7                        | pF    | TAMB = +25°C, FCLK = 1 MHz,<br>VCC = 5.5V (Note 1) |
| D7            | ICCREAD                                                                             | Operating Current                             | _         | 0.3                      | mA    | Vcc = 1.8V, Fclk = 400 kHz                         |
|               |                                                                                     |                                               | _         | 1                        | mA    | Vcc = 5.5V, Fclk = 1 MHz                           |
| D8            | ICCWRITE                                                                            | Operating Current                             | _         | 1                        | mA    | Vcc = 5.5V, Fclк = 1 MHz                           |
| D9            | Iccs                                                                                | Standby Current                               | _         | 0.5                      | μΑ    | SCL = SDA = Vcc = 1.8V                             |
|               |                                                                                     |                                               | _         | 1.0                      | μΑ    | SCL = SDA = Vcc = 5.5V                             |

**Note 1:** This parameter is not tested, but is ensured by characterization.

TABLE 1-2: AC CHARACTERISTICS

| AC CHA        | AC CHARACTERISTICS |                                                                                | Electrical Char<br>Industrial (I): | acteristic | 5.5V TA = -40°C to +85°C: |                            |
|---------------|--------------------|--------------------------------------------------------------------------------|------------------------------------|------------|---------------------------|----------------------------|
| Param.<br>No. | Symbol             | Characteristic                                                                 | Min.                               | Max.       | Units                     | Conditions                 |
| 1             | FCLK               | Clock Frequency                                                                | _                                  | 1000       | kHz                       | 1.6V ≤ Vcc ≤ 5.5V          |
| 2             | THIGH              | Clock High Time                                                                | 260                                | _          | ns                        | 1.6V ≤ VCC ≤ 5.5V          |
| 3             | TLOW               | Clock Low Time                                                                 | 500                                | _          | ns                        | 1.6V ≤ Vcc ≤ 5.5V          |
| 4             | Tr                 | SDA and SCL Rise Time                                                          | _                                  | 1000       | ns                        | 1.6V ≤ VCC ≤ 5.5V (Note 1) |
| 5             | TF                 | SDA and SCL Fall Time                                                          | _                                  | 300        | ns                        | 1.6V ≤ VCC ≤ 5.5V (Note 1) |
| 6             | THD:STA            | Start Condition Hold Time                                                      | 260                                | _          | ns                        | 1.6V ≤ Vcc ≤ 5.5V          |
| 7             | Tsu:sta            | Start Condition Setup Time                                                     | 260                                | _          | ns                        | 1.6V ≤ VCC ≤ 5.5V          |
| 8             | THD:DAT            | Data Input Hold Time                                                           | 0                                  | _          | ns                        | (Note 2)                   |
| 9             | TSU:DAT            | Data Input Setup Time                                                          | 50                                 | _          | ns                        | 1.6V ≤ Vcc ≤ 5.5V          |
| 10            | Tsu:sto            | Stop Condition Setup Time                                                      | 260                                | _          | ns                        | 1.6V ≤ Vcc ≤ 5.5V          |
| 11            | TAA                | Output Valid from Clock                                                        | _                                  | 450        | ns                        | 1.6V ≤ Vcc ≤ 5.5V          |
| 12            | TBUF               | Bus Free Time: Bus Time<br>must be Free before a New<br>Transmission can Start | 500                                | _          | ns                        | 1.6V ≤ VCC ≤ 5.5V          |
| 13            | TSP                | Input Filter Spike Suppression (SDA and SCL pins)                              | _                                  | 50         | ns                        | (Note 3)                   |
| 14            | Twc                | Write Cycle Time (byte or page)                                                | _                                  | 5          | ms                        |                            |

- **Note 1:** The rise/fall times must be less than the specified maximums in order to achieve the maximum clock frequencies specified for FCLK. Please refer to the I<sup>2</sup>C specification for applicable timings.
  - **2:** As a transmitter, the device must provide an internal minimum delay time to bridge the undefined region of the falling edge of SCL to avoid unintended generation of Start or Stop conditions.
  - 3: Not 100% tested. CB = total capacitance of one bus line in pF.

FIGURE 1-1: BUS TIMING DATA



TABLE 1-3: EEPROM CELL PERFORMANCE CHARACTERISTICS

| Operation                      | Test Condition               | Min.      | Max. | Units        |
|--------------------------------|------------------------------|-----------|------|--------------|
| Write Endurance <sup>(1)</sup> | TA = 25°C, 1.6V ≤ VCC ≤ 5.5V | 1,000,000 | _    | Write Cycles |
| Data Retention <sup>(1)</sup>  | TA = 55°C                    | 200       | _    | Years        |

Note 1: Performance is determined through characterization and the qualification process.

## 1.1 Power-up Requirements and Reset Behavior

During a power-up sequence, the Vcc supplied to the 24CW Series should monotonically rise from Vss to the minimum Vcc level, as specified in Table 1-1, with a slew rate no faster than 0.1V/µs.

#### 1.1.1 DEVICE RESET

To prevent write operations or other spurious events from happening during a power-up sequence, the 24CW Series includes a Power-on Reset (POR) circuit. Upon power-up, the device will not respond to any commands until the Vcc level crosses the internal voltage threshold (VPOR) that brings the device out of Reset and into Standby mode.

The system designer must ensure that instructions are not sent to the device until the Vcc supply has reached a stable value greater than, or equal to, the minimum Vcc level. Additionally, once the Vcc is greater than, or equal to, the minimum Vcc level, the master must wait at least TPUP before sending the first command to the device. See Table 1-4 for the values associated with these power-up parameters.

If an event occurs in the system where the Vcc level supplied to the 24CW Series drops below the maximum VPOR level specified, it is recommended that a full-power cycle sequence be performed by first driving the Vcc pin to Vss, waiting at least the minimum TPOFF time and then perform a new power-up sequence in compliance with the requirements defined in Section 1.1 "Power-up Requirements and Reset Behavior".

TABLE 1-4: POWER-UP CONDITIONS

| Symbol | Parameter                                                               | Min. | Max. | Units |
|--------|-------------------------------------------------------------------------|------|------|-------|
| TPUP   | Time Required after Vcc is Stable before the Device can Accept Commands | 100  | _    | μs    |
| VPOR   | Power-on Reset Threshold Voltage                                        | _    | 1.5  | V     |
| TPOFF  | Minimum Time at Vcc = 0V between Power Cycles                           | 1    |      | ms    |

#### 2.0 PIN DESCRIPTIONS

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

TABLE 2-1: PIN FUNCTION TABLE

| Name | 8-Lead<br>SOIC | 8-Lead<br>TSSOP | 5-Lead<br>SOT23 | 8-Lead<br>UDFN <sup>(1)</sup> | 4-Ball CSP<br>(CS0) <sup>(2)</sup> | 4-Ball CSP<br>(CS1) <sup>(3)</sup> | Function            |
|------|----------------|-----------------|-----------------|-------------------------------|------------------------------------|------------------------------------|---------------------|
| NC   | 1              | 1               | _               | 1                             | _                                  | _                                  | No Connect          |
| NC   | 2              | 2               | _               | 2                             | _                                  | _                                  | No Connect          |
| NC   | 3              | 3               | _               | 3                             | _                                  | _                                  | No Connect          |
| Vss  | 4              | 4               | 2               | 4                             | A2                                 | B2                                 | Ground              |
| SDA  | 5              | 5               | 3               | 5                             | B2                                 | B1                                 | Serial Data         |
| SCL  | 6              | 6               | 1               | 6                             | B1                                 | A2                                 | Serial Clock        |
| NC   | 7              | 7               | 5               | 7                             | _                                  | _                                  | No Connect          |
| Vcc  | 8              | 8               | 4               | 8                             | A1                                 | A1                                 | Device Power Supply |

Note 1: The exposed pad on this package can be connected to Vss or left floating.

2: CS0 CSP ball pitch is 0.4x0.4 mm.

3: CS1 CSP ball pitch is 0.5x0.4 mm.

#### 2.1 Serial Data (SDA)

This is a bidirectional pin used to transfer addresses and data into and 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 and 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.2 Serial Clock (SCL)

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

#### 3.0 MEMORY ORGANIZATION

#### 3.1 **EEPROM Organization**

The 24CW Series is internally organized as 64/128/256/512 pages of 32 bytes each, depending on the density.

#### 3.2 Device Configuration Registers

The 24CW Series contains two Configuration registers that modulate device operation and/or report on the current status of the device. These registers are:

- · Write Protection Register (WPR)
- · Hardware Address Register (HAR)

Once the device behavior is set as desired, the Configuration registers can be permanently locked (or set to read-only), thereby preventing any subsequent changes.

#### 3.2.1 WRITE PROTECTION REGISTER

The Write Protection Register (WPR) allows for modification of the device write protection behavior. Refer to Section 8.2 "Write Protection Register" for additional information of the WPR.

#### 3.2.2 HARDWARE ADDRESS REGISTER

The Hardware Address Register (HAR) allows for modification of the hardware slave address bits in the device address byte that the device will Acknowledge. Refer to **Section 8.3 "Hardware Address Register"** for additional information on the HAR.

#### 3.3 Device Addressing

Communication with the 24CW Series begins with an 8-bit device address byte, comprised of a 7-bit slave address and a Read/Write Select (R/W) bit. Since multiple slave devices can reside on the serial bus, each slave device must have its own unique device address, programmed in the HAR, so that the master can access each device independently.

The 7-bit slave address is constructed using two groups of bits. The first four bits contain the Device Type Identifier, followed by three bits containing the hardware slave address bits.

The 24CW Series will respond to only specific Device Type Identifiers, as shown in Section 3.3.1 "Valid Device Address Byte Inputs".

The 3-bit hardware slave address is comprised of bits A2, A1 and A0. These bits can be used to expand the address space by allowing up to eight devices with the same Device Type Identifiers on the bus. These hardware slave address bits must correlate with the values programmed in the HAR.

The device will respond to all valid device address byte combinations that it receives.

## 3.3.1 VALID DEVICE ADDRESS BYTE INPUTS

The 24CW Series will respond to the Device Type Identifiers, as shown in Table 3-1.

#### 3.3.1.1 Preset Slave Addresses

The 24CW Series is preset with a specific slave address. The preset slave address bits are embedded in the base part number, as shown in Table 3-2.

TABLE 3-1: TABLE OF VALID DEVICE ADDRESS BYTES

| Access Region           | D     | evice Typ | e Identifi | er    | Hardwa | re Slave A | Read/Write<br>Select |       |
|-------------------------|-------|-----------|------------|-------|--------|------------|----------------------|-------|
|                         | Bit 7 | Bit 6     | Bit 5      | Bit 4 | Bit 3  | Bit 2      | Bit 1                | Bit 0 |
| EEPROM                  | 1     | 0         | 1          | 0     | A2     | A1         | A0                   | R/W   |
| Configuration Registers | 1     | 0         | 1          | 0     | A2     | A1         | A0                   | R/W   |

**Note:** The access region is selected according to bit 7 of the first word address byte. Refer to **Section 3.3.2** "**Word Address Bytes**" for additional information.

TABLE 3-2: DEVICE PRESET SLAVE ADDRESS

| Part Number Series<br>24CWXXXX   | Hardware Slave<br>Address Bits |    |    |  |  |  |  |
|----------------------------------|--------------------------------|----|----|--|--|--|--|
| 24000                            | A2                             | A1 | Α0 |  |  |  |  |
| 24CWXXX <b>0<sup>(1)</sup></b>   | 0                              | 0  | 0  |  |  |  |  |
| 24CWXXX1 <sup>(1,2)</sup>        | 0                              | 0  | 1  |  |  |  |  |
| 24CWXXX <b>2<sup>(1,2)</sup></b> | 0                              | 1  | 0  |  |  |  |  |
| 24CWXXX <b>3<sup>(1,2)</sup></b> | 0                              | 1  | 1  |  |  |  |  |
| 24CWXXX <b>4<sup>(1,2)</sup></b> | 1                              | 0  | 0  |  |  |  |  |
| 24CWXXX <b>5<sup>(1,2)</sup></b> | 1                              | 0  | 1  |  |  |  |  |
| 24CWXXX <b>6<sup>(1,2)</sup></b> | 1                              | 1  | 0  |  |  |  |  |
| 24CWXXX <b>7<sup>(1,2)</sup></b> | 1                              | 1  | 1  |  |  |  |  |

**Note 1:** 'XXX' in the part number varies depending on the density.

**2:** Contact your local sales representative for hardware slave address availability.

#### 3.3.1.2 Read/Write Select Bit

The eighth bit (bit 0) of  $\underline{\text{th}}$ e device address byte is the Read/Write Select (R/W) bit. A read operation is initiated if this bit is a logic '1' and a write operation is initiated if this bit is a logic '0'.

Upon the successful comparison of the device address byte, the 24CW Series will respond. If a valid comparison is not made, the device will not respond and return to a standby state.

#### 3.3.2 WORD ADDRESS BYTES

Two 8-bit word address bytes are transmitted to the device immediately following the device address byte.

The first word address byte contains the Most Significant bits (MSbs) of the memory array word address to specify which location in the EEPROM to start reading or writing. Note that the number of word address bits depends on the density. Refer to Table 3-3 for details.

When accessing the memory array, it is required that bit 7 of the word address byte be set to a logic '0'. When accessing the Configuration registers, it is required that bit 7 of the first word address byte be set to a logic '1'. Refer to Table 3-3 for details.

Next, the second word address byte is sent to the device which provides the remaining eight bits of the word address (A7 through A0). Refer to Table 3-4 for details.

TABLE 3-3: FIRST WORD ADDRESS BYTE

| Memory Region           | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 16-Kbit EEPROM          | 0     | х     | х     | х     | х     | A10   | A9    | A8    |
| 32-Kbit EEPROM          | 0     | Х     | Х     | Х     | A11   | A10   | A9    | A8    |
| 64-Kbit EEPROM          | 0     | х     | х     | A12   | A11   | A10   | A9    | A8    |
| 128-Kbit EEPROM         | 0     | Х     | A13   | A12   | A11   | A10   | A9    | A8    |
| Configuration Registers | 1     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |

TABLE 3-4: SECOND WORD ADDRESS BYTE

| Memory Region                          | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 16-Kbit EEPROM                         | A7    | A6    | A5    | A4    | A3    | A2    | A1    | A0    |
| 32-Kbit EEPROM                         | A7    | A6    | A5    | A4    | A3    | A2    | A1    | A0    |
| 64-Kbit EEPROM                         | A7    | A6    | A5    | A4    | A3    | A2    | A1    | A0    |
| 128-Kbit EEPROM                        | A7    | A6    | A5    | A4    | A3    | A2    | A1    | A0    |
| Configuration Registers <sup>(1)</sup> | Х     | х     | х     | Х     | Х     | Х     | Х     | Х     |

**Note 1:** When accessing the Configuration registers, the second word address byte must be transmitted to the device despite containing only don't care values.

#### 4.0 FUNCTIONAL DESCRIPTION

The 24CW Series 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 must be controlled by a master which generates the Serial Clock (SCL), controls the bus access and generates the Start and Stop conditions, while the 24CW Series works as a slave. Both master and slave can operate as a transmitter or receiver, but the master determines which mode is activated.

#### 5.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 5-1).

#### 5.1 Bus Not Busy (A)

Both data and clock lines remain high.

#### 5.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.

#### 5.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 end with a Stop condition.

#### 5.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 bit of data per clock pulse.

Each data transfer is initiated with a Start condition and terminated with a Stop condition. The number of the data bytes transferred between the Start and Stop conditions is determined by the master.

#### 5.5 Acknowledge

Each receiving device, when addressed, is obliged to generate an Acknowledge signal after the reception of each byte. The master must generate an extra clock pulse, which is associated with this Acknowledge bit. See Figure 5-2 for Acknowledge timing.

**Note:** The 24CW Series does not generate any Acknowledge bits if an internal programming cycle is in progress.

A device that Acknowledges must 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 read operations, the master must signal an end of data to the slave by NOT generating an Acknowledge (NACK) bit on the last byte that has been clocked out of the slave. In this case, the slave (24CW Series) will leave the data line high to enable the master to generate the Stop condition.

#### FIGURE 5-1: DATA TRANSFER SEQUENCE ON THE SERIAL BUS



#### FIGURE 5-2: ACKNOWLEDGE TIMING



#### 5.6 Standby Mode

The 24CW Series features a low-power Standby mode which is enabled when any one of the following occurs:

- A valid power-up sequence is performed (see Section 1.1 "Power-up Requirements and Reset Behavior").
- A Stop condition is received by the device unless it initiates an internal write cycle (see Section 6.0 "Write Operations").
- At the completion of an internal write cycle (see Section 6.0 "Write Operations").
- An unsuccessful match of the Device Type Identifier or hardware slave address in the device address byte occurs (see Section 3.3 "Device Addressing").
- The master does not Acknowledge the receipt of data read out from the device; instead, it sends a NACK response.(see Section 7.0 "Read Operations").

#### 5.7 Software Reset

After an interruption in protocol, power loss or system Reset, any 2-wire device can be protocol reset by clocking SCL until SDA is released by the EEPROM and goes high. The number of clock cycles until SDA is released by the EEPROM will vary. The Software Reset sequence should not take more than nine dummy clock cycles. Note that the Software Reset sequence will not interrupt the internal write cycle and only resets the I<sup>2</sup>C interface.

Once the Software Reset sequence is complete, new protocol can be sent to the device by sending a Start condition, followed by the protocol. Figure 5-3 illustrates the Software Reset sequence.

In the event that the device is still non-responsive, or remains active on the SDA bus, a power cycle must be used to reset the device (see **Section 1.1.1 "Device Reset"**).

FIGURE 5-3: SOFTWARE RESET



#### 6.0 WRITE OPERATIONS

All write operations for the 24CW Series begin with the master sending a Start condition, followed by a device address byte with the  $R/\overline{W}$  bit set to a logic '0', and then by the word address bytes. The data value(s) to be written to the device immediately follows the word address bytes.

#### 6.1 Byte Write

The 24CW Series supports the writing of a single 8-bit byte. Selecting a data byte in the 24CW Series requires a two-byte word address with the MSb set to a logic '0'. Note that some word address bits are ignored and the number of ignored bits depends on the device density.

Upon receipt of the proper device address and word address bytes, the EEPROM will send an Acknowledge. The device will then be ready to receive the first 8-bit data byte. Following the receipt of the data byte, the EEPROM will respond with an Acknowledge. The addressing device, such as a master, must then terminate the write operation with a Stop condition. At that time, the EEPROM will enter an internally self-timed write cycle, which will be completed within Twc, while the data byte is being programmed into the nonvolatile EEPROM. All inputs are disabled during this write cycle and the EEPROM will not respond until the write operation is complete.

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





#### 6.2 Page Write

A page write operation allows up to 32 bytes to be written in the same write cycle, provided all bytes are in the same page of the memory array. Partial page writes of less than 32 bytes are also allowed.

A page write is initiated the same way as a byte write, but the master does not send a Stop condition after the first data byte is clocked in. Instead, after the EEPROM Acknowledges receipt of the first data byte, the master can transmit up to 31 additional data bytes. The EEPROM will respond with an ACK after each data byte is received.

Once all data to be written has been sent to the device, the master must issue a Stop condition (see Figure 6-2). Once the Stop condition is received, an internal write cycle will begin.

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

The lower five bits of the word address are internally incremented following the receipt of each data byte. The higher order address bits are not incremented and retain the memory page location.

When the incremented word address reaches the page boundary, the address counter will roll over to the beginning of the same 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 the addresses that are integer multiples of [page size - 1]. If a page write operation 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.

#### FIGURE 6-2: PAGE WRITE



#### 6.3 Write Cycle Timing

The length of the self-timed write cycle, or Twc, is defined as the amount of time from the Stop condition that begins the internal write operation, to the Start condition of the first device address byte sent to the 24CW Series that it subsequently responds to with an ACK (see Figure 6-3).

During the internally self-timed write cycle, any attempts to read from, or write to, the memory array will not be processed.

FIGURE 6-3: WRITE CYCLE TIMING



#### 6.4 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 operation 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 device address byte for a write operation ( $R/\overline{W}$  = 0). If the device is still busy with the write cycle, then a NACK will be returned. If a NACK is returned, then the Start bit and device address byte must be resent. If the cycle is complete, then the device will return the ACK and the master can then proceed with the next read or write operation. See Figure 6-4 for the flow diagram.

Note: If the user is polling after writing to the Hardware Address Register (HAR), the user must send the new hardware slave address to determine whether the write cycle is complete. If the 24CW Series doesn't ACK the new hardware slave address after the maximum write cycle time (Twc), the write to the HAR was not successful.

FIGURE 6-4: ACKNOWLEDGE POLLING FLOW



#### 6.5 Write Protection

The 24CW Series write protection is controlled via the Write Protection Register (WPR). The 24CW Series is segmented into four different memory zones, which allows the user to select which of the zones will be software write-protected. The protection behavior can be made permanent by locking the Configuration registers. For additional information on the Write Protection Register, see Section 8.2 "Write Protection Register".

TABLE 6-1: 24CW SERIES SOFTWARE WRITE PROTECTION

| Protection Level | Protected Address Range |             |             |             |  |  |  |
|------------------|-------------------------|-------------|-------------|-------------|--|--|--|
| Protection Level | 24CW16X                 | 24CW32X     | 24CW64X     | 24CW128X    |  |  |  |
| Upper 1/4        | 0600h-07FFh             | 0C00h-0FFFh | 1800h-1FFFh | 3000h-3FFFh |  |  |  |
| Upper 1/2        | 0400h-07FFh             | 0800h-0FFFh | 1000h-1FFFh | 2000h-3FFFh |  |  |  |
| Upper 3/4        | 0200h-07FFh             | 0400h-0FFFh | 0800h-1FFFh | 1000h-3FFFh |  |  |  |
| Entire Array     | 0000h-07FFh             | 0000h-0FFFh | 0000h-1FFFh | 0000h-3FFFh |  |  |  |

#### 7.0 READ OPERATIONS

Read operations are initiated the same way as write operations, with the exception that the Read/Write Select (R/W) bit in the device address byte must be a logic '1'. There are three read operations:

- · Current Address Read
- · Random Address Read
- · Sequential Read

#### 7.1 Current Address Read

The 24CW Series contains an internal Address Pointer that maintains the word address of the last byte accessed, internally incremented by one. Therefore, if the previous read access was to address 'n' (n is any legal address), the next current address read operation would access data from address n+1.

A current address read operation will output data according to the location of the internal Address Pointer. This is initiated with a Start condition, followed by a valid device address byte with the R/W bit set to logic '1'. The device will ACK this sequence and the current address data byte is serially clocked out on the SDA line. All types of read operations will be terminated if the master does not respond with an ACK (it NACKs) during the ninth clock cycle, which will force the device into Standby mode. After the NACK response, the master may send a Stop condition to complete the protocol or it can send a Start condition to begin the next sequence.

#### FIGURE 7-1: CURRENT ADDRESS READ



#### 7.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, first the word address must be set. This is done by sending the word address, with the MSb set to logic '0', to the 24CW Series as part of a write operation ( $R/\overline{W}$  bit set to '0'). After the word 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. Then, the master issues the device address byte again, but with the R/W bit set to a '1'. The 24CW Series will then issue an Acknowledge and transmit the 8-bit data byte. The master will not Acknowledge the transfer, but does generate a Stop condition which causes the 24CW Series to discontinue transmission (Figure 7-2). After a random read operation, the internal Address Pointer will point to the last word address location, incremented by one.

#### FIGURE 7-2: RANDOM READ



#### 7.3 Sequential Read

A sequential read is initiated by either a current address read or a random read. After the master receives a data byte, the master responds with an Acknowledge. As long as the EEPROM receives an ACK, it will continue to increment the word address and serially clock out the sequential data byte. When the maximum memory address is reached, the internal Address Pointer will automatically roll over from the end of the array to word address, 0000h, if the master Acknowledges the byte received from the end of the array.

All types of read operations will be terminated if the master does not respond with an ACK (it NACKs) during the ninth clock cycle, which will force the device into Standby mode. After the NACK response, the master may send a Stop condition to complete the protocol or it can send a Start condition to begin the next sequence.

#### **FIGURE 7-3: SEQUENTIAL READ**



#### 8.0 CONFIGURATION REGISTERS

The 24CW Series device contains a pair of 8-bit Configuration registers which control software write protection and the hardware slave address.

The Configuration registers are accessed sequentially as Byte 0 and Byte 1, as shown in Table 8-1.

If desired, the Configuration registers can be locked so that the registers are set to read-only and can no longer be modified. This makes the current software write protection and hardware slave address scheme permanent.

TABLE 8-1: CONFIGURATION REGISTERS

| Memory Region             | Byte | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------------------------|------|-------|-------|-------|-------|-------|-------|-------|-------|
| Write Protection Register | 0    | _     | WRTE  | CCLK  | _     | WPRE  | WPB1  | WPB0  | CRLB  |
| Hardware Address Register | 1    | _     | HWRE  | A0CK  | _     | _     | A2    | A1    | A0    |

# 8.1 Accessing the Configuration Registers

The value of the Configuration registers can be determined by executing a random read sequence, as shown in Section 8.5 "Reading the Configuration Registers". Changing the value of the Configuration registers is accomplished with a byte write sequence with the requirements outlined in Section 8.4 "Writing to the Configuration Registers".

Accessing these registers requires the use of '1010b' (Ah) as the Device Type Identifier in the device address byte. Following the Device Type Identifier is the hardware slave address bits for which the values are determined by what is currently programmed in the HAR (see Section 8.3 "Hardware Address Register"). Finally, bit 0 is the Read/Write Select (R/W) bit, where a logic '1' is used for reading and logic '0' is used for writing. See Table 3-1 for additional information.

Note: The hardware slave address bit values are initially factory preset but can be changed by the user. These bit values must match the current device configuration to receive an Acknowledge.

When accessing the Configuration registers, the word address must be sent to the device. All bits in the word address are ignored, except for the MSb which must be set to logic '1'. Refer to Table 3-3 and Table 3-4 for additional information.

#### 8.2 Write Protection Register

The Write Protection Register (WPR) is Byte 0 of the sequential Configuration registers. The Write Protection Register format can be seen in Register 8-1.

#### REGISTER 8-1: WRITE PROTECTION REGISTER - BYTE 0

| U-0   | W-0  | W-0  | U-0 | R/W  | R/W  | R/W  | R/W   |
|-------|------|------|-----|------|------|------|-------|
| _     | WRTE | CCLK | _   | WPRE | WPB1 | WPB0 | CRLB  |
| bit 7 |      |      |     |      |      |      | bit 0 |

Legend:R = Readable bitW = Writable bitU = Unimplemented bit, read as '0'-n = Value at POR'1' = Bit is set'0' = Bit is clearedx = Bit is unknown

bit 7 Unimplemented: Read as '0' bit 6 WRTE: Configuration Registers Write bit 1 = Configuration registers are writable 0 = Configuration register writes are ignored bit 5 **CCLK:** Configuration Registers Check Lock bit Must match the CRLB bit when writing to the Configuration registers. bit 4 Unimplemented: Read as '0' bit 3 WPRE: Write Protection Register Enable bit 1 = Write protection is set by the WPB<1:0> bits 0 = No software write protection is enabled (Default) bit 2-1 WPB<1:0>: Write-Protect Block bits If WPRE = 1: 11 = Entire EEPROM is write-protected 10 = Upper 3/4 of EEPROM is write-protected 01 = Upper 1/2 of EEPROM is write-protected 00 = Upper 1/4 of EEPROM is write-protected If WPRE = 0: Unused (Default). bit 0 CRLB: Configuration Registers Lock bit 1 = Configuration registers will become permanently locked

0 = Configuration registers can be written to (**Default**)

Configuration Registers Write bit (WRTE): This bit must be set to a logic '1' in order to write to the Configuration registers. Failure to set the WRTE bit to a logic '1' will cause the device to ignore the write operation. When reading the WPR, the WRTE bit will always read as logic '0'.

Configuration Registers Check Lock bit (CCLK): This bit must match the CRLB bit when writing the Configuration registers. If the CCLK bit does not match the CRLB, the device will ignore the write operation. When reading the WPR, the CCLK bit will always read as logic '0'.

Write Protection Register Enable bit (WPRE): This bit is used to enable or disable the device software write protection feature. A logic '0' will disable the software write protection feature and a logic '1' will enable software write protection.

Write-Protect Block bits (WPB<1:0>): These bits allow four levels of protection for the memory array, provided that the WPRE bit is set to a logic '1'. If the WPRE bit is a logic '0', the state of the WPB<1:0> bits has no impact on device protection. The protected address ranges can be found in Table 8-2.

Configuration Registers Lock bit (CRLB): This bit is used to permanently lock the current state of the WPR and HAR. A logic '0' indicates that these registers can be modified, whereas a logic '1' indicates that the WPR and HAR have been locked and can no longer be modified. To safeguard against accidental locking of these registers, the CCLK bit must match the CRLB bit sent to the device. If these bits do not match, the device will ignore the write operation.

**Note:** The Configuration registers cannot be unlocked once they are locked.

#### 8.2.1 SOFTWARE WRITE PROTECTION

The EEPROM array in the 24CW Series will be protected from writing in accordance with the WPB<1:0> bits value as long as the WPRE bit is set to logic '1'. If the WPRE bit is set to logic '0', the WPB<1:0> bits are ignored and no portion of the EEPROM array will be protected. The combination of these three bits creates five possible levels of protection for the device, as seen in Table 8-2.

TABLE 8-2: PROTECTED ADDRESS RANGE

| Protection Level | WPRE | WDD1 | WPB1 | WDD4        | E WDD4      | WPB0        |             | Protected Ad | ldress Range |  |
|------------------|------|------|------|-------------|-------------|-------------|-------------|--------------|--------------|--|
| Protection Level | WPRE | WPDI | WPBU | 24CW16X     | 24CW32X     | 24CW64X     | 24CW128X    |              |              |  |
| None             | 0    | х    | х    | None        | None        | None        | None        |              |              |  |
| Upper 1/4        | 1    | 0    | 0    | 0600h-07FFh | 0C00h-0FFFh | 1800h-1FFFh | 3000h-3FFFh |              |              |  |
| Upper 1/2        | 1    | 0    | 1    | 0400h-07FFh | 0800h-0FFFh | 1000h-1FFFh | 2000h-3FFFh |              |              |  |
| Upper 3/4        | 1    | 1    | 0    | 0200h-07FFh | 0400h-0FFFh | 0800h-1FFFh | 1000h-3FFFh |              |              |  |
| Entire Array     | 1    | 1    | 1    | 0000h-07FFh | 0000h-0FFFh | 0000h-1FFFh | 0000h-3FFFh |              |              |  |

#### 8.3 Hardware Address Register

The Hardware Address Register (HAR) is Byte 1 of the sequential Configuration registers. The Hardware Address Register format can be seen in Register 8-2.

#### REGISTER 8-2: HARDWARE ADDRESS REGISTER – BYTE 1

| U-0   | W-0  | W-0  | U-0 | U-0 | R/W | R/W | R/W   |
|-------|------|------|-----|-----|-----|-----|-------|
| _     | HWRE | A0CK | _   | _   | A2  | A1  | A0    |
| bit 7 |      |      |     |     |     |     | bit 0 |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | l as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 7   | Unimplemented: Read as '0'                                                                                         |
|---------|--------------------------------------------------------------------------------------------------------------------|
| bit 6   | HWRE: HAR Write Enable bit                                                                                         |
|         | <ul><li>1 = Configuration registers are writable</li><li>0 = Configuration register writes are ignored</li></ul>   |
| bit 5   | A0CK: Hardware Slave Address Check A0 bit                                                                          |
|         | Must match A0 bit when writing the Configuration registers.                                                        |
| bit 4-3 | Unimplemented: Read as '0'                                                                                         |
| bit 2   | A2: Hardware Slave Address A2 bit                                                                                  |
|         | 1 = Hardware slave address bit A2 is set to a logic '1'<br>0 = Hardware slave address bit A2 is set to a logic '0' |
| bit 1   | A1: Hardware Slave Address A1 bit                                                                                  |
|         | 1 = Hardware slave address bit A1 is set to a logic '1' 0 = Hardware slave address bit A1 is set to a logic '0'    |
| bit 0   | A0: Hardware Slave Address A0 bit                                                                                  |
|         | 1 = Hardware slave address bit A0 is set to a logic '1'<br>0 = Hardware slave address bit A0 is set to a logic '0' |

HAR Write Enable bit (HWRE): When writing to the HAR, this bit must be set to a logic '1'. Failure to set the HWRE bit to a logic '1' will cause the device to ignore the write operation. When reading the HAR, the HWRE bit will always read as logic '0'.

Hardware Slave Address Check A0 bit (A0CK): This bit must match the A0 bit when writing to the Configuration registers. If the A0CK bit does not match the A0 bit, the device will ignore the write operation. When reading the HAR, the A0CK bit will always read as logic '0'.

Hardware Slave Address bits (A2, A1, A0): The 3-bit hardware slave address is contained in bits A2, A1 and A0 of the HAR. These bits control the valid values in bit 3 through bit 1 (A2, A1, A0) of the device address byte. Details of the device address byte are found in Section 3.3 "Device Addressing".

Note: If multiple 24CW Series devices are on the same bus, each device must have unique hardware slave addresses to be accessed individually, including programming the HAR. Different preset hardware slave addresses are available. Contact your local sales representative for details.

# 8.4 Writing to the Configuration Registers

When writing to the Configuration registers, a byte write sequence must be sent to the device (see **Section 6.1** "Byte Write" for additional information). The MSb of the word address must be set to logic '1' in order to write to the Configuration registers.

A valid WPR byte must be provided when writing to the Configuration registers. If the WPR byte is invalid, the operation will abort, the EEPROM will not Acknowledge any data bytes and the device will not execute the internal write cycle. Refer to **Section 8.2** "Write Protection Register" for valid WPR byte values.

After sending a valid WPR byte, the HAR byte can optionally be sent. If the HAR byte is invalid, the operation will abort, the EEPROM will not Acknowledge any data bytes and the device will not execute the internal write cycle. Refer to **Section 8.3 "Hardware Address Register"** for valid HAR byte values.

Sending more than the WPR and HAR bytes to the 24CW Series will cause the write cycle to abort and the contents of the WPR and HAR will not be changed.

**Note:** If a polling routine has been implemented and the user writes new data values to the HAR, the user must send the new hardware slave address for the device to Acknowledge.

FIGURE 8-1: CONFIGURATION REGISTERS WRITE SEQUENCE



# 8.5 Reading the Configuration Registers

When reading the Configuration registers, a random read sequence must be sent to the device (see **Section 7.2 "Random Read"** for additional information). The MSb of the word address must be set to logic '1' in order to read the Configuration registers.

It is not possible to read the contents of the Configuration registers with a current address read sequence. Due to the sequential nature of the Configuration registers, it is not possible to read only the HAR contents.

Note:

The 24CW Series will automatically roll over from the HAR (Byte 1) back to the WPR (Byte 0) if the master continues to Acknowledge the data bytes during the read operation.

#### FIGURE 8-2: CONFIGURATION REGISTERS READ SEQUENCE

