# 1K 2.5V Dual Mode I<sup>2</sup>C<sup>TM</sup> Serial EEPROM ## **FEATURES** - · Single supply with operation down to 2.5V - Completely implements DDC1™/DDC2™ interface for monitor identification - · Low power CMOS technology - 1 mA active current typical - 10 μA standby current typical at 5.5V - 2-wire serial interface bus, I<sup>2</sup>C™ compatible - Self-timed write cycle (including auto-erase) - · Page-write buffer for up to 8 bytes - 100 kHz (2.5V) and 400 kHz (5V) compatibility - · Factory programming (QTP) available - · 1,000,000 erase/write cycles guaranteed - Data retention > 200 years - · 8-pin PDIP and SOIC package - · Available for extended temperature ranges - Commercial (C): 0°C to +70°C - Industrial (I): -40°C to +85°C #### DESCRIPTION The Microchip Technology Inc. 24LC21 is a 128 x 8 bit Electrically Erasable PROM. This device is designed for use in applications requiring storage and serial transmission of configuration and control information. Two modes of operation have been implemented: Transmit Only Mode and Bi-Directional Mode. Upon power-up, the device will be in the Transmit Only Mode, sending a serial bit stream of the entire memory array contents, clocked by the VCLK pin. A valid high to low transition on the SCL pin will cause the device to enter the Bi-Directional Mode, with byte selectable read/write capability of the memory array. The 24LC21 is available in a standard 8-pin PDIP and SOIC package in both commercial and industrial temperature ranges. ## **PACKAGE TYPES** ## **BLOCK DIAGRAM** DDC is a trademark of the Video Electronics Standards Association. $I^2C$ is a trademark of Philips Corporation. ## 1.0 ELECTRICAL CHARACTERISTICS ## 1.1 <u>Maximum Ratings\*</u> | Vcc | 7.0V | |-------------------------------------------|-------------------| | All inputs and outputs w.r.t. Vss | 0.6V to Vcc +1.0V | | Storage temperature | 65°C to +150°C | | Ambient temp. with power applied | 65°C to +125°C | | Soldering temperature of leads (10 second | nds)+300°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 extended periods may affect device reliability. TABLE 1-1: PIN FUNCTION TABLE | Name | Function | |------|------------------------------------| | Vss | Ground | | SDA | Serial Address/Data I/O | | SCL | Serial Clock (Bi-Directional Mode) | | VCLK | Serial Clock (Transmit-Only Mode) | | Vcc | +2.5V to 5.5V Power Supply | | NC | No Connection | TABLE 1-2: DC CHARACTERISTICS | | VCC = +2.5V to 5.5V Commercial (C): Tamb = 0°C to +70°C Industrial (I): Tamb = -40°C to +85°C | | | | | |----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----------------|--------------|----------|------------------------------------------------------------------------| | Parameter | Symbol | Min | Max | Units | Conditions | | SCL and SDA pins: High level input voltage Low level input voltage | VIH<br>VIL | .7 <b>V</b> CC | <br>.3 Vcc | V V | | | Input levels on VCLK pin: High level input voltage Low level input voltage | VIH<br>VIL | 2.0<br>— | .8<br>.2 Vcc | V<br>V | Vcc ≥ 2.7V (Note 1)<br>Vcc < 2.7V (Note 1) | | Hysteresis of Schmitt trigger inputs | VHYS | .05 Vcc | _ | V | (Note 1) | | Low level output voltage | VOL1 | _ | .4 | V | IOL = 3 mA, VCC = 2.5V (Note 1) | | Low level output voltage | VOL2 | _ | .6 | V | IOL = 6 mA, VCC = 2.5V | | Input leakage current | ILI | -10 | 10 | μА | VIN = .1V to VCC | | Output leakage current | ILO | -10 | 10 | μА | VOUT = .1V to VCC | | Pin capacitance (all inputs/outputs) | CIN, COUT | _ | 10 | pF | Vcc = 5.0V (Note1),<br>Tamb = 25°C, Fclk = 1 MHz | | Operating current | Icc Write<br>Icc Read | _ | 3<br>1 | mA<br>mA | Vcc = 5.5V, SCL = 400 kHz | | Standby current | Iccs | | 30<br>100 | μA<br>μA | VCC = 3.0V, SDA = SCL = VCC<br>VCC = 5.5V, SDA = SCL = VCC<br>(Note 2) | Note 1: This parameter is periodically sampled and not 100% tested. 2: VLCK must be grounded. **TABLE 1-3: AC CHARACTERISTICS** | Parameter | Symbol | Standar | Standard Mode | | Vcc= 4.5 - 5.5V<br>Fast Mode | | Remarks | | |---------------------------------------------------|---------|---------|---------------|---------------|------------------------------|--------|---------------------------------------------------------------|--| | | | Min | Max | Min | Max | | | | | Clock frequency | FCLK | | 100 | _ | 400 | kHz | | | | Clock high time | THIGH | 4000 | _ | 600 | | ns | | | | Clock low time | TLOW | 4700 | _ | 1300 | | ns | | | | SDA and SCL rise time | TR | | 1000 | _ | 300 | ns | (Note 1) | | | SDA and SCL fall time | TF | | 300 | _ | 300 | ns | (Note 1) | | | START condition hold time | THD:STA | 4000 | _ | 600 | 1 | ns | After this period the first clock pulse is generated | | | START condition setup time | Tsu:sta | 4700 | _ | 600 | | ns | Only relevant for repeated START condition | | | Data input hold time | THD:DAT | 0 | _ | 0 | | ns | (Note 2) | | | Data input setup time | TSU:DAT | 250 | _ | 100 | | ns | | | | STOP condition setup time | Tsu:sto | 4000 | _ | 600 | | ns | | | | Output valid from clock | TAA | _ | 3500 | _ | 900 | ns | (Note 2) | | | Bus free time | TBUF | 4700 | _ | 1300 | _ | ns | Time the bus must be free before a new transmission can start | | | Output fall time from VIH min to VIL max | Tof | _ | 250 | 20 + .1<br>CB | 250 | ns | (Note 1), CB ≤ 100 pF | | | Input filter spike suppression (SDA and SCL pins) | TSP | | 50 | _ | 50 | ns | (Note 3) | | | Write cycle time | Twr | | 10 | _ | 10 | ms | Byte or Page mode | | | Transmit-Only Mode Parai | neters | | | | | | | | | Output valid from VCLK | TVAA | | 2000 | _ | 1000 | ns | | | | VCLK high time | Tvhigh | 4000 | | 600 | | ns | | | | VCLK low time | TvLow | 4700 | _ | 1300 | | ns | | | | Mode transition time | Tvhz | _ | 500 | _ | 500 | ns | | | | Transmit-Only power up time | TVPU | 0 | | 0 | _ | ns | | | | Endurance | _ | 1M | _ | 1M | | cycles | 25°C, Vcc = 5.0V, Block<br>Mode (Note 4) | | Note 1: Not 100% tested. CB = total capacitance of one bus line in pF. <sup>2:</sup> As a transmitter, the device must provide an internal minimum delay time to bridge the undefined region (minimum 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions. <sup>3:</sup> The combined TSP and VHYS specifications are due to new Schmitt trigger inputs which provide improved noise and spike suppression. This eliminates the need for a TI specification for standard operation. <sup>4:</sup> This parameter is not tested but guaranteed by characterization. For endurance estimates in a specific application, please consult the Total Endurance Model which can be obtained on our website. ## 2.0 FUNCTIONAL DESCRIPTION The 24LC21 operates in two modes, the Transmit-Only Mode and the Bi-Directional Mode. There is a separate two wire protocol to support each mode, each having a separate clock input and sharing a common data line (SDA). The device enters the Transmit-Only Mode upon power-up. In this mode, the device transmits data bits on the SDA pin in response to a clock signal on the VCLK pin. The device will remain in this mode until a valid high to low transition is placed on the SCL input. When a valid transition on SCL is recognized, the device will switch into the Bi-Directional Mode. The only way to switch the device back to the Transmit-Only Mode is to remove power from the device. #### 2.1 <u>Transmit-Only Mode</u> The device will power up in the Transmit-Only Mode. This mode supports a unidirectional two wire protocol for transmission of the contents of the memory array. This device requires that it be initialized prior to valid data being sent in the Transmit-Only Mode (see Initialization Procedure, below). In this mode, data is transmitted on the SDA pin in 8 bit bytes, each followed by a ninth, null bit (see Figure 2-1). The clock source for the Transmit-Only Mode is provided on the VCLK pin, and a data bit is output on the rising edge on this pin. The eight bits in each byte are transmitted most significant bit first. Each byte within the memory array will be output in sequence. When the last byte in the memory array is transmitted, the output will wrap around to the first location and continue. The Bi-Directional Mode Clock (SCL) pin must be held high for the device to remain in the Transmit-Only Mode. #### 2.2 <u>Initialization Procedure</u> After Vcc has stabilized, the device will be in the Transmit-Only Mode. Nine clock cycles on the VCLK pin must be given to the device for it to perform internal synchronization. During this period, the SDA pin will be in a high impedance state. On the rising edge of the tenth clock cycle, the device will output the first valid data bit which will be the most significant bit of a byte. The device will power up at an indeterminate byte address. (Figure 2-2). FIGURE 2-1: TRANSMIT ONLY MODE FIGURE 2-2: DEVICE INITIALIZATION ## 3.0 BI-DIRECTIONAL MODE The 24LC21 can be switched into the Bi-Directional Mode (see Figure 3-1) by applying a valid high to low transition on the Bi-Directional Mode Clock (SCL). When the device has been switched into the Bi-Directional Mode, the VCLK input is disregarded, with the exception that a logic high level is required to enable write capability. This mode supports a two wire bi-directional data transmission protocol. In this protocol, a device that sends data on the bus is defined to be the transmitter, and a device that receives data from the bus is defined to be the receiver. The bus must be controlled by a master device that generates the Bi-Directional Mode Clock (SCL), controls access to the bus and generates the START and STOP conditions, while the 24LC21 acts as the slave. Both master and slave can operate as transmitter or receiver, but the master device determines which mode is activated. ## 3.1 <u>Bi-Directional Mode Bus</u> 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 (see Figure 3-2). #### 3.1.1 BUS NOT BUSY (A) Both data and clock lines remain HIGH. #### 3.1.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. #### 3.1.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. FIGURE 3-2: DATA TRANSFER SEQUENCE ON THE SERIAL BUS #### 3.1.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 the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited, although only the last eight will be stored when doing a write operation. When an overwrite does occur it will replace data in a first in first out fashion. #### 3.1.5 ACKNOWLEDGE Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit. **Note:** The 24LC21 does not generate any acknowledge bits if an internal programming cycle is in progress. 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. 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 must leave the data line HIGH to enable the master to generate the STOP condition. FIGURE 3-3: BUS TIMING START/STOP FIGURE 3-4: BUS TIMING DATA #### 3.1.6 SLAVE ADDRESS After generating a START condition, the bus master transmits the slave address consisting of a 7-bit device code (1010) for the 24LC21, followed by three don't care bits. The eighth bit of slave address determines if the master device wants to read or write to the 24LC21 (Figure 3-5). The 24LC21 monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode. | Operation | Control Code | Chip Select | R/W | |-----------|--------------|-------------|-----| | Read | 1010 | XXX | 1 | | Write | 1010 | XXX | 0 | ## FIGURE 3-5: CONTROL BYTE ALLOCATION #### 4.0 WRITE OPERATION #### 4.1 Byte Write Following the start signal from the master, the slave address (4 bits), the don't care bits (3 bits) and the $R/\overline{W}$ bit which is a logic low is placed onto the bus by the master transmitter. This indicates to the addressed slave receiver that a byte with a word address will follow after it has generated an acknowledge bit during the ninth clock cycle. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 24LC21. After receiving another acknowledge signal from the 24LC21 the master device will transmit the data word to be written into the addressed memory location. The 24LC21 acknowledges again and the master generates a stop condition. This initiates the internal write cycle, and during this time the 24LC21 will not generate acknowledge signals (Figure 4-1). It is required that VCLK be held at a logic high level in order to program the device. This applies to byte write and page write operation. Note that VCLK can go low while the device is in its self-timed program operation and not affect programming. ## 4.2 Page Write The write control byte, word address and the first data byte are transmitted to the 24LC21 in the same way as in a byte write. But instead of generating a stop condition the master transmits up to eight data bytes to the 24LC21 which are temporarily stored in the on-chip page buffer and will be written into the memory after the master has transmitted a stop condition. After the receipt of each word, the three lower order address pointer bits are internally incremented by one. The higher order five bits of the word address remains constant. If the master should transmit more than eight words 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 4-3). It is required that VCLK be held at a logic high level in order to program the device. This applies to byte write and page write operation. Note that VCLK can go low while the device is in its self-timed program operation and not affect programming. Page write operations are limited to writing Note: 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. ## FIGURE 4-1: BYTE WRITE #### FIGURE 4-2: BYTE WRITE ## FIGURE 4-3: PAGE WRITE ## 5.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/\overline{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 5-1 for the flow diagram. FIGURE 5-1: ACKNOWLEDGE POLLING FLOW #### 6.0 WRITE PROTECTION When using the 24LC21 in the Bi-Directional Mode, the VCLK pin operates as the write protect control pin. Setting VCLK high allows normal write operations, while setting VCLK low prevents writing to any location in the array. Connecting the VCLK pin to Vss would allow the 24LC21 to operate as a serial ROM, although this configuration would prevent using the device in the Transmit-Only Mode. ## 7.0 READ OPERATION Read operations are initiated in the same way as write operations with the exception that the $R/\overline{W}$ bit of the slave address is set to one. There are three basic types of read operations: current address read, random read and sequential read. #### 7.1 Current Address Read The 24LC21 contains an address counter that maintains the address of the last word accessed, internally incremented by one. 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/\overline{W}$ bit set to one, the 24LC21 issues an acknowledge and transmits the eight bit data word. The master will not acknowledge the transfer but does generate a stop condition and the 24LC21 discontinues transmission (Figure 7-1). #### 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 to the 24LC21 as part of a write operation. 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 control byte again but with the $R/\overline{W}$ bit set to a one. The 24LC21 will then issue an acknowledge and transmits the eight bit data word. The master will not acknowledge the transfer but does generate a stop condition and the 24LC21 discontinues transmission (Figure 7-2). ## 7.3 Sequential Read Sequential reads are initiated in the same way as a random read except that after the 24LC21 transmits the first data byte, the master issues an acknowledge as opposed to a stop condition in a random read. This directs the 24LC21 to transmit the next sequentially addressed 8 bit word (see Figure 7-3). To provide sequential reads the 24LC21 contains an internal address pointer which is incremented by one at the completion of each operation. This address pointer allows the entire memory contents to be serially read during one operation. #### 7.4 <u>Noise Protection</u> The 24LC21 employs a Vcc threshold detector circuit which disables the internal erase/write logic if the Vcc is below 1.5 volts 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. FIGURE 7-1: CURRENT ADDRESS READ ## FIGURE 7-2: RANDOM READ #### FIGURE 7-3: SEQUENTIAL READ #### 8.0 PIN DESCRIPTIONS #### 8.1 SDA This pin is used to transfer addresses and data into and out of the device, when the device is in the Bi-Directional Mode. In the Transmit-Only Mode, which only allows data to be read from the device, data is also transferred on the SDA pin. This pin is an open drain terminal, therefore the SDA bus requires a pullup resistor to Vcc (typical $10K\Omega$ for 100~kHz, $2K\Omega$ for 400~kHz). For normal data transfer in the Bi-Directional Mode, SDA is allowed to change only during SCL low. Changes during SCL high are reserved for indicating the START and STOP conditions. #### 8.2 SCL This pin is the clock input for the Bi-Directional Mode, and is used to synchronize data transfer to and from the device. It is also used as the signaling input to switch the device from the Transmit Only Mode to the Bi-Directional Mode. It must remain high for the chip to continue operation in the Transmit Only Mode. #### 8.3 VCLK This pin is the clock input for the Transmit Only Mode. In the Transmit Only Mode, each bit is clocked out on the rising edge of this signal. In the Bi-Directional Mode, a high logic level is required on this pin to enable write capability. ## **24LC21 Product Identification System** To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices. ## Sales and Support #### **Data Sheets** Products supported by a preliminary Data Sheet may have an errata sheet describing minor operational differences and recommended workarounds. To determine if an errata sheet exists for a particular device, please contact one of the following: - 1. Your local Microchip sales office - 2. The Microchip Corporate Literature Center U.S. FAX: (602) 786-7277 - 3. The Microchip Worldwide Web Site (www.microchip.com) Please specify which device, revision of silicon and Data Sheet (include Literature #) you are using. #### **New Customer Notification System** Register on our web site (www.microchip.com/cn) to receive the most current information on our products.