### M14256 M14128 # Memory Card IC 256/128 Kbit Serial I<sup>2</sup>C Bus EEPROM PRELIMINARY DATA - Compatible with I<sup>2</sup>C Extended Addressing - Two Wire I<sup>2</sup>C Serial Interface Supports 400 kHz Protocol - Single Supply Voltage (2.5 V to 5.5 V) - Hardware Write Control - BYTE and PAGE WRITE (up to 64 Bytes) - BYTE, RANDOM and SEQUENTIAL READ Modes - Self-Timed Programming Cycle - Automatic Address Incrementing - Enhanced ESD/Latch-Up Behaviour - 100,000 Erase/Write Cycles (minimum) - 40 Year Data Retention (minimum) - 5 ms Programming Time (typical) #### **DESCRIPTION** Each device is an electrically erasable programmable memory (EEPROM) fabricated with STMicroelectronics's High Endurance, Double Polysilicon, CMOS technology. This guarantees an endurance typically well above 100,000 Erase/Write cycles, with a data retention of 40 years. The memory operates with a power supply as low as 2.5 V. The M14256 and M14128 are available in micromodule form only. For availability of the M14256 or **Table 1. Signal Names** | SDA | Serial Data/Address Input/<br>Output | |-----------------|--------------------------------------| | SCL | Serial Clock | | WC | Write Control | | V <sub>CC</sub> | Supply Voltage | | GND | Ground | Figure 1. Logic Diagram October 1999 1/12 Figure 2. D22 Contact Connections M14128 in wafer form, please contact your ST sales office. Each memory device is compatible with the I<sup>2</sup>C extended memory standard. This is a two wire serial interface that uses a bi-directional data bus and serial clock. The memory device carries a built-in 7-bit unique Device Type Identifier code (1010000) in accordance with the I<sup>2</sup>C bus definition. Only one memory device can be attached to each I<sup>2</sup>C bus. The memory device behaves as a slave device in the $I^2C$ protocol, with all memory operations synchronized by the serial clock. Read and write operations are initiated by a START condition, generated by the bus master. The START condition is followed by the Device Select Code which is composed of a stream of 7 bits (1010000), plus one read/write bit (R/W) and is terminated by an acknowledge bit. When writing data to the memory, the memory device inserts an acknowledge bit during the 9<sup>th</sup> bit time, following the bus master's 8-bit transmission. When data is read by the bus master, the bus master acknowledges the receipt of the data byte in the same way. Data transfers are terminated by a STOP condition after an Ack for WRITE, and after a NoACK for READ. #### Power On Reset: V<sub>CC</sub> Lock-Out Write Protect In order to prevent data corruption and inadvertent write operations during power up, a Power On Reset (POR) circuit is included. The internal reset is held active until the $V_{CC}$ voltage has reached the POR threshold value, and all operations are disabled – the device will not respond to any command. In the same way, when $V_{CC}$ drops from the operating voltage, below the POR threshold value, all operations are disabled and the device will not respond to any command. A stable and valid $V_{CC}$ must be applied before applying any logic signal. ## SIGNAL DESCRIPTION Serial Clock (SCL) The SCL input pin is used to synchronize all data in and out of the memory. A pull up resistor can be connected from the SCL line to $V_{CC}$ . (Figure 3 indicates how the value of the pull-up resistor can be calculated). #### Serial Data (SDA) The SDA pin is bi-directional, and is used to transfer data in or out of the memory. It is an open drain output that may be wire-OR'ed with other open drain or open collector signals on the bus. A pull up resistor must be connected from the SDA bus to $V_{CC}$ . (Figure 3 indicates how the value of the pull-up resistor can be calculated). Table 2. Absolute Maximum Ratings <sup>1</sup> | Symbol | Parameter | Value | Unit | |------------------|-----------------------------------------------------------------|-------------|------| | T <sub>A</sub> | Ambient Operating Temperature | 0 to 70 | °C | | T <sub>STG</sub> | Storage Temperature | -40 to 120 | °C | | V <sub>IO</sub> | Input or Output range | -0.6 to 6.5 | V | | V <sub>CC</sub> | Supply Voltage | -0.3 to 6.5 | V | | \/ | Electrostatic Discharge Voltage (Human Body model) <sup>2</sup> | 4000 | V | | $V_{ESD}$ | Electrostatic Discharge Voltage (Machine model) <sup>3</sup> | 400 | V | Note: 1. Except for the rating "Operating Temperature Range", stresses above those listed in the Table "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and operation of the device at these or any other conditions above those indicated in the Operating sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods may affect device reliability. Refer also to the ST SURE Program and other relevant quality documents. - 2. MIL-STD-883C, 3015.7 (100 pF, 1500 Ω) - 3. EIAJ IC-121 (Condition C) (200 pF, 0 $\Omega)$ ### Write Control (WC) The hardware Write Control contact ( $\overline{WC}$ ) is useful for protecting the entire contents of the memory from inadvertent erase/write. The Write Control signal is used to enable ( $\overline{WC}=V_{IL}$ ) or disable ( $\overline{WC}=V_{IH}$ ) write instructions to the entire memory area. When unconnected, the $\overline{WC}$ input is internally read as $V_{IL}$ and write operations are allowed. When $\overline{WC}$ =1, Device Select and Address bytes are acknowledged, Data bytes are not acknowledged. Please see the Application Note *AN404* for a more detailed description of the Write Control feature. #### **DEVICE OPERATION** The memory device supports the XI<sup>2</sup>C (Extended I<sup>2</sup>C) protocol, as summarized in Figure 4. Any device that sends data on to the bus is defined to be a transmitter, and any device that reads the data to be a receiver. The device that controls the data transfer is known as the master, and the other as the slave. A data transfer can only be initiated by the master, which will also provide the serial clock for synchronization. The memory device is always a slave device in all communication. #### **Start Condition** START is identified by a high to low transition of the SDA line while the clock, SCL, is stable in the high state. A START condition must precede any data transfer command. The memory device continuously monitors (except during a programming cycle) the SDA and SCL lines for a START condition, and will not respond unless one is given. #### **Stop Condition** STOP is identified by a low to high transition of the SDA line while the clock, SCL, is stable in the high state. A STOP condition terminates communication between the memory device and the bus master. A STOP condition at the end of a Read command, after (and only after) a NoACK, forces the memory device into its standby state. A STOP condition at the end of a Write command triggers the internal EEPROM write cycle. #### Acknowledge Bit (ACK) An acknowledge signal is used to indicate a successful data transfer. The bus transmitter, either master or slave, will release the SDA bus after sending 8 bits of data. During the 9<sup>th</sup> clock pulse period the receiver pulls the SDA bus low to acknowledge the receipt of the 8 data bits. #### **Data Input** During data input, the memory device samples the SDA bus signal on the rising edge of the clock, SCL. For correct device operation, the SDA signal must be stable during the clock low-to-high transition, and the data must change *only* when the SCL line is low. #### **Memory Addressing** To start communication between the bus master and the slave memory, the master must initiate a START condition. Following this, the master sends 8 bits to the SDA bus line (with the most significant bit first). These bits represent the Device Select Code (7 bits) and a $\overline{RW}$ bit. The seven most significant bits of the Device Select Code are the Device Type Identifier, according to the I<sup>2</sup>C bus definition. For the memory device, the seven bits are fixed at 1010000b (A0h), as shown in Table 5. The $8^{th}$ bit is the read or write bit ( $R\overline{W}$ ). This bit is set to '1' for read and '0' for write operations. If a match occurs on the Device Select Code, the cor- responding memory gives an acknowledgment on the SDA bus during the 9<sup>th</sup> bit time. If the memory does not match the Device Select code, it will deselect itself from the bus, and go into stand-by mode. Each data byte in the memory has a 16-bit (two byte wide) address. The Most Significant Byte (Table 3) is sent first, followed by the Least significant Byte (Table 4). Bits b15 to b0 form the address of the byte in memory. Bit b15 is treated as a Don't Care bit on the M14256 memory. Bits b15 and b14 are treated as Don't Care bits on the M14128 memory. #### **Table 3. Most Significant Byte** | b15 | b14 | b13 | b12 | b11 | b10 | b9 | b8 | |-----|-----|-----|-----|-----|-----|----|----| Note: 1. b15 is Don't Care on the M14256 series. b15 and b14 are Don't Care on the M14128 series. ### **Table 4. Least Significant Byte** | b7 b6 b5 b4 b3 b2 b1 b0 | |-------------------------| |-------------------------| Table 5. Device Select Code 1 | | Device Code | | | | Chip Enable | | | R₩ | |---------------|-------------|----|----|----|-------------|----|----|----| | | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | | Device Select | 1 | 0 | 1 | 0 | 0 | 0 | 0 | R₩ | Note: 1. The most significant bit, b7, is sent first. #### **Write Operations** Following a START condition the master sends a Device Select code with the $R\overline{W}$ bit set to '0', as shown in Table 6. The memory acknowledges it and waits for two bytes of address, which provides access to the memory area. After receipt of each byte address, the memory again responds with an acknowledge and waits for the data byte. Writing in the memory may be inhibited if the input pin $\overline{WC}$ is taken high. Any write command with $\overline{WC}$ =1 (during a period of time from the START condition until the end of the two bytes address) will not modify the memory content and will NOT be acknowledged on data bytes, as shown in Figure 5. #### **Byte Write** In the Byte Write mode, after the Device Select code and the address, the master sends one data byte. If the addressed location is write protected by the $\overline{WC}$ pin, the memory replies with a NoACK, and the location is not modified. If, instead, the $\overline{WC}$ pin has been held at 0, as shown in Figure 6, the memory replies with an ACK. The master terminates the transfer by generating a STOP condition. #### **Page Write** The Page Write mode allows up to 64 bytes to be written in a single write cycle, provided that they are all located in the same 'row' in the memory: that is the most significant memory address bits (b14-b6 for the M14256 and b13-b6 for the M14128) are the same. The master sends from one up to 64 bytes of data, each of which is acknowledged by the memory if the WC pin is low. If the WC pin is high, each data byte is followed by a NoACK and the location is not modified. After each byte is transferred, the internal byte address counter (the six least significant bits only) is incremented. The transfer is terminated by the master generating a STOP condition. Care must be taken to avoid address counter 'roll-over' which could result in data being overwritten. Note that, for any Figure 5. Write Mode Sequences with WC=1 **Table 6. Operating Modes** | Mode | R₩ bit | WC 1 | Bytes | Initial Sequence | |----------------------|--------|-----------------|-------|------------------------------------------------------| | Current Address Read | '1' | Х | 1 | START, Device Select, RW = '1' | | Random Address Read | ,0, | Х | | START, Device Select, $R\overline{W}$ = '0', Address | | Random Address Read | '1' | Х | 1 | reSTART, Device Select, RW = '1' | | Sequential Read | '1' | Х | ≥ 1 | Similar to Current or Random Mode | | Byte Write | ,0, | V <sub>IL</sub> | 1 | START, Device Select, RW = '0' | | Page Write | ,0, | V <sub>IL</sub> | ≤ 64 | START, Device Select, RW = '0' | Note: 1. $X = V_{IH} \text{ or } V_{IL}$ . Figure 6. Write Mode Sequences with WC=0 byte or page write mode, the generation by the master of the STOP condition starts the internal memory program cycle. This STOP condition triggers an internal memory program cycle only if the STOP condition is internally decoded immediately after the ACK bit; any STOP condition decoded out of this "10<sup>th</sup> bit" time slot will not trigger the internal programming cycle. All inputs are disabled until the completion of this cycle and the Memory will not respond to any request. Figure 7. Write Cycle Polling Flowchart using ACK #### Minimizing System Delays by Polling On ACK During the internal write cycle, the memory disconnects itself from the bus, and copies the data from its internal latches to the memory cells. The maximum write time $(t_w)$ is indicated in Table 7, but the typical time is shorter. To make use of this, an ACK polling sequence can be used by the master. The sequence, as shown in Figure 7, is as follows: - Initial condition: a Write is in progress. - Step 1: the master issues a START condition followed by a device select byte (first byte of the new instruction). - Step 2: if the memory is busy with the internal write cycle, no ACK will be returned and the master goes back to Step 1. If the memory has terminated the internal write cycle, it responds with an ACK, indicating that the memory is ready to receive the second part of the next instruction (the first byte of this instruction having been sent during Step 1). #### **Read Operations** Read operations are independent of the state of the WC pin. On delivery, the memory content is set at all "1's" (FFh). #### **Current Address Read** The memory has an internal address counter. Each time a byte is read, this counter is incremented. For the Current Address Read mode, following a START condition, the master sends a device select with the $R\overline{W}$ bit set to '1'. The memory acknowledges this, and outputs the byte addressed by the internal address counter. The counter is then incremented. The master must *not* acknowledge the byte output, and terminates the transfer with a STOP condition, as shown in Figure 8. #### **Random Address Read** A dummy write is performed to load the address into the address counter, as shown in Figure 8. This is followed by another START condition from the master and the device select is repeated with Figure 8. Read Mode Sequences Note: 1. The seven most significant bits of the Device Select bytes of a Random Read (in the 1<sup>st</sup> and 4<sup>th</sup> bytes) must be identical. the $R\overline{W}$ bit set to '1'. The memory acknowledges this, and outputs the byte addressed. The master must *not* acknowledge the byte output, and terminates the transfer with a STOP condition. #### Sequential Read This mode can be initiated with either a Current Address Read or a Random Address Read. However, in this case the master *does* acknowledge the data byte output, and the memory continues to output the next byte in sequence. To terminate the stream of bytes, the master must *not* acknowledge the last byte output, and *must* generate a STOP condition. The output data comes from consecu- tive addresses, with the internal address counter automatically incremented after each byte output. After the last memory address, the address counter will 'roll-over' and the memory will continue to output data from the start of the memory block. #### Acknowledge in Read Mode In all read modes the memory waits for an acknowledgment during the 9<sup>th</sup> bit time. If the master does not pull the SDA line low during this time, the memory terminates the data transfer and switches to its standby state. **Table 7. AC Characteristics** $(T_A = 0 \text{ to } 70 \text{ °C}; V_{CC} = 2.5 \text{ V to } 5.5 \text{ V})$ | Symbol | Alt. | Parameter | | t I <sup>2</sup> C<br>kHz | I <sup>2</sup> C<br>100 kHz | | Unit | |----------------------------------|---------------------|--------------------------------------|-----|---------------------------|-----------------------------|------|------| | | | | Min | Max | Min | Max | | | t <sub>CH1CH2</sub> <sup>2</sup> | t <sub>R</sub> | Clock Rise Time | | 300 | | 1000 | ns | | t <sub>CL1CL2</sub> <sup>2</sup> | t <sub>F</sub> | Clock Fall Time | | 300 | | 300 | ns | | t <sub>DH1DH2</sub> <sup>2</sup> | t <sub>R</sub> | SDA Rise Time | 20 | 300 | 20 | 1000 | ns | | t <sub>DL1DL2</sub> <sup>2</sup> | t <sub>F</sub> | SDA Fall Time | 20 | 300 | 20 | 300 | ns | | t <sub>CHDX</sub> <sup>1</sup> | t <sub>SU:STA</sub> | Clock High to Input Transition | 600 | | 4700 | | ns | | t <sub>CHCL</sub> | t <sub>HIGH</sub> | Clock Pulse Width High | 600 | | 4000 | | ns | | t <sub>DLCL</sub> | t <sub>HD:STA</sub> | Input Low to Clock Low (START) | 600 | | 4000 | | ns | | t <sub>CLDX</sub> | t <sub>HD:DAT</sub> | Clock Low to Input Transition | 0 | | 0 | | μs | | t <sub>CLCH</sub> | t <sub>LOW</sub> | Clock Pulse Width Low | 1.3 | | 4.7 | | μs | | t <sub>DXCX</sub> | t <sub>SU:DAT</sub> | Input Transition to Clock Transition | 100 | | 250 | | ns | | t <sub>CHDH</sub> | t <sub>SU:STO</sub> | Clock High to Input High (STOP) | 600 | | 4000 | | ns | | t <sub>DHDL</sub> | t <sub>BUF</sub> | Input High to Input Low (Bus Free) | 1.3 | | 4.7 | | μs | | t <sub>CLQV</sub> | t <sub>AA</sub> | Clock Low to Data Out Valid | | 1000 | | 3500 | ns | | t <sub>CLQX</sub> | t <sub>DH</sub> | Data Out Hold Time After Clock Low | 200 | | 200 | | ns | | f <sub>C</sub> | f <sub>SCL</sub> | Clock Frequency | | 400 | | 100 | kHz | | t <sub>W</sub> | t <sub>WR</sub> | Write Time | | 10 | | 10 | ms | Note: 1. For a reSTART condition, or following a write cycle. 2. Sampled only, not 100% tested Table 8. DC Characteristics $(T_A = 0 \text{ to } 70 \text{ °C}; V_{CC} = 2.5 \text{ V to } 5.5 \text{ V})$ | Symbol | Parameter | Test Condition | Min. | Max. | Unit | |------------------|----------------------------------|-----------------------------------------------------------------------|-----------------------|---------------------|------| | ILI | Input Leakage Current (SCL, SDA) | $0 \text{ V} \leq V_{IN} \leq V_{CC}$ | | ± 2 | μA | | I <sub>LO</sub> | Output Leakage Current | $0 \text{ V} \leq V_{OUT} \leq V_{CC}$ , SDA in Hi-Z | | ± 2 | μΑ | | l | Supply Current | $V_{CC}$ =5V, $f_c$ =400kHz (rise/fall time < 30ns) | | 2 | mA | | I <sub>CC</sub> | Supply Current | V <sub>CC</sub> =2.5V, f <sub>c</sub> =400kHz (rise/fall time < 30ns) | | 1 | mA | | I <sub>CC1</sub> | Supply Current | $V_{IN} = V_{SS} \text{ or } V_{CC}$ , $V_{CC} = 5 \text{ V}$ | | 20 | μΑ | | ICC1 | (Stand-by) | $V_{IN} = V_{SS}$ or $V_{CC}$ , $V_{CC} = 2.5$ V | | 2 | μΑ | | V <sub>IL</sub> | Input Low Voltage (SCL, SDA) | | - 0.3 | 0.3 V <sub>CC</sub> | V | | V <sub>IH</sub> | Input High Voltage (SCL, SDA) | | 0.7 V <sub>CC</sub> | V <sub>CC</sub> + 1 | V | | V <sub>IL</sub> | Input Low Voltage (WC) | | - 0.3 | 0.5 | V | | V <sub>IH</sub> | Input High Voltage (WC) | | V <sub>CC</sub> - 0.5 | V <sub>CC</sub> + 1 | V | | V <sub>OL</sub> | Output Low | $I_{OL} = 3 \text{ mA}, V_{CC} = 5 \text{ V}$ | | 0.4 | V | | VOL | Voltage | $I_{OL} = 2.1 \text{ mA}, V_{CC} = 2.5 \text{ V}$ | | 0.4 | V | Figure 9. AC Waveforms **Table 9. AC Measurement Conditions** | Input Rise and Fall Times | ≤ 50 ns | |-----------------------------------------------|------------------------------------------| | Input Pulse Voltages | 0.2V <sub>CC</sub> to 0.8V <sub>CC</sub> | | Input and Output Timing<br>Reference Voltages | 0.3V <sub>CC</sub> to 0.7V <sub>CC</sub> | Figure 10. AC Testing Input Output Waveforms Table 10. Input Parameters<sup>1</sup> ( $T_A = 25$ °C, f = 400 kHz) | Symbol | Parameter | <b>Test Condition</b> | Min. | Max. | Unit | |-----------------|-----------------------------------------------------------|-----------------------|------|------|------| | C <sub>IN</sub> | Input Capacitance (SDA) | | | 8 | pF | | C <sub>IN</sub> | Input Capacitance (other pins) | | | 6 | pF | | t <sub>NS</sub> | Low Pass Filter Input Time<br>Constant (SCL & SDA Inputs) | | 100 | 400 | ns | Note: 1. Sampled only, not 100% tested. **Table 11. Ordering Information Scheme** #### **ORDERING INFORMATION** Devices are shipped from the factory with the memory content set at all '1's (FFh). The notation used for the device number is as shown in Table 11. For a list of available options (speed, package, etc.) or for further information on any aspect of this device, please contact the ST Sales Office nearest to you. Information furnished is believed to be accurate and reliable. However, STMicroelectronics assumes no responsibility for the consequences of use of such information nor for any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of STMicroelectronics. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. STMicroelectronics products are not authorized for use as critical components in life support devices or systems without express written approval of STMicroelectronics. © 1999 STMicroelectronics - All Rights Reserved The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners. STMicroelectronics GROUP OF COMPANIES Australia - Brazil - China - France - Germany - Italy - Japan - Korea - Malaysia - Malta - Mexico - Morocco - The Netherlands - Singapore - Spain - Sweden - Switzerland - Taiwan - Thailand - United Kingdom - U.S.A. http://www.st.com 4