## SPI Serial E2PROM #### **FEATURES** - 1MHz Clock Rate - 128 X 8 Bits - —4 Byte Page Mode - Low Power CMOS - —150µA Standby Current - -3mA Active Write Current - 3V To 5.5V Power Supply - Block Write Protection - -Protect 1/4, 1/2 or all of E<sup>2</sup>PROM Array - Built-in Inadvertent Write Protection - -Power-Up/Power-Down Protection Circuitry - ---Write Latch - -Write Protect Pin - Self-Timed Write Cycle - -5mS Write Cycle Time (Typical) - · High Reliability - -- Endurance: 100,000 Cycles per byte - -Data Retention: 100 Years - -ESD Protection: 2000V on all Pins - 8-Pin Mini-DIP Package - 8-Pin SOIC Package #### DESCRIPTION The X25010 is a CMOS 1024 bit serial $E^2PROM$ , internally organized as 128 x 8. The X25010 features a serial interface and software protocol allowing operation on a simple three wire bus. The bus signals are a clock input (SCK) plus separate data in (SI) and data out (SO) lines. Access to the device is controlled through a chip select ( $\overline{CS}$ ) input, allowing any number of devices to share the same bus. The X25010 also features two additional inputs that provide the end user with added flexibility. By asserting the $\overline{HOLD}$ input, the X25010 will ignore transitions on its inputs, thus allowing the host to service higher priority interrupts. The $\overline{WP}$ input can be used as a hardwire input to the X25010 disabling all write attempts; thus providing a mechanism for limiting end user capability of altering the memory. The X25010 utilizes Xicor's proprietary Direct Write™ cell, providing a minimum endurance of 100,000 cycles per byte and a minimum data retention of 100 years. #### **FUNCTIONAL DIAGRAM** Direct Write<sup>™</sup> is a trademark of Xicor, Inc. 3835 FHD F01 #### PIN DESCRIPTIONS #### Serial Output (SO) SO is a push-pull serial data output pin. During a read cycle, data is shifted out on this pin. Data is clocked out by the falling edge of the serial clock. #### Serial Input (SI) SI is the serial data input pin. All data, opcodes, byte addresses, and data to be written to the memory are input on this pin. Data is latched by the rising edge of the serial clock. ## Serial Clock (SCK) The Serial Clock controls the serial bus timing for data input and output. Opcodes, addresses, or data present on the SI pin are sampled or latched on the rising edge of the clock input, while data on the SO pin change after the falling edge of the clock input. #### Chip Select (CS) When $\overline{\text{CS}}$ is high, the X25010 is deselected and the SO output pin is at high impedance and unless an internal write operation is underway the X25010 will be in the standby power mode. $\overline{\text{CS}}$ low enables the X25010, placing it in the active power mode. It should be noted that after power-on, a high to low transition on $\overline{\text{CS}}$ is required prior to the start of any operation. #### Write Protect (WP) When $\overline{WP}$ is low, nonvolatile writes to the X25010 are disabled, but the part otherwise functions normally. When $\overline{WP}$ is held high, all functions, including nonvolatile writes operate normally. WP going low while $\overline{CS}$ is still low will interrupt a write to the X25010. If the internal write cycle has already been initiated, $\overline{WP}$ going low will have no affect on write. ## Hold (HOLD) HOLD is used in conjunction with the $\overline{CS}$ pin to select the device. Once the part is selected and a serial sequence is underway, $\overline{HOLD}$ may be used to pause the serial communication with the controller without resetting the serial sequence. To pause, $\overline{HOLD}$ must be brought low while SCK is Low. To resume communication, $\overline{HOLD}$ is brought high, again while SCK is low. If the pause feature is not used, $\overline{HOLD}$ should be held high at all times. #### PIN CONFIGURATION #### **PIN NAMES** | Symbol | Description | | | | |-----------------|---------------------|--|--|--| | CS | Chip Select Input | | | | | SO | Serial Output | | | | | SI | Serial Input | | | | | SCK | Serial Clock Input | | | | | WP | Write Protect Input | | | | | V <sub>SS</sub> | Ground | | | | | Vcc | Supply Voltage | | | | | HOLD | Hold Input | | | | 3835 PGM T01 #### PRINCIPLES OF OPERATION The X25010 is a 128 x 8 E<sup>2</sup>PROM designed to interface directly with the synchronous serial peripheral interface (SPI) of the popular 6805 and 68HC11 microcontroller families. The X25010 contains an 8-bit instruction register. It is accessed via the SI input, with data being clocked in on the rising SCK. $\overline{CS}$ must be low and the $\overline{HOLD}$ and $\overline{WP}$ inputs must be high during the entire operation. Table 1 contains a list of the instructions and their operation codes. All instructions, addresses and data are transferred MSB first. Data input is sampled on the first rising edge of SCK after $\overline{CS}$ goes low. SCK is static, allowing the user to stop the clock and then resume operations. If the clock line is shared with other peripheral devices on the SPI bus, the user can assert the $\overline{HOLD}$ input to place the X25010 into a "PAUSE" condition. After releasing $\overline{HOLD}$ , the X25010 will resume operation from the point when $\overline{HOLD}$ was first asserted. ## Write Enable (WREN) and Write Disable (WRDI) The X25010 contains a write enable latch. This latch must be SET before a write operation will be completed internally. The WREN instruction will set the latch and the WRDI instruction will reset the latch. This latch is automatically reset upon a power-on condition and after the completion of a byte or page write cycle. The latch is also reset if $\overline{WP}$ is brought low. #### Read Status Register (RDSR) The RDSR instruction provides access to the status register. The status register may be read at any time, even during a write cycle. The status register is formatted as follows: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|-----|-----|-----|-----| | Х | Х | Х | Х | BP1 | BP0 | WEL | WIP | The **Write-In-Process (WIP)** bit indicates whether the X25010 is busy with a write operation. When set to a "1" a write is in progress, when set to a "0" no write is in progress. During a write all other bits are set to "1". The Write Enable Latch (WEL) bit indicates the status of the write enable latch. When set to a "1" the latch is set, when set to a "0" the latch is reset. The **Block Protect (BP0 and BP1)** bits indicate the extent of protection employed. These bits are set by the user issuing the WRSR instruction. #### Write Status Register (WRSR) The write status register instruction allows the user to select one of four levels of protection. The X25010 is divided into four 128-bit segments. One, two or all four of the segments may be protected. That is , the user may read the segment but will be unable to alter (write) data within the selected segments. The partitioning is controlled as illustrated below. | Status Register Bits | | Array Addresses | | | |----------------------|-----|-----------------|--|--| | BP1 | BP0 | Protected | | | | 0 | 0 | NONE | | | | 0 | 1 | \$60-\$7F (1/4) | | | | 1 0 | | \$40-\$7F (1/2) | | | | 1 | 1 | \$00-\$7F (All) | | | Table 1. Instruction Set | Instruction Name | Instruction Format* | Operation | |------------------|---------------------|-------------------------------------------------------------------------| | WREN | 0000 0110 | Set the Write Enable Latch (Enable Write Operations) | | WRDI | 0000 0100 | Reset the Write Enable Latch (Disable Write Operations) | | RDSR | 0000 0101 | Read Status Register | | WRSR | 0000 0001 | Write Status Register (Block Protect Bits) | | READ | 0000 0011 | Read Data from Memory Array beginning at Selected Address | | WRITE | 0000 0010 | Write Data to Memory Array beginning at Selected Address (1 to 4 Bytes) | \*Instructions are shown MSB in leftmost position. Instructions are transferred MSB first. 3835 PGM T02 #### **DEVICE OPERATION** #### **Clock and Data Timing** Data input on the SI line is sampled and latched on the rising edge of SCK. Data is output on the SO line by the falling edge of SCK. #### **Read Sequence** The $\overline{CS}$ line is first pulled low to select the device. The 8 bit read opcode is transmitted to the X25010, followed by the 8 bit byte address. After the read opcode and byte address are sent, the data stored in the memory at the selected address is shifted out on the SO line. The data stored in memory at the next address can be read sequentially by continuing to provide clock pulses. The byte address is automatically incremented to the next higher address after each byte of data is shifted out. When the highest address is reached (\$7F) the address counter rolls over to address \$00 allowing the read cycle to be continued indefinitely. The read operation is terminated by taking $\overline{CS}$ high. Refer to the read operation sequence illustrated in Figure 1. #### Write Sequence Prior to any attempt to write data into the X25010 the write enable latch must first be set by issuing the WREN instruction. (See Fig. 2) $\overline{CS}$ is first taken low, then the instruction is clocked into the X25010. After all eight bits of the instruction are transmitted, $\overline{CS}$ must then be taken high. If the user continues the write operation without taking $\overline{CS}$ high after issuing the WREN instruction the write operation will be ignored. Once the write enable latch is set, the user may proceed by issuing the write instruction, followed by the address and then the data to be written. This is minimally a twenty-four clock operation. $\overline{CS}$ must go low and remain low for the duration of the operation. The host may continue to write up to four bytes of data to the X25010. The only restriction is the four bytes must reside on the same page. A page address begins with address XXXX XX00 and ends with XXXX XX11. If the byte address counter reaches XXXX XX11 and the clock continues the counter will roll back to the first address of the page and overwrite any data that may have been written. For the write operation (byte or page write) to be completed, $\overline{CS}$ can only be brought high after the twenty-fourth, thirty-second, fourtieth or fourty-eighth clock. If it is brought high at any other time the write operation will not be completed. Refer to Figure 4 below for a detailed illustration of the page write sequence and time frames in which $\overline{CS}$ going high are valid. While the write is in progress the stats register may be read to check the WIP bit. During this time the WIP bit will be high and all other bits in the status register will be high. #### **Hold Operation** The HOLD input should be high (at V<sub>IH</sub>) under normal operation. If a data transfer is to be interrupted HOLD can be pulled low to suspend the transfer until it can be resumed. The only restriction is the SCK input must be low when HOLD is first pulled low and SCK must also be low when HOLD is released. The $\overline{HOLD}$ input may be tied high either directly to $V_{CC}$ or tied to $V_{CC}$ through a resistor. ## 2 #### **Operational Notes** The X25010 powers-on in the following state: - · The device is in the low power standby state. - A high to low transition on CS is required to enter an active state and receive an instruction. - · SO pin is high impedance. - · The write enable latch is reset. #### **Data Protection** The following circuitry has been included to prevent inadvertent writes: - The write enable latch is reset upon power-up. - A write enable instruction must be issued to set the write enable latch. - CS must come high at the proper clock count in order to start a write cycle. The write enable latch is reset when $\overline{WP}$ is brought low. Figure 2. Write Enable Latch Figure 3. Write Operation Sequence Figure 4. Page Write Operation Sequence ## 2 #### **ABSOLUTE MAXIMUM RATINGS\*** | Temperature Under Bias | 65°C to +135°C | |---------------------------------|------------------------| | Storage Temperature | 65°C to +150°C | | Voltage on any Pin with Respect | to Ground -1.0V to +7V | | D.C. Output Current | 5mA | | Lead Temperature | | | (Soldering, 10 Seconds) | 300°C | #### \*COMMENT Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and the functional operation of the device at these or any other conditions above those listed in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### RECOMMENDED OPERATING CONDITIONS | Temp | Min. | Max. | |------------|-------|--------------| | Commercial | 0°C | 70°C | | Industrial | -40°C | +85°C | | Military | –55°C | +125°C | | | | 3835 PGM T03 | \_\_\_\_ | Supply Voltage | Limits | |----------------|------------| | X25010 | 5V ± 10% | | X25010-3 | 3V to 5.5V | 3835 PGM T04 ## D.C. OPERATING CHARACTERISTICS (Over the recommended operating conditions unless otherwise specified.) | | | Lim | its | | | |---------------------|------------------------------------------|-----------------------|-----------------------|-------|------------------------------------------------------------------------| | Symbol | Parameter | Min. | Max. | Units | Test Conditions | | Icc | V <sub>CC</sub> Supply Current (Active) | | 3 | mA | SCK = V <sub>CC</sub> x 0.1/V <sub>CC</sub> x 0.9 @ 1MHz,<br>SO = OPEN | | ISB | V <sub>CC</sub> Supply Current (Standby) | | 150 | μА | CS = V <sub>CC</sub> , V <sub>IN</sub> = Gnd or V <sub>CC</sub> - 0.3V | | ILI | Input Leakage Current | | 10 | μА | V <sub>IN</sub> = GND to V <sub>CC</sub> | | ILO | Output Leakage Current | | 10 | μА | V <sub>OUT</sub> = GND to V <sub>CC</sub> | | V <sub>IL</sub> (1) | Input Low Voltage | -1.0 | V <sub>CC</sub> x 0.3 | ٧ | | | VIH <sup>(1)</sup> | Input High Voltage | V <sub>CC</sub> x 0.7 | V <sub>CC</sub> + 0.5 | ٧ | | | VOL | Output Low Voltage | | 0.4 | ٧ | I <sub>OL</sub> = 2mA | | Voн | Output High Voltage | V <sub>CC</sub> -0.8 | | V | I <sub>OH</sub> = -1.0mA | 3835 PGM T05 #### **POWER-UP TIMING** | Symbol | Parameter | Min. | Max. | Units | |----------------------|-----------------------------|------|------|-------| | t <sub>PUR</sub> (2) | Power-up to Read Operation | | 1 | ms | | t <sub>PUW</sub> (2) | Power-up to Write Operation | | 5 | ms | 3835 PGM T09 #### **CAPACITANCE** $T_A = 25$ °C, f = 1.0MHz, $V_{CC} = 5$ V. | Symbol | Test | Max. | Units | Conditions | |----------------------|-------------------------------------------|------|-------|-----------------------| | C <sub>OUT</sub> (2) | Output Capacitance (SO) | 8 | pF | V <sub>OUT</sub> = 0V | | C <sub>IN</sub> (2) | Input Capacitance (SCK, SI, CS, WP, HOLD) | 6 | pF | V <sub>IN</sub> = 0V | Notes: (1) V<sub>IL</sub> Min and V<sub>IH</sub> Max. are for reference only and are not tested. (2) This parameter is periodically sampled and not 100% tested. 3835 PGM T06 #### **EQUIVALENT A.C. LOAD CIRCUIT** # **≶** 2.16 KΩ OUTPUT-≥3.07 KΩ ‡100 pF 3835 FHD F12 #### A.C. TEST CONDITIONS | Input Pulse Levels | V <sub>CC</sub> x 0.1 to V <sub>CC</sub> x 0.9 | | |-------------------------------|------------------------------------------------|--| | Input Rise and Fall Times | 10ns | | | Input and Output Timing Level | V <sub>CC</sub> x 0.5 | | 3835 PGM T07 ## A.C. CHARACTERISTICS (Over recommended operating conditions, unless otherwise specified) #### **Data Input Timing** | Symbol | Parameter | Min. | Max. | Units | |--------------------|-------------------|------|------|-------| | fsck | Clock Frequency | 0 | 1 | MHz | | tcyc | Cycle Time | 1000 | | ns | | tLEAD | CS Lead Time | 500 | | ns | | tLAG | CS Lag Time | 500 | | ns | | twH | Clock High Time | 400 | | ns | | twL | Clock Low Time | 400 | | ns | | tsu | Data Setup Time | 100 | | ns | | tH | Data Hold Time | 100 | | ns | | t <sub>RI</sub> | Data In Rise Time | | 2.0 | μs | | tFI | Data In Fall Time | | 2.0 | μs | | tHD | HOLD Setup Time | 200 | | ns | | tcp | HOLD Hold Time | 200 | | ns | | tcs | CS Deselect Time | 500 | | ns | | twc <sup>(3)</sup> | Write Cycle Time | | 10 | ms | 3835 PGM T08 #### **Data Output Timing** | Symbol | Parameter | Min. | Max. | Units | |--------------------------------|------------------------------|------|------|-------| | fsck | Clock Frequency | 0 | 1 | MHz | | tDIS | Output Disable Time | | 500 | ns | | ty | Output Valid from clock Low | | 360 | ns | | tHO | Output Hold Time | 0 | | ns | | t <sub>RO</sub> (1) | Output Rise Time | | 300 | ns | | t <sub>FO</sub> <sup>(1)</sup> | Output Fall Time | | 300 | ns | | tLZ | HOLD High to Output in Low Z | 100 | | ns | | tHZ | HOLD Low to Output in High Z | 100 | | ns | 3835 PGM T09 Notes: (3) two is the time from the rising edge of CS after a valid write sequence has been sent to the end of the self-timed internal nonvolatile write cycle. ## 2 ## **Serial Output Timing** ## **Serial Input Timing** ## X25010 ## **Hold Timing**