# KS24A010/020/040 # 1K/2K/4K-bit Serial EEPROM for Low Power with software write protect **Data Sheet** #### **OVERVIEW** The KS24A010/020/040 serial EEPROM has a 1,024/2,048/4,096-bit (128/256/512-byte) capacity, supporting the standard I<sup>2</sup>C™-bus serial interface. It is fabricated using Samsung's most advanced CMOS technology. It has been developed for low power and low voltage applications (1.8 V to 5.5 V). Important features are a hardware-based write protection circuit for the entire memory area and software-based write protection logic for the lower 128 bytes. Hardware-based write protection is controlled by the state of the write-protect (WP) pin. The software-based method is one-time programmable and permanent. Using one-page write mode, you can load up to 16 bytes of data into the EEPROM in a single write operation. Another significant feature of the KS24A010/020/040 is its support for fast mode and standard mode. #### **FEATURES** #### I<sup>2</sup>C-Bus Interface - Two-wire serial interface - Automatic word address increment #### **EEPROM** - 1K/2K/4K-bit (128/256/512-byte) storage area - 16-byte page buffer - Typical 3 ms write cycle time with auto-erase function - Hardware-based write protection for the entire EEPROM (using the WP pin) - Software-based write protection for the lower 128-byte EEPROM - EEPROM programming voltage generated on chip - 1,000,000 erase/write cycles - 100 years data retention #### **Operating Characteristics** - Operating voltage - 1.8 V to 5.5 V - Operating current - Maximum write current: < 3 mA at 5.5 V</p> - Maximum read current: < 200 μA at 5.5 V</li> - Maximum stand-by current: < 1 μA at 5.5 V</li> - Operating temperature range - - 25°C to + 70°C (commercial) - - 40°C to + 85°C (industrial) - Operating clock frequencies - 100 kHz at standard mode - 400 kHz at fast mode - Electrostatic discharge (ESD) - 5,000 V (HBM) - 500 V (MM) #### **Packages** 8-pin DIP, SOP, and TSSOP Figure 2-1. KS24A010/020/040 Block Diagram Figure 2-2. Pin Assignment Diagram Table 2-1. KS24A010/020/040 Pin Descriptions | Name | Туре | Description | Circuit<br>Type | |-----------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------| | A0, A1, A2 | Input | Input pins for device address selection. To configure a device address, these pins should be connected to the $V_{CC}$ or $V_{SS}$ of the device. These pins are internally pulled down to $V_{SS}$ . | 1 | | V <sub>SS</sub> | _ | Ground pin. | _ | | SDA | I/O | Bi-directional data pin for the $I^2C$ -bus serial data interface. Schmitt trigger input and open-drain output. An external pull-up resistor must be connected to $V_{CC}$ . Typical values for this pull-up resistor are 4.7 k $\Omega$ (100 kHz) and 1 k $\Omega$ (400 kHz). | 3 | | SCL | Input | Schmitt trigger input pin for serial clock input. | 2 | | WP | Input | Input pin for hardware write protection control. If you tie this pin to $V_{CC}$ , the write function is disabled to protect previously written data in the entire memory; if you tie it to $V_{SS}$ , the write function is enabled. This pin is internally pulled down to $V_{SS}$ . | 1 | | V <sub>CC</sub> | _ | Single power supply. | _ | **NOTE**: See the following page for diagrams of pin circuit types 1, 2, and 3. 2-3 Figure 2-3. Pin Circuit Type 1 Figure 2-4. Pin Circuit Type 2 Figure 2-5. Pin Circuit Type 3 #### **FUNCTION DESCRIPTION** #### I<sup>2</sup>C-BUS INTERFACE The KS24A010/020/040 supports the $I^2$ C-bus serial interface data transmission protocol. The two-wire bus consists of a serial data line (SDA) and a serial clock line (SCL). The SDA and the SCL lines must be connected to $V_{CC}$ by a pull-up resistor that is located somewhere on the bus. Any device that puts data onto the bus is defined as the "transmitter" and any device that gets data from the bus is the "receiver." The bus is controlled by a master device which generates the serial clock and start/stop conditions, controlling bus access. Using the A0,A1 and A2 input pins, up to eight KS24A010/020 (four for KS24A040) devices can be connected to the same I<sup>2</sup>C-bus as slaves (see Figure 2-6). Both the master and slaves can operate as transmitter or receiver, but the master device determines which bus operating mode would be active. Figure 2-6. Typical Configuration (16 Kbits of Memory on the I<sup>2</sup>C-Bus) #### I<sup>2</sup>C-BUS PROTOCOLS Here are several rules for I<sup>2</sup>C-bus transfers: - A new data transfer can be initiated only when the bus is currently not busy. - MSB is always transferred first in transmitting data. - During a data transfer, the data line (SDA) must remain stable whenever the clock line (SCL) is High. The I<sup>2</sup>C-bus interface supports the following communication protocols: - Bus not busy: The SDA and the SCL lines remain High level when the bus is not active. - <u>Start condition</u>: Start condition is initiated by a High-to-Low transition of the SDA line while SCL remains High level. All bus commands must be preceded by a start condition. - <u>Stop condition</u>: A stop condition is initiated by a Low-to-High transition of the SDA line while SCL remains High level. All bus operations must be completed by a stop condition (see Figure 2-7). Figure 2-7. Data Transmission Sequence - <u>Data valid</u>: Following a start condition, the data becomes valid if the data line remains stable for the duration of the High period of SCL. New data must be put onto the bus while SCL is Low. Bus timing is one clock pulse per data bit. The number of data bytes to be transferred is determined by the master device. The total number of bytes that can be transferred in one operation is theoretically unlimited. - <u>ACK (Acknowledge)</u>: An ACK signal indicates that a data transfer is completed successfully. The transmitter (the master or the slave) releases the bus after transmitting eight bits. During the 9th clock, which the master generates, the receiver pulls the SDA line low to acknowledge that it successfully received the eight bits of data (see Figure 2-8). But the slave does not send an ACK if an internal write cycle is still in progress. In data read operations, the slave releases the SDA line after transmitting 8 bits of data and then monitors the line for an ACK signal during the 9th clock period. If an ACK is detected, the slave will continue to transmit data. If an ACK is not detected, the slave terminates data transmission and waits for a stop condition to be issued by the master before returning to its stand-by mode. Figure 2-8. Acknowledge Response From Receiver - <u>Slave Address</u>: After the master initiates a Start condition, it must output the address of the device to be accessed. The most significant four bits of the slave address are called the "device identifier". The identifier for the KS24A010/020/040 is "1010B". The next three bits comprise the address of a specific device. The device address is defined by the state of the A0, A1 and A2 pins. Using this addressing scheme, you can cascade up to eight KS24A010/020 or four KS24A040 on the bus (see Table 2-2 below). The b1 is "don't care" for the KS24A040. The b1 for KS24A040 is used by the master to select which of the blocks of internal memory (1 block = 256 words) are to be accessed. The bit which is "don't care" is in effect the most significant bit of the word address. - Read/Write: The final (eighth) bit of the slave address defines the type of operation to be performed. If the R/W bit is "1", a read operation is executed. If it is "0", a write operation is executed. | | | | | | | ` | = | | |---------------|----|-------------------|----|----|----|---------------|----------------------|----| | Function | De | Device Identifier | | | [ | Device Addres | R/W Bit | | | | b7 | b6 | b5 | b4 | b3 | b2 | b1 <sup>(note)</sup> | b0 | | Read | 1 | 0 | 1 | 0 | A2 | A1 | A0 | 1 | | Write | 1 | 0 | 1 | 0 | A2 | A1 | A0 | 0 | | Write-protect | 0 | 1 | 1 | 0 | A2 | A1 | A0 | 0 | Table 2-2. Slave Device Addressing NOTE: The b1 is don't care for the KS24A040 2-7 #### **BYTE WRITE OPERATION** In a complete byte write operation, the master transmits the slave address, word address, and one data byte to the KS24A010/020/040 slave device (see Figure 2-9). Figure 2-9. Byte Write Operation Following the Start condition, the master sends the device identifier (4 bits), the device address (3 bits), and an R/W bit set to "0" onto the bus. Then the addressed KS24A010/020/040 generates an ACK and waits for the next byte. The next byte to be transmitted by the master is the word address. This 8-bit address is written into the word address pointer of the KS24A010/020/040. When the KS24A010/020/040 receives the word address, it responds by issuing an ACK and then waits for the next 8-bit data. When it receives the data byte, the KS24A010/020/040 again responds with an ACK. The master terminates the transfer by generating a Stop condition, at which time the KS24A010/020/040 begins the internal write cycle. While the internal write cycle is in progress, all KS24A010/020/040 inputs are disabled and the KS24A010/020/040 does not respond to additional requests from the master. #### **PAGE WRITE OPERATION** The KS24A010/020/040 can also perform 16-byte page write operation. A page write operation is initiated in the same way as a byte write operation. However, instead of finishing the write operation after the first data byte is transferred, the master can transmit up to 15 additional bytes. The KS24A010/020/040 responds with an ACK each time it receives a complete byte of data (see Figure 2-10). Figure 2-10. Page Write Operation The KS24A010/020/040 automatically increments the word address pointer each time it receives a complete data byte. When one byte has been received, the internal word address pointer increments to the next address and the next data byte can be received. If the master transmits more than 16 bytes before it generates a stop condition to end the page write operation, the KS24A010/020/040 word address pointer value "rolls over" and the previously received data is overwritten. If the master transmits less than 16 bytes and generates a stop condition, the KS24A010/020/040 writes the received data to the corresponding EEPROM address. During a page write operation, all inputs are disabled and there is no response to additional requests from the master until the internal write cycle is completed. #### **POLLING FOR AN ACK SIGNAL** When the master issues a stop condition to initiate a write cycle, the KS24A010/020/040 starts an internal write cycle. The master can then immediately begin polling for an ACK from the slave device. To poll for an ACK signal in a write operation, the master issues a start condition followed by the slave address. As long as the KS24A010/020/040 remains busy with the write operation, no ACK is returned. When the KS24A010/020/040 completes the write operation, it returns an ACK and the master can then proceed with the next read or write operation (see Figure 2-11). Figure 2-11. Master Polling for an ACK Signal from a Slave Device #### **SOFTWARE-BASED WRITE PROTECTION** You can write-protect the lower 128 bytes of the EEPROM, locations 00H–7FH, in one operation. To do this, you simply write a value to a one-time, write-only register. Once you have applied this write protection, any write attempt to access the lower 128-byte area is ignored. In other words, the write protection is permanent. The effect of such a failed attempt is processed in the same way as an invalid I<sup>2</sup>C-bus protocol. To enable write protection, you must execute a write operation to the write protection register. To access the write protection register, you use the device address "0110". The word address and data in this write operation can be any value and the timing and wave form characteristics are identical to a normal byte write operation (see Figure 2-12). Figure 2-12. Write Protection Operation #### HARDWARE-BASED WRITE PROTECTION You can also write-protect the entire memory area of the KS24A010/020/040. This method of write protection is controlled by the state of the Write Protect (WP) pin. When the WP pin is connected to V<sub>CC</sub>, any attempt to write a value to the memory is ignored. The KS24A010/020/040 will acknowledge slave and word address, but it will not generate an acknowledge after receiving the first byte of the data. Thus the write cycle will not be started when the stop condition is generated. By connecting the WP pin to $V_{SS}$ , the write function is allowed for the entire memory. These write protection features effectively change the EEPROM to a ROM in order to prevent data from being overwritten. Whenever the write function is disabled, a slave address and a word address are acknowledged on the bus, but data bytes are not acknowledged. #### **CURRENT ADDRESS BYTE READ OPERATION** The internal word address pointer maintains the address of the last word accessed, incremented by one. Therefore, if the last access (either read or write) was to the address "n", the next read operation would access data at address "n+1". When the KS24A010/020/040 receives a slave address with the R/W bit set to "1", it issues an ACK and sends the eight bits of data. The master does not acknowledge the transfer but it does generate a Stop condition. In this way, the KS24A010/020/040 effectively stops the transmission (see Figure 2-13). Figure 2-13. Current Address Byte Read Operation #### **RANDOM ADDRESS BYTE READ OPERATION** Using random read operations, the master can access any memory location at any time. Before it issues the slave address with the R/W bit set to "1", the master must first perform a "dummy" write operation. This operation is performed in the following steps: - 1. The master first issues a Start condition, the slave address, and the word address to be read. (This step sets the internal word address pointer of the KS24A010/020/040 to the desired address.) - 2. When the master receives an ACK for the word address, it immediately re-issues a start condition followed by another slave address, with the R/W bit set to "1". - 3. The KS24A010/020/040 then sends an ACK and the 8-bit data stored at the desired address. - 4. At this point, the master does not acknowledge the transmission, but generates a stop condition instead. - 5. In response, the KS24A010/020/040 stops transmitting data and reverts to its stand-by mode (see Figure 2-14). Figure 2-14. Random Address Byte Read Operation #### **SEQUENTIAL READ OPERATION** Sequential read operations can be performed in two ways: as a series of current address reads or as random address reads. The first data is sent in the same way as the previous read mode used on the bus. The next time, however, the master responds with an ACK, indicating that it requires additional data. The KS24A010/020/040 continues to output data for each ACK it receives. To stop the sequential read operation, the master does not respond with an ACK, but instead issues a Stop condition. Using this method, data is output sequentially with the data from address "n" followed by the data from "n+1". The word address pointer for read operations increments all word addresses, allowing the entire EEPROM to be read sequentially in a single operation. After the entire EEPROM is read, the word address pointer "rolls over" and the KS24A010/020/040 continues to transmit data for each ACK it receives from the master (see Figure 2-15). Figure 2-15. Sequential Read Operation ## **ELECTRICAL DATA** **Table 2-3. Absolute Maximum Ratings** $(T_A = 25^{\circ}C)$ | Parameter | Symbol | Conditions | Rating | Unit | |-------------------------|------------------|------------|----------------|------| | Supply voltage | V <sub>cc</sub> | _ | -0.3 to $+7.0$ | V | | Input voltage | V <sub>IN</sub> | _ | -0.3 to $+7.0$ | V | | Output voltage | Vo | _ | -0.3 to $+7.0$ | V | | Operating temperature | T <sub>A</sub> | _ | - 40 to + 85 | °C | | Storage temperature | T <sub>STG</sub> | _ | - 65 to + 150 | °C | | Electrostatic discharge | V <sub>ESD</sub> | НВМ | 5000 | V | | | | MM | 500 | 1 | ### **Table 2-4. D.C. Electrical Characteristics** $(T_A = -25^{\circ}C \text{ to} + 70^{\circ}C \text{ (C)}, -40^{\circ}C \text{ to} + 85^{\circ}C \text{ (I)}, V_{CC} = 1.8 \text{ V to } 5.5 \text{ V)}$ | Paramet | ter | Symbol | Conditions | Min | Тур | Max | Unit | |------------------------|-------|------------------|-------------------------------------------------|---------------------|-----|---------------------|------| | Input low voltage | | V <sub>IL</sub> | SCL, SDA, A0, A1, A2 | _ | _ | 0.3 V <sub>CC</sub> | V | | Input high voltage | | V <sub>IH</sub> | | 0.7 V <sub>CC</sub> | _ | _ | V | | Input leakage current | | I <sub>LI</sub> | $V_{IN} = 0$ to $V_{CC}$ | _ | _ | 10 | μA | | Output leakage current | | I <sub>LO</sub> | $V_O = 0$ to $V_{CC}$ | _ | _ | 10 | μA | | Output low voltage | | V <sub>OL</sub> | $I_{OL} = 3 \text{ mA}, V_{CC} = 2.5 \text{ V}$ | _ | _ | 0.4 | V | | Supply current | Write | I <sub>CC1</sub> | V <sub>CC</sub> = 5.5 V, 400 kHz | _ | _ | 3 | mA | | | | I <sub>CC2</sub> | V <sub>CC</sub> = 1.8 V, 100 kHz | _ | _ | 1 | | | | Read | I <sub>CC3</sub> | V <sub>CC</sub> = 5.5 V, 400 kHz | _ | _ | 0.2 | | | | | I <sub>CC4</sub> | V <sub>CC</sub> = 1.8 V, 100 kHz | _ | _ | 60 | μA | | Stand-by current | | I <sub>CC5</sub> | $V_{CC} = SDA = SCL = 5.5 V,$ | _ | _ | 1 | μA | | | | | all other inputs = 0 V | | | | | | | | I <sub>CC6</sub> | $V_{CC} = SDA = SCL = 1.8 V,$ | _ | _ | 1 | | | | | | all other inputs = 0 V | | | | | Table 2-4. D.C. Electrical Characteristics (Continued) $(T_A = -25^{\circ}C \text{ to} + 70^{\circ}C \text{ (C)}, -40^{\circ}C \text{ to} + 85^{\circ}C \text{ (I)}, V_{CC} = 1.8 \text{ V to } 5.5 \text{ V)}$ | Parameter | Symbol | Conditions | Min | Тур | Max | Unit | |--------------------------|------------------|------------------------------------------------------------------------------------------------------------|-----|-----|-----|------| | Input capacitance | C <sub>IN</sub> | 25 °C, 1MHz,<br>V <sub>CC</sub> = 5 V, V <sub>IN</sub> = 0 V,<br>A0, A1, A2, SCL and WP pin | - | - | 10 | pF | | Input/output capacitance | C <sub>I/O</sub> | $25 ^{\circ}\text{C}$ , 1MHz,<br>$V_{\text{CC}} = 5 \text{V}$ , $V_{\text{I/O}} = 0 \text{V}$ ,<br>SDA pin | - | - | 10 | | ### Table 2-5. A.C. Electrical Characteristics $(T_A = -25^{\circ}C \text{ to} + 70^{\circ}C (C), -40^{\circ}C \text{ to} + 85^{\circ}C (I), V_{CC} = 1.8 \text{ V to } 5.5 \text{ V})$ | Parameter | Symbol | Conditions | V <sub>CC</sub> = 1.8 to 5.5 V<br>(Standard Mode) | | V <sub>CC</sub> = 2.5 to 5.5 V<br>(Fast Mode) | | Unit | |----------------------------------------------------|---------------------|-------------------------|---------------------------------------------------|-----|-----------------------------------------------|-----|------| | | | | Min | Max | Min | Max | | | External clock frequency | F <sub>CLK</sub> | - | 0 | 100 | 0 | 400 | kHz | | Clock high time | t <sub>HIGH</sub> | _ | 4 | _ | 0.6 | _ | μs | | Clock low time | t <sub>LOW</sub> | _ | 4.7 | _ | 1.3 | _ | | | Rising time | t <sub>R</sub> | SDA, SCL | _ | 1 | - | 0.3 | | | Falling time | t <sub>F</sub> | SDA, SCL | _ | 0.3 | - | 0.3 | | | Start condition hold time | t <sub>HD:STA</sub> | _ | 4 | _ | 0.6 | _ | | | Start condition setup time | t <sub>SU:STA</sub> | - | 4.7 | _ | 0.6 | _ | | | Data input hold time | t <sub>HD:DAT</sub> | - | 0 | _ | 0 | _ | | | Data input setup time | t <sub>SU:DAT</sub> | - | 0.25 | _ | 0.1 | _ | | | Stop condition setup time | t <sub>SU:STO</sub> | - | 4 | _ | 0.6 | _ | | | Bus free time | t <sub>BUF</sub> | Before new transmission | 4.7 | _ | 1.3 | _ | | | Data output valid from clock low <sup>(note)</sup> | t <sub>AA</sub> | _ | 0.3 | 3.5 | _ | 0.9 | | | Noise spike width | t <sub>SP</sub> | _ | _ | 100 | _ | 50 | ns | | Write cycle time | t <sub>WR</sub> | _ | _ | 5 | _ | 5 | ms | **NOTE**: When acting as a transmitter, the KS24A010/020/040 must provide an internal minimum delay time to bridge the undefined period (minimum 300 ns) of the falling edge of SCL. This is required to avoid unintended generation of a start or stop condition. Figure 2-16. Timing Diagram for Bus Operations Figure 2-17. Write Cycle Timing Diagram ## **NOTES**