# 24C01A/02A/04A # 1K/2K/4K 5.0V I<sup>2</sup>CTM Serial EEPROMs #### **FEATURES** - · Low power CMOS technology - · Hardware write protect - Two wire serial interface bus, PC™ compatible - · 5.0V only operation - · Self-timed write cycle (including auto-erase) - · Page-write buffer - . 1ms write cycle time for single byte - 1,000,000 Erase/Write cycles guaranteed - · Data retention >200 years - · 8-pin DIP/SOIC packages - · Available for extended temperature ranges - Commercial (C): 0°C to +70°C - Industrial (I): -40°C to +85°C - Automotive (E): -40°C to +125°C #### DESCRIPTION The Microchip Technology Inc. 24C01A/02A/04A is a 1K/2K/4K bit Electrically Erasable PROM. The device is organized as shown, with a standard two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. A special feature in the 24C02A and 24C04A provides hardware write protection for the upper half of the block. The 24C01A and 24C02A have a page length of eight of two bytes and the 24C04A has a page length of eight bytes. Up to eight 24C01A or 24C02A devices and up to four 24C04A devices may be connected to the same two wire bus. This device offers fast (1ms) byte write and extended (-40°C to 125°C) temperature operation. It is recommended that all other applications use Microchip's 24LCXXB. | | 24C01A | 24C02A | 24C04A | |----------------------|---------|---------|-------------| | Organization | 128 x 8 | 258 x 8 | 2 x 256 x 8 | | Write Protect | None | 080-0FF | 100-1FF | | Page Write<br>Buffer | 2 Bytes | 2 Bytes | 8 Bytes | #### **PACKAGE TYPES** #### **BLOCK DIAGRAM** I<sup>2</sup>C is a trademark of Philips Corporation. ## 1.0 ELECTRICAL CHARACTERISTICS #### 1.1 Maximum Ratings\* | Vcc | 7.0V | |-------------------------------------------|-------------------| | All inputs and outputs w.r.t. Vss | 0.6V to Vcc +1.0V | | Storage temperature | | | Ambient temp. with power applied | | | 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 | |------------|--------------------------------------------------------------| | AO | No Function for 24C04A only, Must be connected to Vcc or Vss | | A0, A1, A2 | Chip Address Inputs | | Vss | Ground | | SDA | Serial Address/Data I/O | | SCL | Serial Clock | | TEST | (24C01A only) Vcc or Vss | | WP | Write Protect Input | | Vcc | +5V Power Supply | TABLE 1-2: DC CHARACTERISTICS | Industrial (I): Tamb | | | | 0 = 0°C to +70°C<br>0 = -40°C to +85°C<br>0 = -40°C to +125°C | | | |---------------------------------------------------------------------------------------------|-------------------|-------------------|-----------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------|--| | Parameter | Symbol | Min. | Max. | Units | Conditions | | | Vcc detector threshold | VTH | 2.8 | 4.5 | ٧ | | | | SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH<br>VIL<br>VOL | Vcc x 0.7<br>-0.3 | Vcc + 1<br>Vcc x 0.3<br>0.4 | > > > | IOL = 3.2 mA (SDA only) | | | A1 & A2 pins:<br>High level input voltage<br>Low level input voltage | VIH<br>VIL | Vcc - 0.5<br>-0.3 | Vcc + 0.5<br>0.5 | V<br>V | | | | Input leakage current | lu | _ | 10 | μA | Vin = 0V to Vcc | | | Output leakage current | ILO | | 10 | μA | Vout = 0V to Vcc | | | Pin capacitance (all inputs/outputs) | Cin,<br>Cout | _ | 7.0 | pF | VIN/VOUT = 0V (Note) Tamb = +25°C, f = 1 MHz | | | Operating current | Icc Write | | 3.5 | mA | FCLK = 100 kHz, program cycle time = 1 ms,<br>Vcc = 5V, Tamb = 0°C to +70°C | | | | Icc Write | _ | 4.25 | mA | FCLK = 100 kHz, program cycle time = 1 ms, Vcc = 5V, Tamb = (I) and (E) | | | | icc<br>Read | _ | 750 | μA | Vcc = 5V, Tamb= (C), (I) and (E) | | | Standby current | Iccs | _ | 100 | μΑ | SDA=SCL=Vcc=5V (no PROGRAM active) | | Note: This parameter is periodically sampled and not 100% tested FIGURE 1-1: BUS TIMING START/STOP TABLE 1-3: AC CHARACTERISTICS | Parameter | Symbol | Min. | Тур | Max. | Units | Remarks | |-----------------------------------------------|---------|------------|----------|------|--------|---------------------------------------------------------------| | Clock frequency | Fclk | | <u> </u> | 100 | kHz | | | Clock high time | THIGH | 4000 | | _ | ns | | | Clock low time | TLOW | 4700 | | | ns | | | SDA and SCL rise time | TR | _ | T — | 1000 | ns | | | SDA and SCL fall time | TF | _ | | 300 | ns | | | START condition hold time | THD:STA | 4000 | | _ | ns | After this period the first clock pulse is generated | | START condition setup time | Tsu:Sta | 4700 | _ | _ | ns | Only relevant for repeated START condition | | Data input hold time | THD:DAT | 0 | — | | ns | | | Data input setup time | Tsu:Dat | 250 | T — | | ns | | | Data output delay time | TAA | 300 | _ | 3500 | | (Note 1) | | STOP condition setup time | Tsu:Sto | 4700 | | | ns | | | Bus free time | TBUF | 4700 | _ | | ns | Time the bus must be free before a new transmission can start | | Input filter time constant (SDA and SCL pins) | Tı | _ | _ | 100 | ns | | | Program cycle time | Twc | _ | .4 | 1 | ms | Byte mode | | | | | .4N | N | ms | Page mode, N=# of bytes | | Endurance | _ | 1 <b>M</b> | _ | _ | cycles | 25°C, Vcc = 5.0V, Block<br>Mode (Note 2) | Note 1: As transmitter the device must provide this 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. 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 BBS or website. FIGURE 1-2: BUS TIMING DATA #### 2.0 FUNCTIONAL DESCRIPTION The 24C01A/02A/04A supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as 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 24C01A/02A/04A works as slave. Both master and slave can operate as transmitter or receiver but the master device determines which mode is activated. Up to eight 24C01/24c02s can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Up to four 24C04As can be connected to the bus, selected by A1 and A2 chip address inputs. A0 must be tied to Vcc or Vss for the 24C04A. Other devices can be connected to the bus but require different device codes than the 24C01A/02A/04A (refer to section Slave Address). #### 3.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 3-1). #### 3.1 Bus not Busy (A) Both data and clock lines remain HIGH. #### 3.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.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. #### 3.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. #### 3.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 24C01A/02A/04A 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. #### 4.0 SLAVE ADDRESS The chip address inputs A0, A1 and A2 of each 24C01A/ 02A/04A must be externally connected to either Vcc or ground (Vss), assigning to each 24C01A/02A/04A a unique address. A0 is not used on the 24C04A and must be connected to either Vcc or Vss. Up to eight 24C01A or 24C02A devices and up to four 24C04A devices may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the slave address to the corresponding hard-wired logic levels of the selected 24C01A/02A/04A. After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 24C01A/02A/04A, followed by the chip address bits A0, A1 and A2. In the 24C04A, the seventh bit of that byte (A0) is used to select the upper block (addresses 100-1FF) or the lower block (addresses 000-OFF) of the array. The eighth bit of slave address determines if the master device wants to read or write to the 24C01A/02A/04A (Figure 4-1). The 24C01A/02A/04A 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. FIGURE 4-1: SLAVE ADDRESS ALLOCATION # 5.0 BYTE PROGRAM MODE In this mode, the master sends addresses and one data byte to the 24C01A/02A/04A. Following the START signal from the master, the device code (4-bits), the slave address (3-bits), and the $R\overline{\it W}$ bit, which is logic LOW, are placed onto the bus by the master. This indicates to the addressed 24C01A/02A/04A that a byte with a word address will follow after it has generated an acknowledge bit. Therefore the next byte transmitted by the master is the word address and will be written into the address pointer of the 24C01A/02A/04A. After receiving the acknowledge of the 24C01A/02A/04A, the master device transmits the data word to be written into the addressed memory location. The 24C01A/02A/04A acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 24C01A/02A/04A (Figure 6-1). #### 6.0 PAGE PROGRAM MODE To program the 24C01A/02A/04A, the master sends addresses and data to the 24C01A/02A/04A which is the slave (Figure 6-1 and Figure 6-2). This is done by supplying a START condition followed by the 4-bit device code, the 3-bit slave address, and the R/W bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 24C01A/02A/04A, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (The A0 bit transmitted with the slave address is the ninth bit of the address pointer for the 24C04A). The 24C01A/02A/04A will generate an acknowledge after every 8-bits received and store them consecutively in a RAM buffer until a STOP condition is detected. This STOP condition initiates the internal programming cycle. The RAM buffer is 2 bytes for the 24C01A/02A and 8 bytes for the 24C04A. If more than 2 bytes are transmitted by the master to the 24C01A/02A, the device will not acknowledge the data transfer and the sequence will be aborted. If more than 8 bytes are transmitted by the master to the 24C04A, it will roll over and overwrite the data beginning with the first received byte. This does not affect erase/write cycles of the EEPROM array and is accomplished as a result of only allowing the address registers bottom 3 bits to increment while the upper 5 bits remain unchanged. If the master generates a STOP condition after transmitting the first data word (Point 'P' on Figure 6-1), byte programming mode is entered. The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received data bytes in the page buffer will be written in a serial manner. The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes (N max = 8 for 24C04A, 2 for 24C01A/02A). ### FIGURE 6-2: PAGE WRITE ## 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/\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 7-1 for flow diagram. FIGURE 7-1: ACKNOWLEDGE POLLING FLOW #### 8.0 WRITE PROTECTION Programming of the upper half of the memory will not take place if the WP pin of the 24C02A or 24C04A is connected to Vcc (+5.0V). The device will accept slave and word addresses but if the memory accessed is write protected by the WP pin, the 24C02A/04A will not generate an acknowledge after the first byte of data has been received, and thus the program cycle will not be started when the STOP condition is asserted. Polarity of the WP pin has no effect on the 24C01A. #### 9.0 READ MODE This mode illustrates master device reading data from the 24C01A/02A/04A. As can be seen from Figure 9-2 and Figure 9-3, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to). During this period the 24C01A/02A/04A generates the necessary acknowledge bits as defined in the appropriate section. The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pin, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This auto-increment sequence is only aborted when the master sends a STOP condition instead of an acknowledge. Note 1: If the master knows where the address pointer is, it can begin the read sequence at the current address (Figure 9-1) and save time transmitting the slave and word addresses. Note 2: In all modes, the address pointer will not increment through a block (256 byte) boundary, but will rotate back to the first location in that block. FIGURE 9-1: CURRENT ADDRESS READ FIGURE 9-2: RANDOM READ #### 10.0 PIN DESCRIPTION #### 10.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. For 24C04 A0 is no function. Up to eight 24C01A/02A's or up to four 24C04A's can be connected to the bus. These inputs must be connected to either Vss or Vcc. #### 10.2 SDA Serial Address/Data Input/Output 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 $10K\Omega$ ). 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. #### 10.3 SCL Serial Clock This input is used to synchronize the data transfer from and to the device. #### 10.4 WP Write Protection This pin must be connected to either Vcc or Vss for 24C02A or 24C04A. It has no effect on 24C01A. If tied to Vcc, PROGRAM operations onto the upper memory block will not be executed. Read operations are possible. If tied to Vss, normal memory operation is enabled (read/write the entire memory). This feature allows the user to assign the upper half of the memory as ROM which can be protected against accidental programming. When write is disabled, slave address and word address will be acknowledged but data will not be acknowledged. Note 1: A "page" is defined as the maximum number of bytes that can be programmed in a single write cycle. The 24C04A page is 8 bytes long; the 24C01A/02A page is 2 bytes long. Note 2: A "block" is defined as a continuous area of memory with distinct boundaries. The address pointer can not cross the boundary from one block to another. It will however, wrap around from the end of a block to the first location in the same block. The 24C04A has two blocks, 256 bytes each. The 24C01A and 24C02A each have only one block. NOTES: # PAGE(S) INTENTIONALLY BLANK #### 24C01A/02A/04A 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.