## M36DR432AD M36DR432BD # 32 Mbit (2Mb x16, Dual Bank, Page) Flash Memory and 4 Mbit (256Kb x16) SRAM, Multiple Memory Product #### **FEATURES SUMMARY** - Multiple Memory Product - 1 bank of 32 Mbit (2Mb x16) Flash Memory - 1 bank of 4 Mbit (256Kb x16) SRAM - SUPPLY VOLTAGE - $V_{DDF} = V_{DDS} = 1.65 \text{V to } 2.2 \text{V}$ - V<sub>PPF</sub> = 12V for Fast Program (optional) - ACCESS TIMES: 85ns, 100ns, 120ns - LOW POWER CONSUMPTION - ELECTRONIC SIGNATURE - Manufacturer Code: 0020h - Top Device Code, M36DR432AD: 00A0h - Bottom Device Code, M36DR432BD: 00A1h #### **FLASH MEMORY** - MEMORY BLOCKS - Dual Bank Memory Array: 4 Mbit, 28 Mbit - Parameter Blocks (Top or Bottom location) - PROGRAMMING TIME - 10µs by Word typical - Double Word Program Option - ASYNCHRONOUS PAGE MODE READ - Page Width: 4 Words - Page Access: 35ns - Random Access: 85ns, 100ns, 120ns - DUAL BANK OPERATIONS - Read within one Bank while Program or Erase within the other - No delay between Read and Write operations - BLOCK LOCKING - All blocks locked at Power up - Any combination of blocks can be locked - WPF for Block Lock-Down - COMMON FLASH INTERFACE (CFI) - 64 bit Unique Device Identifier - 64 bit User Programmable OTP Cells Figure 1. Package - ERASE SUSPEND and RESUME MODES - 100,000 PROGRAM/ERASE CYCLES per BLOCK - 20 YEARS DATA RETENTION - Defectivity below 1ppm/year #### SRAM - 4 Mbit (256Kb x16) - LOW V<sub>DDS</sub> DATA RETENTION: 1.0V - POWER DOWN FEATURES USING TWO CHIP ENABLE INPUTS February 2003 1/52 ## M36DR432AD, M36DR432BD ## **TABLE OF CONTENTS** | SU | MMARY DESCRIPTION | 6 | |-----|-------------------------------------------------------------------|------| | | Figure 2. Logic Diagram | 6 | | | Table 1. Signal Names | | | | Figure 3. TFBGA Connections (Top view through package) | 7 | | | | | | SIG | NAL DESCRIPTIONS | 8 | | | Address Inputs (A0-A17) | 8 | | | Address Inputs (A18-A20) | 8 | | | Data Input/Output (DQ0-DQ15) | 8 | | | Flash Chip Enable (EF) | 8 | | | Flash Output Enable (GF) | 8 | | | Flash Write Enable (WF) | 8 | | | Flash Write Protect (WPF) | 8 | | | Flash Write Protect (WPF) | 8 | | | Flash Reset/Power-Down (RPF) | 8 | | | VDDF Supply Voltage (1.65V to 2.2V) | 8 | | | V <sub>PPF</sub> Programming Voltage (11.4V to 12.6V) | 8 | | | V <sub>SSF</sub> Ground | 8 | | | SRAM Chip Enable (ES) | 8 | | | SRAM Write Enable (WS) | | | | SRAM Output Enable (GS) | 9 | | | SRAM Upper Byte Enable (UBS) | | | | SRAM Lower Byte Enable (LBS) | | | | VDDS Supply Voltage (1.65V to 2.2V) | 9 | | FUI | NCTIONAL DESCRIPTION | 10 | | | | | | | Figure 4. Functional Block Diagram | | | | Table 2. Main Operation Modes | . 11 | | FL | ASH MEMORY COMPONENT | . 12 | | | Table 3. Flash Bank Architecture | | | | Figure 5. Flash Security Block and Protection Register Memory Map | | | | Figure 5. Flash Security Block and Flotection Register Memory Map | . 13 | | | Flash Bus Operations | . 13 | | | Flash Read | | | | Flash Write | | | | Flash Output Disable | | | | Flash Standby | | | | Automatic Flash Standby | | | | Flash Power-Down | | | | Dual Bank Operations | . 13 | | | Flash Command Interface | . 13 | | | Flash Read/Reset Command | | | | Flash Read CFI Query Command. | | | | • | | | | Auto Select Command | . 14 | |----|-------------------------------------------------------------------|------| | | Set Configuration Register Command | . 14 | | | Program Command | . 14 | | | Double Word Program Command | . 14 | | | Quadruple Word Program Command | . 14 | | | Enter Bypass Mode Command | . 15 | | | Exit Bypass Mode Command | . 15 | | | Program in Bypass Mode Command | . 15 | | | Double Word Program in Bypass Mode Command | . 15 | | | Quadruple Word Program in Bypass Mode Command | . 15 | | | Block Lock Command | . 15 | | | Block Unlock Command | . 15 | | | Block Lock-Down Command | . 15 | | | Block Erase Command | . 15 | | | Bank Erase Command | . 16 | | | Erase Suspend Command | . 16 | | | Erase Resume Command | | | | Protection Register Program Command | . 16 | | | Table 4. Flash Commands | | | | Table 5. Read Electronic Signature | . 18 | | | Table 6. Flash Read Block Protection | | | | Table 7. Configuration Register | | | | Table 8. Read Protection Register | | | | Table 9. Program, Erase Times and Program, Erase Endurance Cycles | . 19 | | | Flash Block Locking | . 19 | | | Reading a Block's Lock Status | | | | Locked State | | | | Unlocked State | | | | Lock-Down State | | | | Locking Operations During Erase Suspend | | | | Table 10. Flash Lock Status | | | | | | | | Flash Status Register | | | | Data Polling Bit (DQ7). | | | | Toggle Bit (DQ6) | | | | Toggle Bit (DQ2) | | | | Error Bit (DQ5) | | | | Erase Timer Bit (DQ3) | | | | Table 11. Polling and Toggle Bits | | | | Table 11. Foling and Toggle Bits | | | | Table 12. Status Register Bits | . 23 | | SR | AM COMPONENT | . 24 | | | SRAM Operations | . 24 | | | Read | | | | Write | | | | | | ## M36DR432AD, M36DR432BD | | Standby/Power-Down | 24 | |-------|-----------------------------------------------------------------------------------------------------------------------|----| | | Data Retention | 24 | | | Output Disable | 24 | | N / / | AXIMUM RATING | 25 | | VI F | | | | | Table 13. Absolute Maximum Ratings(1) | 25 | | DC | AND AC PARAMETERS | 26 | | | Table 14. Operating and AC Measurement Conditions | 26 | | | Figure 6. AC Measurement I/O Waveform | 26 | | | Figure 7. AC Measurement Load Circuit | 26 | | | Table 15. Device Capacitance | | | | Table 16. Flash DC Characteristics | | | | Table 17. SRAM DC Characteristics (T <sub>A</sub> = -40 to 85°C; V <sub>DDF</sub> = V <sub>DDS</sub> = 1.65V to 2.2V) | 28 | | | Figure 8. Flash Random Read AC Waveforms | | | | Figure 9. Flash Page Read AC Waveforms | | | | Table 18. Flash Read AC Characteristics | | | | Figure 10. Flash Write AC Waveforms, Write Enable Controlled | | | | Table 19. Flash Write AC Characteristics, Write Enable Controlled | | | | Figure 11. Flash Write AC Waveforms, Chip Enable Controlled | | | | Table 20. Flash Write AC Characteristics, Chip Enable Controlled | | | | Figure 12. Flash Reset/Power-Down AC Waveform | | | | Table 21. Flash Reset/Power-Down AC Characteristics | | | | Figure 13. Flash Data Polling DQ7 AC Waveforms | | | | Figure 14. Flash Data Toggle DQ6, DQ2 AC Waveforms | | | | Table 22. Flash Data Polling and Toggle Bits AC Characteristics | | | | Figure 15. Flash Data Polling Flowchart | | | | Figure 16. Flash Data Toggle Flowchart | | | | Figure 17. SRAM Read Mode AC Waveforms, Address Controlled with UBS = LBS = V <sub>IL</sub> | | | | Figure 18. SRAM Read AC Waveforms, ES or GS Controlled | | | | Figure 19. SRAM Standby AC Waveforms | | | | Table 23. SRAM Read AC Characteristics) | | | | Figure 20. SRAM Write AC Waveforms, WS Controlled with GS Low | | | | Figure 21. SRAM Write AC Waveforms, WS Controlled with GS High | | | | Figure 22. SRAM Write Cycle Waveform, UBS and LBS Controlled, G Low | | | | Figure 23. SRAM Write AC Waveforms, ES Controlled | | | | Table 24. SRAM Write AC Characteristics | | | | Figure 24. SRAM Low V <sub>DDS</sub> Data Retention AC Waveforms, ES Controlled | | | | Table 25. SRAM Low V <sub>DDS</sub> Data Retention Characteristics (1, 2) | | | D ^ | CKACE MECHANICAL | 11 | | - 1 | CKAGE MECHANICAL | | | | Figure 25. Stacked LFBGA 12x8mm - 8x8 ball array, 0.8mm pitch, Bottom View Package Outline | | | | Table 26. Stacked LFBGA 12x8mm - 8x8 ball array, 0.8mm pitch, Package Mechanical Data | 44 | ## M36DR432AD, M36DR432BD | PART NUMBERING | 45 | |----------------------------------------------------------|----| | Table 27. Ordering Information Scheme | 45 | | APPENDIX A. BLOCK ADDRESSES | 46 | | Table 28. Bank A, Top Boot Block Addresses M36DR432AD | 46 | | Table 29. Bank B, Top Boot Block Addresses M36DR432AD | 46 | | Table 30. Bank B, Bottom Boot Block Addresses M36DR432BD | 47 | | Table 31. Bank A, Bottom Boot Block Addresses M36DR432BD | 47 | | APPENDIX B. COMMON FLASH INTERFACE | 48 | | Table 32. Query Structure Overview | 48 | | Table 33. CFI Query Identification String | 48 | | Table 34. CFI Query System Interface Information | 49 | | Table 35. Device Geometry Definition | 50 | | REVISION HISTORY | 51 | | Table 36 Document Revision History | 51 | 47/ #### SUMMARY DESCRIPTION The M36DR432AD/BD is a low-voltage Multiple Memory Product which combines two memory devices: a 32 Mbit (2Mbit x16) non-volatile Flash memory and a 4 Mbit SRAM. The memory is available in a Stacked LFBGA66 12x8mm - 8x8 active ball array, 0.8mm pitch package and supplied with all the bits erased (set to '1'). Figure 2. Logic Diagram **Table 1. Signal Names** | able 1. Digital Names | | | | | | | | | | | |-------------------------|--------------------------------------------------------|--|--|--|--|--|--|--|--|--| | A0-A17 | Address Inputs | | | | | | | | | | | A18-A20 | Address Inputs for Flash Chip only | | | | | | | | | | | DQ0-DQ15 | Data Input/Outputs, Command Inputs | | | | | | | | | | | V <sub>DDF</sub> | Flash Power Supply | | | | | | | | | | | V <sub>PPF</sub> | Flash Optional Supply Voltage for Fast Program & Erase | | | | | | | | | | | V <sub>SSF</sub> | Flash Ground | | | | | | | | | | | V <sub>DDS</sub> | SRAM Power Supply | | | | | | | | | | | V <sub>SSS</sub> | SRAM Ground | | | | | | | | | | | NC | Not Connected Internally | | | | | | | | | | | Flash control functions | | | | | | | | | | | | EF | Chip Enable | | | | | | | | | | | GF | Output Enable | | | | | | | | | | | WF | Write Enable | | | | | | | | | | | RPF | Reset/Power-Down | | | | | | | | | | | WPF | Write Protect input | | | | | | | | | | | SRAM control | functions | | | | | | | | | | | E1S | Chip Enable | | | | | | | | | | | E2S | Chip Enable | | | | | | | | | | | GS | Output Enable | | | | | | | | | | | WS | Write Enable | | | | | | | | | | | <u>UBS</u> | Upper Byte Enable | | | | | | | | | | | LBS | Lower Byte Enable | | | | | | | | | | 47/ Figure 3. TFBGA Connections (Top view through package) #### SIGNAL DESCRIPTIONS See Figure 2 Logic Diagram and Table 1, Signal Names, for a brief overview of the signals connected to this device. Address Inputs (A0-A17). Addresses A0-A17 are common inputs for the Flash and the SRAM components. The Address Inputs select the cells in the memory array to access during Bus Read operations. During Bus Write operations they control the commands sent to the Command Interface of the internal state machine. During a write operation, the address inputs for the Flash memory are latched on the falling edge of the Flash Chip Enable (EF) or Write Enable (WF), whichever occurs last, whereas for the SRAM array they are latched on the falling edge of the SRAM Chip Enable lines (E1S or E2S) or Write Enable (WS). In the rest of the datasheet, only the Active Low SRAM Chip Enable line will be discussed. It will be referred to as ES. **Address Inputs (A18-A20).** Addresses A18-A20 are inputs for the Flash component only. They are latched during a write operation on the falling edge of Flash Chip Enable (EF) or Write Enable (WF), whichever occurs last. **Data Input/Output (DQ0-DQ15).** The Data I/O output the data stored at the selected address during a Bus Read operation or input a command or the data to be programmed during a Write Bus operation. The input is data to be programmed in the Flash or SRAM memory array or a command to be written to the C.I. of the Flash memory. Both are latched on the rising edge of Flash Write Enable (WF) and, SRAM Chip Enable lines ( $\overline{\text{ES}}$ ) or Write Enable ( $\overline{\text{WS}}$ ). The output is data from the Flash memory array or SRAM array, the Electronic Signature Manufacturer or Device codes, the Block Protection status, the Configuration Register status or the Status Register Data (Polling bit DQ7, Toggle bits DQ6 and DQ2, Error bit DQ5 or Erase Timer bit DQ3) depending on the address. Outputs are valid when Flash Chip Enable ( $\overline{\text{EF}}$ ) and Output Enable ( $\overline{\text{GF}}$ ) or SRAM Chip Enable lines ( $\overline{\text{ES}}$ ) and Output Enable ( $\overline{\text{GS}}$ ) are active. The output is high impedance when both the Flash chip and the SRAM chip are deselected or the outputs are disabled and when Reset (RPF) is at V<sub>IL</sub>. Flash Chip Enable ( $\overline{\text{EF}}$ ). The Chip Enable input activates the Flash memory control logic, input buffers, decoders and sense amplifiers. When Chip Enable is at V<sub>IH</sub> the memory is deselected and the power consumption is reduced to the standby level. Flash Output Enable (GF). gates the outputs through the data buffers during a read operation. When Output Enable, $\overline{GF}$ , is at $V_{IH}$ the outputs are High impedance. **Flash Write Enable (WF).** The Write Enable controls the Bus Write operation of the Flash memory's Command Interface. **Flash Write Protect (WPF).** Write Protect is an input that gives an additional hardware protection for each Flash block. When Write Protect is at $V_{IL}$ , the locked-down blocks cannot be locked or unlocked. When Write Protect is at $V_{IH}$ , the Lock-Down is disabled and the Locked-Down blocks can be locked or unlocked. Refer to Table 8, Read Protection Register. Flash Reset/Power-Down (RPF). The Reset/Power-Down input provides hardware reset of the Flash memory, and/or Power-Down functions, depending on the Flash Configuration Register status. Reset or Power-Down of the memory is achieved by pulling RPF to V<sub>IL</sub> for at least t<sub>PLPH</sub>. The Reset/Power-Down function is set in the Configuration Register (see Set Configuration Register Command). If it is set to '0' the Reset function is enabled, if it is set to '1' the Power-Down function is enabled. After a Reset or Power-Up the power save function is disabled and all blocks are locked. The memory Command Interface is reset on Power Up to Read Array. Either Chip Enable or Write Enable must be tied to V<sub>IH</sub> during Power Up to allow maximum security and the possibility to write a command on the first rising edge of Write Enable. After a Reset, when the device is in Read, Erase Suspend Read or Standby, valid data will be output tpHQ7V1 after the rising edge of RPF. If the device is in Erase or Program, the operation will be aborted and the reset recovery will take a maximum of tpLQ7V. The memory will recover from Reset/Power-Down tpHQ7V2 after the rising edge of RPF. See Tables 18 and 19, and Figure 12. **V<sub>DDF</sub> Supply Voltage (1.65V to 2.2V).** V<sub>DDF</sub> provides the power supply to the internal core and I/O pins of the memory device. It is the main power supply for all operations (read, program and erase). **VPPF Programming Voltage (11.4V to 12.6V).**VPPF provides a high voltage power supply for fast factory programming. VPPF is required to use the Double Word and Quadruple Word Program commands. **V<sub>SSF</sub> Ground.** V<sub>SSF</sub> ground is the reference for the core supply. It must be connected to the system ground. **SRAM Chip Enable (ES).** The Chip Enable inputs for SRAM activate the memory control logic, input buffers and decoders. ES at V<sub>IH</sub> deselects the memory and reduces the power consumption to the standby level. $\overline{ES}$ can also be used to control writing to the SRAM memory array, while $\overline{WS}$ remains at $V_{IL}$ . It is not allowed to set $\overline{EF}$ at $V_{IL}$ and $\overline{ES}$ at $V_{IL}$ at the same time. **SRAM Write Enable (WS).** The Write Enable input controls writing to the SRAM memory array. WS is active Low. **SRAM Output Enable (GS).** The Output Enable gates the outputs through the data buffers during a read operation of the SRAM chip. GS is active Low. **SRAM Upper Byte Enable (UBS).** Enables the upper bytes for SRAM (DQ8-DQ15). UBS is active Low. **SRAM Lower Byte Enable (LBS).** Enables the lower bytes for SRAM (DQ0-DQ7). LBS is active Low. $V_{DDS}$ Supply Voltage (1.65V to 2.2V). $V_{DDS}$ is the SRAM power supply for all operations. Note: Each device in a system should have $V_{DDF}$ and $V_{PPF}$ decoupled with a $0.1\mu F$ capacitor close to the pin. See Figure 7, AC Measurement Load Circuit. The PCB trace widths should be sufficient to carry the required $V_{PPF}$ program and erase currents. #### **FUNCTIONAL DESCRIPTION** The Flash and SRAM components have separate power supplies and grounds and are distinguished by three chip enable inputs: $\overline{\text{EF}}$ for the Flash mem- ory and $\overline{\text{ES}}$ ( $\overline{\text{E1S}}$ and E2S, respectively) for the SRAM. Figure 4. Functional Block Diagram **Table 2. Main Operation Modes** | C | Operation Mode | EF | GF | WF | RPF | WPF | ES | GS | ws | UBS, LBS <sup>(1)</sup> | DQ15-DQ0 | |--------------|----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------------|-----------------------| | | Read | VIL | VIL | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | ; | SRAM | must b | e disabled | Data Output | | > | Page Read | V <sub>IL</sub> | $V_{IL}$ | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | ; | SRAM | Data Output | | | | Flash Memory | Write | V <sub>IL</sub> | V <sub>IH</sub> | $V_{IL}$ | V <sub>IH</sub> | V <sub>IH</sub> | ; | SRAM | Data Input | | | | h Me | Standby | V <sub>IH</sub> | Х | Х | V <sub>IH</sub> | V <sub>IH</sub> | Ar | ny SRA | Hi-Z | | | | Flas | Reset/<br>Power-Down | х | Х | Х | VIL | VIH | Ar | ny SRA | Hi-Z | | | | | Output Disable | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Ar | ny SRA | Hi-Z | | | | | Read | | Flash | must be | e disable | d | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Data out<br>Word Read | | | Write | | Flash | must be | e disable | d | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | Data in Word<br>Write | | SRAM | Standby/Power | ۸. | ov Floo | h 200 do | ناه والعامة | abla | V <sub>IH</sub> | Х | Х | Х | Hi-Z | | SR. | Down | Ai | iy rias | n mode | is allowa | able | Х | Х | Х | V <sub>IH</sub> | Hi-Z | | | Data Datastica | Δ. | <b>-</b> | | :!! | -1-1- | V <sub>IH</sub> | Х | Х | Х | Hi-Z | | | Data Retention | Ai | iy rias | птоае | is allowa | able | Х | Х | Х | VIH | Hi-Z | | | Output Disable | Aı | ny Flas | h mode | is allowa | able | $V_{IL}$ | V <sub>IH</sub> | V <sub>IH</sub> | Х | Hi-Z | Note: 1. X = Don't care (V<sub>IL</sub> or V<sub>IH</sub>). 2. If UBS and LBS are tied together the bus is at 16 bit. For an 8 bit bus configuration use UBS and LBS separately. #### FLASH MEMORY COMPONENT The Flash Memory is a 32 Mbit (2Mbit x16) non-volatile Flash memory that may be erased electrically at block level and programmed in-system on a Word-by-Word basis using a 1.65V to 2.2V $V_{DDF}$ supply for the circuitry and a 1.65V to 2.2V $V_{DDG}$ supply for the Input/Output pins (in the stacked device, $V_{DDF}$ and $V_{DDQF}$ are tied internally). An optional 12V $V_{PPF}$ power supply is provided to speed up customer programming. The Flash device features an asymmetrical block architecture with an array of 71 blocks divided into two banks, Banks A and B, providing Dual Bank operations. While programming or erasing in Bank A, read operations are possible in Bank B or vice versa. Only one bank at a time is allowed to be in program or erase mode. The bank architecture is summarized in Table 3, and the Block Addresses are shown in Appendix A. The Parameter Blocks are located at the top of the memory address space for the M36DR432AD and, at the bottom for the M36DR432BD. Each block can be erased separately. Erase can be suspended, in order to perform either read or program in any other block, and then resumed. Each block can be programmed and erased over 100,000 cycles. Program and Erase commands are written to the Command Interface of the memory. An internal Program/Erase Controller takes care of the timings necessary for program and erase operations. The end of a program or erase operation can be detected and any error conditions identified in the Status Register. The command set required to control the memory is consistent with JEDEC standards. The Flash memory features an instant, individual block locking scheme that allows any block to be locked or unlocked with no latency, enabling instant code and data protection. All blocks have two levels of protection. They can be individually locked and locked-down preventing any accidental programming or erasure. All blocks are locked at Power Up and Reset. The device includes a 128 bit Protection Register and a Security Block to increase the protection of a system's design. The Protection Register is divided into two 64 bit segments. The first segment contains a unique device number written by ST, while the second one is one-time-programmable by the user. The user programmable segment can be permanently protected. The Security Block, parameter block 0, can be permanently protected by the user. Figure 5, shows the Flash Security Block and Protection Register Memory Map. Table 3. Flash Bank Architecture | | Bank Size | Parameter Blocks | Main Blocks | |--------|-----------|----------------------|------------------------| | Bank A | 4 Mbits | 8 blocks of 4 KWords | 7 blocks of 32 KWords | | Bank B | 28 Mbits | - | 56 blocks of 32 KWords | Figure 5. Flash Security Block and Protection Register Memory Map #### **Flash Bus Operations** The following operations can be performed using the appropriate bus cycles: Flash Read Array (Random and Page Modes), Flash Write, Flash Output Disable, Flash Standby and Flash Reset/ Power-Down, see Table 2, Main Operation Modes. Flash Read. Flash Read operations are used to output the contents of the Memory Array, the Electronic Signature, the Status Register, the CFI, the Block Protection Status or the Configuration Register status. Read operation of the Flash memory array is performed in asynchronous page mode, that provides fast access time. Data is internally read and stored in a page buffer. The page has a size of 4 words and is addressed by A0-A1 address inputs. Read operations of the Electronic Signature, the Status Register, the CFI, the Block Protection Status, the Configuration Register status and the Security Code are performed as single asynchronous read cycles (Random Read). Both Flash Chip Enable EF and Flash Output Enable GF must be at V<sub>II</sub> in order to read the output of the memory. Flash Write. Write operations are used to give commands to the memory or to latch Input Data to be programmed. A write operation is initiated when Chip Enable EF and Write Enable WF are at V<sub>IL</sub> with Output Enable GF at V<sub>IH</sub>. Addresses are latched on the falling edge of WF or EF whichever occurs last. Commands and Input Data are latched on the rising edge of WF or EF whichever occurs first. Noise pulses of less than 5ns typical on EF, WF and GF signals do not start a write cycle. Flash Output Disable. The data outputs are high impedance when the Output Enable $\overline{GF}$ is at $V_{IH}$ with Write Enable $\overline{WF}$ at $V_{IH}$ . **Flash Standby.** The memory is in standby when Chip Enable EF is at V<sub>IH</sub> and the P/E.C. is idle. The power consumption is reduced to the standby level and the outputs are high impedance, independent of the Output Enable GF or Write Enable WF inputs. **Automatic Flash Standby.** In Read mode, after 150ns of bus inactivity and when CMOS levels are driving the addresses, the chip automatically enters a pseudo-standby mode where consumption is reduced to the CMOS standby value, while outputs still drive the bus. **Flash Power-Down.** The memory is in Power-Down when the Configuration Register is set for/Power-Down and RPF is at V<sub>IL</sub>. The power consumption is reduced to the Power-Down level, and Outputs are high impedance, independent of the Chip Enable EF, Output Enable GF or Write Enable WF inputs. **Dual Bank Operations.** The Dual Bank allows data to be read from one bank of memory while a program or erase operation is in progress in the other bank of the memory. Read and Write cycles can be initiated for simultaneous operations in different banks without any delay. Status Register during Program or Erase must be monitored using an address within the bank being modified. #### Flash Command Interface All Bus Write operations to the memory are interpreted by the Command Interface. Commands consist of one or more sequential Bus Write operations. An internal Program/Erase Controller han- dles all timings and verifies the correct execution of the Program and Erase commands. Two bus write cycles are required to unlock the Command Interface. They are followed by a setup or confirm cycle. The increased number of write cycles is to ensure maximum data security. The Program/Erase Controller provides a Status Register whose output may be read at any time to monitor the progress or the result of the operation. The Command Interface is reset to Read mode when power is first applied or exiting from Reset. Command sequences must be followed exactly. Any invalid combination of commands will reset the device to Read mode Flash Read/Reset Command. The Read/Reset command returns the device to Read mode. One Bus Write cycle is required to issue the Read/Reset command and return the device to Read mode. Subsequent Read operations will read the addressed location and output the data. The write cycle can be preceded by the unlock cycles but it is not mandatory. Flash Read CFI Query Command. The Read CFI Query command is used to read data from the Common Flash Interface (CFI) and the Electronic Signature (Manufacturer or the Device Code, see Table 5). The Read CFI Query Command consists of one Bus Write cycle. Once the command is issued the device enters Read CFI mode. Subsequent Bus Read operations read the Common Flash Interface or Electronic Signature. Once the device has entered Read CFI mode, only the Read/Reset command should be used and no other. Issuing the Read/Reset command returns the device to Read mode. See Appendix B, Common Flash Interface, Tables 33, 34, and 35 for details on the information contained in the Common Flash Interface memory ar- Auto Select Command. The Auto Select command uses the two unlock cycles followed by one write cycle to any bank address to setup the command. Subsequent reads at any address will output the Block Protection status, Protection Register and Protection Register Lock or the Configuration Register status depending on the levels of A0 and A1 (see Tables 6, 7 and 8). Once the Auto Select command has been issued only the Read/Reset command should be used and no other. Issuing the Read/Reset command returns the device to Read mode. **Set Configuration Register Command.** The Flash component contains a Configuration Register, see Table 7, Configuration Register. It is used to define the status of the Reset/Power-Down functions. The value for the Configuration Register is always presented on A0-A15, the other address bits are ignored. Address input A10 defines the status of the Reset/Power-Down functions. If it is set to '0' the Reset function is enabled, if it is set to '1' the Power-Down function is enabled. At Power Up the Configuration Register bit is set to '0'. The Set Configuration Register command is used to write a new value to the Configuration Register. The command uses the two unlock cycles followed by one write cycle to setup the command and a further write cycle to write the data and confirm the command. **Program Command.** The Program command uses the two unlock cycles followed by a write cycle to setup the command and a further write cycle to latch the Address and Data and start the Program Erase Controller. Read operations within the same bank output the Status Register after programming has started. Note that the Program command cannot change a bit set at '0' back to '1'. One of the Erase Commands must be used to set all the bits in a block or in the whole bank from '0' to '1'. If the Program command is used to try to set a bit from '0' to '1' Status Register Error bit DQ5 will be set to '1', only if $V_{PPF}$ is in the range of 11.4V to 12.6V. **Double Word Program Command.** This feature is offered to improve the programming throughput by writing a page of two adjacent words in parallel. The V<sub>PPF</sub> supply voltage is required to be from 11.4V to 12.6V for the Double Word Program command. The command uses the two unlock cycles followed by a write cycle to setup the command. A further two cycles are required to latch the address and data of the two Words and start the Program Erase Controller. The addresses must be the same except for the A0. The Double Word Program command can be executed in Bypass mode to skip the two unlock cycles. Note that the Double Word Program command cannot change a bit set at '0' back to '1'. One of the Erase Commands must be used to set all the bits in a block or in the whole bank from '0' to '1'. If the Double Word Program command is used to try to set a bit from '0' to '1' Status Register Error bit DQ5 will be set to '1'. Quadruple Word Program Command. The Quadruple Word Program command improves the programming throughput by writing a page of four adjacent words in parallel. The four words must differ only for the addresses A0 and A1. The V<sub>PPF</sub> supply voltage is required to be from 11.4V to 12.6V for the Quadruple Word Program command. The command uses the two unlock cycles followed by a write cycle to setup the command. A further four cycles are required to latch the address and data of the four Words and start the Program Erase Controller. The Quadruple Word Program command can be executed in Bypass mode to skip the two unlock cycles. Note that the Quadruple Word Program command cannot change a bit set to '0' back to '1'. One of the Erase Commands must be used to set all the bits in a block or in the whole bank from '0' to '1'. If the Quadruple Word Program command is used to try to set a bit from '0' to '1' Status Register Error bit DQ5 will be set to '1'. **Enter Bypass Mode Command.** The Bypass mode is used to reduce the overall programming time when large memory arrays need to be programmed. The Enter Bypass Mode command uses the two unlock cycles followed by one write cycle to set up the command. Once in Bypass mode, it is imperative that only the following commands be issued: Exit Bypass, Program, Double Word Program or Quadruple Word Program. **Exit Bypass Mode Command.** The Exit Bypass Mode command uses two write cycles to setup and confirm the command. The unlock cycles are not required. After the Exit Bypass Mode command, the device resets to Read mode. Program in Bypass Mode Command. The Program in Bypass Mode command can be issued when the device is in Bypass mode (issue a Enter Bypass Mode command). It uses the same sequence of cycles as the Program command with the exception of the unlock cycles. Double Word Program in Bypass Mode Command. The Double Word Program in Bypass Mode command can be issued when the device is in Bypass mode (issue a Enter Bypass Mode command). It uses the same sequence of cycles as the Double Word Program command with the exception of the unlock cycles. Quadruple Word Program in Bypass Mode Command. The Quadruple Word Program in Bypass Mode command can be issued when the device is in Bypass mode (issue a Enter Bypass Mode command). It uses the same sequence of cycles as the Quadruple Word Program command with the exception of the unlock cycles. **Block Lock Command.** The Block Lock command is used to lock a block and prevent Program or Erase operations from changing the data in it. All blocks are locked at power-up or reset. Three Bus Write cycles are required to issue the Block Lock command. - The first two bus cycles unlock the Command Interface. - The third bus cycle sets up the Block Lock command and latches the block address. The lock status can be monitored for each block using the Auto Select command. Table 10 shows the Lock Status after issuing a Block Lock command. The Block Lock bits are volatile, once set they remain set until a hardware reset or power-down/power-up. They are cleared by a Blocks Unlock command. Refer to the section, Block Locking, for a detailed explanation. **Block Unlock Command.** The Blocks Unlock command is used to unlock a block, allowing the block to be programmed or erased. Three Bus Write cycles are required to issue the Blocks Unlock command. - The first two bus cycles unlock the Command Interface. - The third bus cycle sets up the Block UnLock command and latches the block address. The lock status can be monitored for each block using the Auto Select command. Table 10 shows the lock status after issuing a Block Unlock command. Refer to the section, Block Locking, for a detailed explanation. **Block Lock-Down Command.** A locked or unlocked block can be locked-down by issuing the Block Lock-Down command. A locked-down block cannot be programmed or erased, or have its protection status changed when $\overline{WPF}$ is Low, $V_{IL}$ . When $\overline{WPF}$ is High, $V_{IH}$ , the Lock-Down function is disabled and the locked blocks can be individually unlocked by the Block Unlock command. Three Bus Write cycles are required to issue the Block Lock-Down command. - The first two bus cycles unlock the Command Interface. - The third bus cycle sets up the Block Lock-Down command and latches the block address. The lock status can be monitored for each block using the Auto Select command. Locked-Down blocks revert to the locked (and not locked-down) state when the device is reset on power-down. Table 10 shows the Lock Status after issuing a Block Lock-Down command. Refer to the section, Block Locking, for a detailed explanation. **Block Erase Command.** The Block Erase command can be used to erase a block. It sets all the bits within the selected block to '1'. All previous data in the block is lost. If the block is protected then the Erase operation will abort, the data in the block will not be changed and the device will return to Read Array mode. It is not necessary to pre-pro- gram the block as the Program/Erase Controller does it automatically before erasing. Six Bus Write cycles are required to issue the command. - The first two write cycles unlock the Command Interface. - The third write cycles sets up the command - the fourth and fifth write cycles repeat the unlock sequence - the sixth write cycle latches the block address and confirms the command. Additional Block Erase confirm cycles can be issued to erase other blocks without further unlock cycles. All blocks must belong to the same bank; if a new block belonging to the other bank is given, the operation is aborted. The additional Block Erase confirm cycles must be given within the DQ3 erase timeout period. Each time a new confirm cycle is issued the timeout period restarts. The status of the internal timer can be monitored through the level of DQ3, see Status Register section for more details. Once the command is issued the device outputs the Status Register data when any address within the bank is read. After the command has been issued the Flash Read/Reset command will be accepted during the DQ3 timeout period, after that only the Erase Suspend command will be accepted. On successful completion of the Block Erase command, the device returns to Read Array mode. Bank Erase Command. The Bank Erase command can be used to erase a bank. It sets all the bits within the selected bank to '1'. All previous data in the bank is lost. The Bank Erase command will ignore any protected blocks within the bank. If all blocks in the bank are protected then the Bank Erase operation will abort and the data in the bank will not be changed. It is not necessary to pre-program the bank as the Program/Erase Controller does it automatically before erasing. As for the Block Erase command six Bus Write cycles are required to issue the command. - The first two write cycles unlock the Command Interface. - The third write cycles sets up the command - the fourth and fifth write cycles repeat the unlock sequence - the sixth write cycle latches the block address and confirms the command. Once the command is issued the device outputs the Status Register data when any address within the bank is read. On successful completion of the Bank Erase command, the device returns to Read Array mode. **Erase Suspend Command.** The Erase Suspend command is used to pause a Block Erase operation. In a Dual Bank memory it can be used to read data within the bank where an Erase operation is in progress. It is also possible to program data in blocks not being erased. One bus write cycle is required to issue the Erase Suspend command. The Program/Erase Controller suspends the Erase operation within 20µs of the Erase Suspend command being issued and bits 7, 6 and/ or 2 of the Status Register are set to '1'. The device is then automatically set to Read mode. The command can be addressed to any bank. During Erase Suspend the memory will accept the Erase Resume, Program, Read CFI Query, Auto Select, Block Lock, Block Unlock and Block Lock-Down commands. Erase Resume Command. The Erase Resume command can be used to restart the Program/ Erase Controller after an Erase Suspend command has paused it. One Bus Write cycle is required to issue the command. The command must be issued to an address within the bank being erased. The unlock cycles are not required. Protection Register Program Command. The Protection Register Program command is used to Program the Protection Register (One-Time-Programmable (OTP) segment and Protection Register Lock). The OTP segment is programmed 16 bits at a time. When shipped all bits in the segment are set to '1'. The user can only program the bits to '0'. Four write cycles are required to issue the Protection Register Program command. - The first two bus cycles unlock the Command Interface. - The third bus cycle sets up the Protection Register Program command. - The fourth latches the Address and the Data to be written to the Protection Register and starts the Program/Erase Controller. Read operations output the Status Register content after the programming has started. The OTP segment can be protected by programming bit 1 of the Protection Register Lock. The segment can be protected by programming bit 1 of the Protection Register Lock. Bit 1 of the Protection Register Lock also protects bit 2 of the Protection Register Lock. Programming bit 2 of the Protection Register Lock will result in a permanent protection of Parameter Block #0 (see Figure 5, Flash Security Block and Protection Register Memory Map). Attempting to program a previously protected Protection Register will result in a Status Register error. The protection of the Protection Register and/or the Security Block is not reversible. **Table 4. Flash Commands** | | les | | | | | В | us Op | eration | ıs | | | | | | | |---------------------------------------------|--------|------|------|------|----------|---------|-------------------------------------------------------------------------------------------------------------------|----------|----------|---------------|----------|----------|----------|----------|----------| | Commands | Cycles | 1: | st | 2nd | | 3 | rd | 41 | th | 5 | th | 61 | th | 7 | th | | | No of | Add | Data | Read/Reset | 1+ | Х | F0h | | | Read | Memor | y Array | until a | new w | rite cyc | le is in | itiated. | | | | iveau/iveset | 3+ | 555h | AAh | 2AAh | 55h | 555h | F0h | Read | Memor | y Array | until a | new w | rite cyc | le is in | itiated. | | CFI Query | 1+ | 55h | 98h | Re | ad CFI | and El | ectroni | c Signa | ature u | ntil a R | ead/Re | set cor | nmand | is issu | ed. | | Auto Select | 3+ | 555h | AAh | 2AAh | 55h | 555h | Read Protection Register, Block Protection or Configuration Register Status until a Read/Reset command is issued. | | | | | | | | | | Set Configuration<br>Register | 4 | 555h | AAh | 2AAh | 55h | 555h | 60h | CRD | 03h | | | | | | | | Program | 4 | 555h | AAh | 2AAh | 55h | 555h | A0h | PA | PD | Rea | | | or Tog | | until | | Double Word<br>Program | 5 | 555h | AAh | 2AAh | 55h | 555h | 40h | PA1 | PD1 | PA2 | PD2 | | | | | | Quadruple Word<br>Program | 5 | 555h | AAh | 2AAh | 55h | 555h | 50h | PA1 | PD1 | PA2 | PD2 | PA3 | PD3 | PA4 | PD4 | | Enter Bypass<br>Mode | 3 | 555h | AAh | 2AAh | 55h | 555h | 20h | | | | | | | | | | Exit Bypass<br>Mode | 2 | Х | 90h | Х | 00h | | | | | | | | | | | | Program in<br>Bypass Mode | 2 | Х | A0h | PA | PD | F | Read D | ata Pol | lling or | Toggle | Bit unt | il Progr | am cor | npletes | S. | | Double Word<br>Program in<br>Bypass Mode | 3 | х | 40h | PA1 | PD1 | PA2 | PD2 | | | | | | | | | | Quadruple Word<br>Program in<br>Bypass Mode | 3 | х | 50h | PA1 | PD1 | PA2 | PD2 | PA3 | PD3 | PA4 | PD4 | | | | | | Block Lock | 4 | 555h | AAh | 2AAh | 55h | 555h | 60h | ВА | 01h | | | | | | | | Block Unlock | 4 | 555h | AAh | 2AAh | 55h | 555h | 60h | ВА | D0h | | | | | | | | Block Lock-Down | 4 | 555h | AAh | 2AAh | 55h | 555h | 60h | ВА | 2Fh | | | | | | | | Block Erase | 6+ | 555h | AAh | 2AAh | 55h | 555h | 80h | 555h | AAh | 2AAh | 55h | ВА | 30h | | | | Bank Erase | 6 | 555h | AAh | 2AAh | 55h | 555h | 80h | 555h | AAh | 2AAh | 55h | ВА | 10h | | | | Erase Suspend | 1 | Х | B0h | Read | until To | oggle s | | en read | | | | | ny Blo | cks not | being | | Erase Resume | 1 | ВА | 30h | Rea | d Data | Polling | or Tog | gle Bits | | rase cer time | omplet | es or E | rase is | suspei | nded | | Protection<br>Register Program | 4 | 555h | AAh | 2AAh | 55h | PA | C0h | PA | PD | | | | | | | | | | | • | | _ | | | | | | | | | | | Note: X = Don't Care, BA = Block Address, PA = Program address, PD = Program Data, CRD = Configuration Register Data. For Coded cycles address inputs A12-A20 are don't care. **Table 5. Read Electronic Signature** | Code | Device | EF | GF | WF | A0 | <b>A</b> 1 | A7-A2 | A8-A20 | DQ15-DQ0 | |-------------------|------------|-----------------|----------|-----------------|-----------------|------------|-------|--------|----------| | Manufacturer Code | | $V_{IL}$ | $V_{IL}$ | V <sub>IH</sub> | $V_{IL}$ | $V_{IL}$ | 0 | Х | 0020h | | Device Code | M36DR432AD | VIL | VIL | V <sub>IH</sub> | V <sub>IH</sub> | VIL | 0 | Х | 00A0h | | Device Code | M36DR432BD | V <sub>IL</sub> | VIL | V <sub>IH</sub> | V <sub>IH</sub> | VIL | 0 | Х | 00A1h | Note: X = Don't care. **Table 6. Flash Read Block Protection** | Block Status | EF | GF | WF | Α0 | <b>A</b> 1 | A20-A12 | A7-A2 | Other<br>Addresses | DQ0 | DQ1 | DQ15-DQ2 | |----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|---------------|-------|--------------------|-----|-----|----------| | Locked Block | $V_{IL}$ | V <sub>IL</sub> | $V_{IH}$ | $V_{IL}$ | $V_{IH}$ | Block Address | 0 | X | 1 | 0 | 0000h | | Unlocked Block | $V_{IL}$ | $V_{IL}$ | $V_{IH}$ | $V_{IL}$ | $V_{IH}$ | Block Address | 0 | Х | 0 | 0 | 0000h | | Locked-Down<br>Block | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Block Address | 0 | Х | Х | 1 | 0000h | Note: X = Don't care. **Table 7. Configuration Register** | RPF Function | EF | GF | WF | Α0 | <b>A</b> 1 | A7-A2 | Other Addresses | DQ10 | DQ9-DQ0<br>DQ15-DQ11 | |------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------|-----------------|------|----------------------| | Reset | V <sub>IL</sub> | $V_{IL}$ | V <sub>IH</sub> | V <sub>IH</sub> | $V_{IH}$ | 0 | Х | 0 | Don't Care | | Reset/Power-Down | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | 0 | Х | 1 | Don't Care | Note: X = Don't care. 47/ **Table 8. Read Protection Register** | Word | EF | GF | WF | A20-A8 | A7-0 | DQ15-8 | DQ7-3 | DQ2 | DQ1 | DQ0 | |-------------|-----------------|-----------------|-----------------|--------|------|----------|----------|--------------------|------------------|----------| | Lock | VIL | VIL | V <sub>IH</sub> | Х | 80h | XXh | 00000b | Security prot.data | OTP<br>prot.data | 0 | | Unique ID 0 | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х | 81h | ID data | ID data | ID data | ID data | ID data | | Unique ID 1 | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х | 82h | ID data | ID data | ID data | ID data | ID data | | Unique ID 2 | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х | 83h | ID data | ID data | ID data | ID data | ID data | | Unique ID 3 | $V_{IL}$ | $V_{IL}$ | $V_{\text{IH}}$ | Х | 84h | ID data | ID data | ID data | ID data | ID data | | OTP 0 | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х | 85h | OTP data | OTP data | OTP data | OTP data | OTP data | | OTP 1 | $V_{IL}$ | $V_{IL}$ | $V_{\text{IH}}$ | Х | 86h | OTP data | OTP data | OTP data | OTP data | OTP data | | OTP 2 | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х | 87h | OTP data | OTP data | OTP data | OTP data | OTP data | | OTP 3 | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х | 88h | OTP data | OTP data | OTP data | OTP data | OTP data | Note: X= Don't care. Table 9. Program, Erase Times and Program, Erase Endurance Cycles | | | M36DR43 | 2AD, M36D | R432BD | | |-------------------------------------------------------------------|---------|---------|-----------|----------------------------------|--------| | Parameter | Min | Max | Тур | Typical after<br>100k W/E Cycles | Unit | | Parameter Block (4 KWord) Erase (Preprogrammed) | | 2.5 | 0.3 | 1 | S | | Main Block (32 KWord) Erase (Preprogrammed) | | 4 | 0.8 | 3 | S | | Bank Erase (Preprogrammed, Bank A) | | | 3 | 6 | S | | Bank Erase (Preprogrammed, Bank B) | | | 20 | 30 | s | | Chip Program <sup>(1)</sup> | | | 20 | 25 | s | | Chip Program (Double Word, V <sub>PPF</sub> = 12V) <sup>(1)</sup> | | | 8 | | s | | Word Program <sup>(2)</sup> | | 100 | 10 | | μs | | Double Word Program (V <sub>PPF</sub> = 12V) | | 100 | 8 | | μs | | Quadruple Word Program (V <sub>PPF</sub> = 12V) | | 100 | 8 | | μs | | Program/Erase Cycles (per Block) | 100,000 | | | | cycles | Note: 1. Excludes the time needed to execute the sequence for program command. 2. Same timing value if V<sub>PPF</sub> = 12V #### Flash Block Locking The Flash memory features an instant, individual block locking scheme that allows any block to be locked or unlocked with no latency. This locking scheme has two levels of protection. - Lock/Unlock this first level allows softwareonly control of block locking. - Lock-Down this second level requires hardware interaction before locking can be changed. The protection status of each block can be set to Locked, Unlocked, and Lock-Down. Table 10, defines all of the possible protection states (WPF, DQ1, DQ0). #### Reading a Block's Lock Status The lock status of every block can be read in the Auto Select mode of the device. Subsequent reads at the address specified in Table 6, will output the protection status of that block. The lock status is represented by DQ0 and DQ1. DQ0 indicates the Block Lock/Unlock status and is set by the Lock command and cleared by the Unlock command. It is also automatically set when enter- ing Lock-Down. DQ1 indicates the Lock-Down status and is set by the Lock-Down command. It cannot be cleared by software, only by a hardware reset or power-down. The following sections explain the operation of the locking system. #### **Locked State** The default status of all blocks on power-up or after a hardware reset is Locked (states (0,0,1) or (1,0,1)). Locked blocks are fully protected from any program or erase. Any program or erase operations attempted on a locked block will reset the device to Read Array mode. The Status of a Locked block can be changed to Unlocked or Lock-Down using the appropriate software commands. An Unlocked block can be Locked by issuing the Lock command. #### **Unlocked State** Unlocked blocks (states (0,0,0), (1,0,0) (1,1,0)), can be programmed or erased. All unlocked blocks return to the Locked state after a hardware reset or when the device is powered-down. The status of an unlocked block can be changed to Locked or Locked-Down using the appropriate software commands. A locked block can be unlocked by issuing the Unlock command. #### **Lock-Down State** Blocks that are Locked-Down (state (0,1,x))are protected from program and erase operations (as for Locked blocks) but their protection status cannot be changed using software commands alone. A Locked or Unlocked block can be Locked-Down by issuing the Lock-Down command. Locked-Down blocks revert to the Locked state when the device is reset or powered-down. The Lock-Down function is dependent on the WPF input pin. When $\overline{WPF}=0$ (V<sub>IL</sub>), the blocks in the Lock-Down state (0,1,x) are protected from program, erase and protection status changes. When WPF=1 (V<sub>IH</sub>) the Lock-Down function is disabled (1,1,1) and Locked-Down blocks can be individually unlocked to the (1.1.0) state by issuing the software command, where they can be erased and programmed. These blocks can then be re-locked (1,1,1) and unlocked (1,1,0) as desired while WPF remains High. When WPF is Low, blocks that were previously Locked-Down return to the Lock-Down state (0,1,x) regardless of any changes made while WPF was High. Device reset or power-down resets all blocks, including those in Lock-Down, to the Locked state. ### **Locking Operations During Erase Suspend** Changes to block lock status can be performed during an erase suspend by using the standard locking command sequences to unlock, lock or lock-down a block. This is useful in the case when another block needs to be updated while an erase operation is in progress. To change block locking during an erase operation, first write the Erase Suspend command, then check the status register until it indicates that the erase operation has been suspended. Next write the desired Lock command sequence to a block and the lock status will be changed. After completing any desired lock, read, or program operations, resume the erase operation with the Erase Resume command. If a block is locked or locked-down during an erase suspend of the same block, the locking status bits will be changed immediately, but when the erase is resumed, the erase operation will complete. 47/ Table 10. Flash Lock Status | Protection | rent<br>n Status <sup>(1)</sup><br>Q1, DQ0) | | Next Protect<br>(WPF, Do | ion Status <sup>(1)</sup><br>Q1, DQ0) | | |----------------------|---------------------------------------------|--------------------------------|----------------------------------|---------------------------------------|-------------------------------| | Current State | Program/Erase<br>Allowed | After<br>Block Lock<br>Command | After<br>Block Unlock<br>Command | After Block<br>Lock-Down<br>Command | After WPF transition | | 1,0,0 | yes | 1,0,1 | 1,0,0 | 1,1,1 | 0,0,0 | | 1,0,1 <sup>(2)</sup> | no | 1,0,1 | 1,0,0 | 1,1,1 | 0,0,1 | | 1,1,0 | yes | 1,1,1 | 1,1,0 | 1,1,1 | 0,1,1 | | 1,1,1 | no | 1,1,1 | 1,1,0 | 1,1,1 | 0,1,1 | | 0,0,0 | yes | 0,0,1 | 0,0,0 | 0,1,1 | 1,0,0 | | 0,0,1 <sup>(2)</sup> | no | 0,0,1 | 0,0,0 | 0,1,1 | 1,0,1 | | 0,1,1 | no | 0,1,1 | 0,1,1 | 0,1,1 | 1,1,1 or 1,1,0 <sup>(3)</sup> | Note: 1. The lock status is defined by the write protect pin and by DQ1 ('1' for a locked-down block) and DQ0 ('1' for a locked block) as read in the Auto Select command with A1 = V<sub>IH</sub> and A0 = V<sub>IL</sub>. - 2. All blocks are locked at power-up, so the default configuration is 001 or 101 according to WPF status. - 3. A WPF transition to VIH on a locked block will restore the previous DQ0 value, giving a 111 or 110. #### Flash Status Register The Status Register provides information on the current or previous Program or Erase operations. Bus Read operations from any address within the bank, always read the Status Register during Program and Erase operations. The various bits convey information about the status and any errors of the operation. The bits in the Status Register are summarized in Table 12, Status Register Bits. Refer to Tables 11 and 12 in conjunction with the following text descriptions. **Data Polling Bit (DQ7).** When Program operations are in progress, the Data Polling bit outputs the complement of the bit being programmed on DQ7. For a Double Word Program operation, it is the complement of DQ7 for the last Word written to the Command Interface. During an Erase operation, it outputs a '0'. After completion of the operation, DQ7 will output the bit last programmed or a '1' after erasing. Data Polling is valid and only effective during P/E.C. operation, that is after the fourth WF pulse for programming or after the sixth WF pulse for erase. It must be performed at the address being programmed or at an address within the block being erased. See Figure 22 for the Data Polling flow-chart and Figure 13 for the Data Polling waveforms. DQ7 will also flag an Erase Suspend by switching from '0' to '1' at the start of the Erase Suspend. In order to monitor DQ7 in the Erase Suspend mode an address within a block being erased must be provided. DQ7 will output '1' if the read is attempted on a block being erased and the data value on other blocks. During a program operation in Erase Suspend, DQ7 will have the same behavior as in the normal program. **Toggle Bit (DQ6).** When Program or Erase operations are in progress, successive attempts to read DQ6 will output complementary data. DQ6 will toggle following the toggling of either GF or EF. The operation is completed when two successive reads give the same output data. The next read will output the bit last programmed or a '1' after erasing. The Toggle Bit DQ6 is valid only during P/E.C. operations, that is after the fourth WF pulse for programming or after the sixth WF pulse for Erase. DQ6 will be set to '1' if a read operation is attempted on an Erase Suspend block. When erase is suspended DQ6 will toggle during programming operations in a block different from the block in Erase Suspend. See Figure 16 for Toggle Bit flowchart and Figure 14 for Toggle Bit waveforms. **Toggle Bit (DQ2).** Toggle Bit DQ2, together with DQ6, can be used to determine the device status during erase operations. During Erase Suspend a read from a block being erased will cause DQ2 to toggle. A read from a block not being erased will output data. DQ2 will be set to '1' during program operation and to '0' in erase operation. If a read operation is addressed to a block where an erase error has occurred, DQ2 will toggle. **Error Bit (DQ5).** The Error Bit can be used to identify if an error occurs during a program or erase operation. The Error Bit is set to '1' when a program or erase operation has failed. When it is set to '0' the program or erase operation was successful. If any Program command is used to try to set a bit from '0' to '1' Status Register Error bit DQ5 will be set to '1', only if $V_{PP}$ is in the range of 11.4V to 12.6V. The Error Bit is reset by a Read/Reset command. **Erase Timer Bit (DQ3).** The Erase Timer bit is used to indicate the timeout period for an erase operation. When the last block Erase command has been entered to the Command Interface and it is waiting for the erase operation to start, the Erase Timer Bit is set to '0'. When the erase timeout period is finished, DQ3 returns to '1', (80µs to 120µs). **DQ0, DQ1 and DQ4** are reserved for future use and should be masked. Table 11. Polling and Toggle Bits | Mode | DQ7 | DQ6 | DQ2 | |--------------------------------------------------------|-----|--------|--------| | Program | DQ7 | Toggle | 1 | | Erase | 0 | Toggle | N/A | | Erase Suspend Read<br>(in Erase Suspend<br>block) | 1 | 1 | Toggle | | Erase Suspend Read<br>(outside Erase Suspend<br>block) | DQ7 | DQ6 | DQ2 | | Erase Suspend Program | DQ7 | Toggle | 1 | **Table 12. Status Register Bits** | DQ | Name | Logic Level | Definition | Note | |----|-----------------|-------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------| | | | '1' | Erase complete or erase block in Erase Suspend. | | | | Data | '0' | Erase in progress | Indicates the P/E.C. status, check | | 7 | Data<br>Polling | DQ | Program complete or data of non erase block during Erase Suspend. | during Program or Erase, and on completion before checking bits DQ5 for Program or Erase success. | | | | DQ | Program in progress <sup>(2)</sup> | | | | | '-1-0-1-0-1-0-1-' | Erase or Program in progress | Successive reads output | | | | DQ | Program complete | complementary data on DQ6 while Programming or Erase operations are | | 6 | Toggle Bit | '-1-1-1-1-1-1-' | Erase complete or Erase<br>Suspend on currently addressed<br>block | in progress. DQ6 remains at constant level when P/E.C. operations are completed or Erase Suspend is acknowledged. | | _ | Error Bit | '1' | Program or Erase Error | This bit is set to '1' in the case of | | 5 | EIIOI BIL | '0' | Program or Erase in progress | Programming or Erase failure. | | 4 | Reserved | | | | | | Erase Time | '1' | Erase Timeout Period Expired | P/E.C. Erase operation has started.<br>Only possible command entry is Erase<br>Suspend | | 3 | Bit | '0' | Erase Timeout Period in progress | An additional block to be erased in parallel can be entered to the P/E.C provided that it belongs to the same bank | | 2 | Toggle Bit | '-1-0-1-0-1-0-1-' | Erase Suspend read in the Erase Suspended Block. Erase Error due to the currently addressed block (when DQ5 = '1'). | Indicates the erase status and allows | | _ | .099.0 Dit | 1 | Program in progress or Erase complete. | to identify the erased block. | | | | DQ | Erase Suspend read on non Erase Suspend block. | | | 1 | Reserved | | | | | 0 | Reserved | | | | Note: 1. Logic level '1' is High, '0' is Low. -0-1-0-0-1-1-1-0- represent bit value in successive read operations. 2. In case of double word program DQ7 refers to the last word input. #### SRAM COMPONENT The SRAM is a 4 Mbit (256Kb x16) low-power consumption memory array with low $V_{DDS}$ data retention. #### **SRAM Operations** The following operations can be performed using the appropriate bus cycles: Read Array, Write Array, Output Disable, Power Down (see Table 2). **Read.** Read operations are used to output the contents of the SRAM Array. The SRAM is in Read mode whenever Write Enable (WS) is at $V_{IH}$ with Output Enable (GS) at $V_{IL}$ , Chip Enable ES and UBS, LBS combinations are asserted. Valid data will be available at the output pins within $\underline{t_{AVQV}}$ after the <u>last</u> stable address, provided that GS is Low and ES is Low. If Chip Enable or Output Enable access times are not met, data access will be measured from the limiting parameter ( $t_{ELQV}$ or $t_{GLQV}$ ) rather than the address. Data out may be indeterminate at $t_{ELQX}$ and $t_{GLQX}$ , but data lines will always be valid at $t_{AVQV}$ (see Table 23, Figures 17 and 18). **Write.** Write operations are used to write data in the $\underline{SRAM}$ . The $\underline{SRAM}$ is in Write mode whenever the $\underline{WS}$ and $\underline{ES}$ pins are at $V_{IL}$ . Either the Chip Enable input ( $\overline{ES}$ ) or the Write Enable input ( $\overline{WS}$ ) must be de-asserted during address transitions for subsequent write cycles. Write begins with the concurrence of Chip Enable being active and $\overline{WS}$ at $V_{IL}$ . A Write begins at the latest transition among $\overline{\text{ES}}$ going to V<sub>IL</sub> and $\overline{\text{WS}}$ going to V<sub>IL</sub>. Therefore, address setup time is referenced to Write Enable and Chip Enable as $t_{\text{AVWL}}$ and $t_{\text{AVEL}}$ respectively, and is determined by the latter occurring edge. The Write cycle can be terminated by the rising edge of $\overline{\text{ES}}$ or the rising edge of $\overline{\text{WS}}$ , whichever occurs first. If the Output is enabled ( $\overline{ES}=V_{IL}$ and $\overline{GS}=V_{IL}$ ), then $\overline{WS}$ will return the outputs to high impedance within $t_{WLQZ}$ of its falling edge. Care must be taken to avoid bus contention in this type of operation. Data input must be valid for $t_{DVWH}$ before the rising edge of $\overline{ES}$ , whichever occurs first, and remain valid for $t_{WHDX}$ and $t_{EHAX}$ (see Table 24, Figure 20, 22, 24). **Standby/Power-Down.** The SRAM chip has a Chip Enable power-down feature which invokes an automatic standby mode (see Table 23, Figure 19) whenever either Chip Enable is de-asserted $(\overline{ES}=V_{IH})$ . **Data Retention.** The SRAM data retention performances as $V_{DDS}$ go down to $\underline{V_{DR}}$ are described in Table 25 and Figure 24. In $\overline{ES}$ controlled data retention mode, minimum standby current mode is entered when $\overline{ES} \geq V_{DDS} - 0.2V$ . **Output Disable.** The data outputs are high impedance when the <u>Output Enable</u> ( $\overline{GS}$ ) is at V<sub>IH</sub> with Write Enable ( $\overline{WS}$ ) at V<sub>IH</sub>. 47/ #### **MAXIMUM RATING** Stressing the device above the rating listed in the Absolute Maximum Ratings table 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 im- plied. Exposure to Absolute Maximum Rating conditions for extended periods may affect device reliability. Refer also to the STMicroelectronics SURE Program and other relevant quality documents. Table 13. Absolute Maximum Ratings<sup>(1)</sup> | Symbol | Parameter | Value | Unit | |---------------------|-----------------------------------|---------------------------------------------|------| | T <sub>A</sub> | Ambient Operating Temperature (3) | -40 to 85 | °C | | T <sub>BIAS</sub> | Temperature Under Bias | -40 to 125 | °C | | T <sub>STG</sub> | Storage Temperature | -55 to 150 | °C | | V <sub>IO</sub> (2) | Input or Output Voltage | –0.5 to V <sub>DD</sub> <sup>(3)</sup> +0.5 | V | | V <sub>DDF</sub> | Supply Voltage | -0.5 to 2.7 | V | | V <sub>DDS</sub> | SRAM Chip Supply Voltage | -0.5 to 2.4 | V | | V <sub>PPF</sub> | Program Voltage | -0.5 to 13 | V | Note: 1. Minimum voltage may undershoot to -2V during transition and for less than 20ns. <sup>2.</sup> Depends on range. <sup>3.</sup> $V_{DD} = V_{DDS} = V_{DDF}$ . #### DC AND AC PARAMETERS This section summarizes the operating measurement conditions, and the DC and AC characteristics of the device. The parameters in the DC and AC characteristics Tables that follow, are derived from tests performed under the Measurement Conditions summarized in Table 14, Operating and AC Measurement Conditions. Designers should check that the operating conditions in their circuit match the operating conditions when relying on the quoted parameters. **Table 14. Operating and AC Measurement Conditions** | | SR | AM | | | | | | |------------------------------------------------------|----------------|-----------------|----------------|-----------------|----------------------|-----------------|--------| | Parameter | 70 | | 85 | | 100, 120 | | Units | | Farameter | Min | Max | Min | Max | Min | Max | Offics | | V <sub>DDF</sub> Supply Voltage | - | - | 1.8 | 2.2 | 1.65 | 2.2 | V | | V <sub>DDS</sub> Supply Voltage | 1.65 | 2.2 | - | - | | | V | | V <sub>PPF</sub> Supply Voltage | | | 11.4 | 12.6 | 11.4 | 12.6 | V | | Ambient Operating Temperature | - 40 | 85 | - 40 | 85 | - 40 | 85 | °C | | Load Capacitance (C <sub>L</sub> ) | 30 | 5 | 3 | 0 | 3 | 0 | pF | | Input Rise and Fall Times | | 2 | | 4 | | 4 | ns | | Input Pulse Voltages <sup>(1)</sup> | 0 to | $V_{DD}$ | 0 to | $V_{DD}$ | 0 to V <sub>DD</sub> | | V | | Input and Output Timing Ref. Voltages <sup>(1)</sup> | V <sub>D</sub> | <sub>D</sub> /2 | V <sub>D</sub> | <sub>D</sub> /2 | V <sub>D</sub> | <sub>D</sub> /2 | V | Note: 1. V<sub>DD</sub> = V<sub>DDS</sub> = V<sub>DDF</sub> Figure 6. AC Measurement I/O Waveform Note: V<sub>DD</sub> means V<sub>DDF</sub> = V<sub>DDS</sub> Figure 7. AC Measurement Load Circuit Note: $V_{DD}$ means $V_{DDF} = V_{DDS}$ **Table 15. Device Capacitance** | Symbol | Parameter | Test Condition | Min | Max | Unit | |------------------|--------------------|-----------------------|-----|-----|------| | C <sub>IN</sub> | Input Capacitance | $V_{IN} = 0V$ | | 12 | pF | | C <sub>OUT</sub> | Output Capacitance | V <sub>OUT</sub> = 0V | | 15 | pF | Note: Sampled only, not 100% tested. **Table 16. Flash DC Characteristics** | Symbol | Parameter | Test Condition | Min | Тур | Max | Unit | |-----------------------------------|-------------------------------------------------------|---------------------------------------------------------------------|-----------------------|-----|-----------------------|------| | ILI | Input Leakage Current | $0V \le V_{IN} \le V_{DD}$ | | | ±1 | μA | | I <sub>LO</sub> | Output Leakage Current | $0V \le V_{OUT} \le V_{DD}$ | | | ±5 | μA | | I <sub>CC1</sub> | Supply Current<br>(Read Mode) | EF = V <sub>IL</sub> , GF = V <sub>IH</sub> , f = 6MHz | | 3 | 6 | mA | | I <sub>CC2</sub> | Supply Current<br>(Power-Down) | $\overline{RPF} = V_{SS} \pm 0.2V$ | | 2 | 10 | μA | | I <sub>CC3</sub> | Supply Current (Standby) | $\overline{EF} = V_{DD} \pm 0.2V$ | | 10 | 50 | μA | | I <sub>CC4</sub> <sup>(1)</sup> | Supply Current<br>(Program or Erase) | Word Program, Block Erase in progress | | 10 | 20 | mA | | I <sub>CC5</sub> <sup>(1)</sup> | Supply Current<br>(Dual Bank) | Program/Erase in progress<br>in one Bank, Read in the<br>other Bank | | 13 | 26 | mA | | I <sub>PPF1</sub> | V <sub>PPF</sub> Supply Current<br>(Program or Erase) | V <sub>PPF</sub> = 12V ± 0.6V | | 2 | 5 | mA | | lance | V <sub>PPF</sub> Supply Current | V <sub>PPF</sub> ≤ V <sub>DD</sub> | | 0.2 | 5 | μA | | I <sub>PPF2</sub> | (Standby or Read) | V <sub>PPF</sub> = 12V ± 0.6V | | 100 | 400 | μΑ | | VIL | Input Low Voltage | | -0.5 | | 0.4 | V | | VIH | Input High Voltage | | V <sub>DD</sub> – 0.4 | | V <sub>DD</sub> + 0.4 | V | | V <sub>OL</sub> | Output Low Voltage | I <sub>OL</sub> = 100μA | | | 0.1 | V | | V <sub>OH</sub> | Output High Voltage<br>CMOS | I <sub>OH</sub> = -100μA | V <sub>DD</sub> -0.1 | | | V | | V <sub>PPF</sub> <sup>(2,3)</sup> | V <sub>PPF</sub> Supply Voltage | | -0.4 | | V <sub>DD</sub> + 0.4 | V | | V PPF ` ' ' ' | (Program or Erase) | Double Word Program | 11.4 | | 12.6 | V | Note: 1. Sampled only, not 100% tested. 2. VPPF may be connected to 12V power supply for a total of less than 100 hrs. 3. For standard program/erase operation VPPF is don't care. ## **Table 17. SRAM DC Characteristics** $(T_A = -40 \text{ to } 85^{\circ}\text{C}; V_{DDF} = V_{DDS} = 1.65 \text{V to } 2.2 \text{V})$ | Symbol | Parameter | Test Condition | Min | Тур | Max | Unit | |------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------|------|-----|------------------------|------| | loz | Output Leakage<br>Current | 0V ≤ V <sub>OUT</sub> ≤ V <sub>DDS</sub> , output disabled | -1 | +1 | +1 | μΑ | | I <sub>IX</sub> | Input Load Current | $0V \le V_{IN} \le V_{DDS}$ | -1 | ±1 | +1 | μA | | I <sub>DDS</sub> | V <sub>DD</sub> Standby<br>Current | $\overline{ES} \ge V_{DDS} - 0.2V, V_{IN} \ge V_{DDS} - 0.2V$ or $V_{IN} \le 0.2V$ , f=0 $V_{DDS} = 2.2V$ | | 1 | 10 | μА | | I <sub>DD</sub> | Supply Current | $I_{OUT} = 0$ mA, $f = f_{MAX} = 1/t_{RC}$ , CMOS levels $V_{DDS} = 2.2V$ | | 4 | 7 | mA | | טטי | Зирріу Сипепі | I <sub>OUT</sub> = 0 mA, f = 0Hz<br>CMOS levels | | 1 | 5 | mA | | V <sub>IL</sub> | Input Low Voltage | V <sub>DDS</sub> = 1.65V | -0.5 | | 0.4 | V | | V <sub>IH</sub> | Input High Voltage | $V_{DDS} = 2.2V$ | 1.4 | | V <sub>DDS</sub> +0.2V | V | | V <sub>OL</sub> | Output Low Voltage | V <sub>DDS</sub> = 1.65V<br>I <sub>OL</sub> = 0.1μA | | | 0.2 | V | | VoH | Output High Voltage | $V_{DDS} = 1.65V$ $I_{OH} = -0.1\mu A$ | 1.4 | | | V | Note: 1. IDDES and IDDWS are specified with device deselected. If device is read while in erase suspend, current draw is sum of IDDES and $I_{DDR}$ . If the device is read while in program suspend, current draw is the sum of $I_{DDWS}$ and $I_{DDR}$ . 2. $V_{IN} = V_{IL}$ or $V_{IH}$ Figure 8. Flash Random Read AC Waveforms AI07312 - tAXQX - tGHQX -- tGHQZ tEHQZ tEHQX -VALID tAVAV – VALID tGLQV tGLQX tELQV tELQX tAVQV **Note:** Write Enable $(\overline{WF})$ = High. 出 GFI Figure 9. Flash Page Read AC Waveforms **Table 18. Flash Read AC Characteristics** | | | | | | M36D | R432A | ), M36D | R432B[ | ) | | |-----------------------|------------------|--------------------------------------------|---------------------------------------------------|-------------------|-------------------|-------|---------|--------|-----|------| | Symbol | Alt | Parameter | Test Condition | 8 | 5 | 10 | 00 | 12 | 20 | Unit | | | | | | Min | Max | Min | Max | Min | Max | | | t <sub>AVAV</sub> | t <sub>RC</sub> | Address Valid to Next<br>Address Valid | $\overline{EF} = V_{IL}, \overline{GF} = V_{IL}$ | 85 <sup>(3)</sup> | | 100 | | 120 | | ns | | t <sub>AVQV</sub> | t <sub>ACC</sub> | Address Valid to<br>Output Valid (Random) | $\overline{EF} = V_{IL}, \overline{GF} = V_{IL}$ | | 85 <sup>(3)</sup> | | 100 | | 120 | ns | | t <sub>AVQV1</sub> | tPAGE | Address Valid to<br>Output Valid (Page) | $\overline{EF} = V_{IL}, \overline{GF} = V_{IL}$ | | 30 <sup>(3)</sup> | | 35 | | 45 | ns | | t <sub>ELQX</sub> (1) | t <sub>LZ</sub> | Chip Enable Low to<br>Output Transition | GF = V <sub>IL</sub> | 0 | | 0 | | 0 | | ns | | t <sub>ELQV</sub> (2) | t <sub>CE</sub> | Chip Enable Low to<br>Output Valid | GF = V <sub>IL</sub> | | 85 <sup>(3)</sup> | | 100 | | 120 | ns | | t <sub>GLQX</sub> (1) | t <sub>OLZ</sub> | Output Enable Low to Output Transition | EF = V <sub>IL</sub> | 0 | | 0 | | 0 | | ns | | t <sub>GLQV</sub> (2) | t <sub>OE</sub> | Output Enable Low to<br>Output Valid | EF = V <sub>IL</sub> | | 25 <sup>(3)</sup> | | 25 | | 35 | ns | | t <sub>EHQX</sub> | t <sub>OH</sub> | Chip Enable High to<br>Output Transition | GF = V <sub>IL</sub> | 0 | | 0 | | 0 | | ns | | t <sub>EHQZ</sub> (1) | t <sub>HZ</sub> | Chip Enable High to Output Hi-Z | GF = V <sub>IL</sub> | | 20 <sup>(3)</sup> | | 25 | | 35 | ns | | t <sub>GHQX</sub> | t <sub>OH</sub> | Output Enable High to Output Transition | EF = V <sub>IL</sub> | 0 | | 0 | | 0 | | ns | | t <sub>GHQZ</sub> (1) | t <sub>DF</sub> | Output Enable High to Output Hi-Z | EF = V <sub>IL</sub> | | 20 <sup>(3)</sup> | | 25 | | 35 | ns | | t <sub>AXQX</sub> | t <sub>OH</sub> | Address Transition to<br>Output Transition | $\overline{EF} = V_{IL}, \overline{GF} = V_{IL}$ | 0 | | 0 | | 0 | | ns | Note: 1. Sampled only, not 100% tested. 2. GF may be delayed by up to t<sub>ELQV</sub> - t<sub>GLQV</sub> after the falling edge of EF without increasing t<sub>ELQV</sub>. 3. To be characterized. tAVAV A0-A20 VALID tWLAX tAVWL tWHEH-EF tELWL tWHGL GF tGHWL tWLWH · WF tWHWL tDVWH tWHDX DQ0-DQ15 VALID $V_{\text{DDF}}$ tVDHEL -AI07314 Figure 10. Flash Write AC Waveforms, Write Enable Controlled Note: Addresses are latched on the falling edge of $\overline{WF}$ , Data is latched on the rising edge of $\overline{WF}$ . Table 19. Flash Write AC Characteristics, Write Enable Controlled | | | | | M36DR432AD, M36DR432BD | | | | | | |--------------------|------------------|------------------------------------------------|-------------------|------------------------|-----|-----|-----|-----|------| | Symbol | Alt | Parameter | 85 | | 100 | | 120 | | Unit | | | | | Min | Max | Min | Max | Min | Max | | | t <sub>AVAV</sub> | twc | Address Valid to Next Address Valid | 85 <sup>(1)</sup> | | 100 | | 120 | | ns | | t <sub>ELWL</sub> | t <sub>CS</sub> | Chip Enable Low to Write Enable Low | 0 | | 0 | | 0 | | ns | | t <sub>WLWH</sub> | t <sub>WP</sub> | Write Enable Low to Write Enable High | 50 <sup>(1)</sup> | | 50 | | 50 | | ns | | t <sub>DVWH</sub> | t <sub>DS</sub> | Input Valid to Write Enable High | 40 <sup>(1)</sup> | | 50 | | 50 | | ns | | twhox | t <sub>DH</sub> | Write Enable High to Input Transition | 0 | | 0 | | 0 | | ns | | t <sub>WHEH</sub> | t <sub>CH</sub> | Write Enable High to Chip Enable High | 0 | | 0 | | 0 | | ns | | t <sub>WHWL</sub> | t <sub>WPH</sub> | Write Enable High to Write Enable Low | 30 | | 30 | | 30 | | ns | | t <sub>AVWL</sub> | t <sub>AS</sub> | Address Valid to Write Enable Low | 0 | | 0 | | 0 | | ns | | $t_{WLAX}$ | t <sub>AH</sub> | Write Enable Low to Address Transition | 50 | | 50 | | 50 | | ns | | tGHWL | | Output Enable High to Write Enable Low | 0 | | 0 | | 0 | | ns | | t <sub>VDHEL</sub> | t <sub>VCS</sub> | V <sub>DD</sub> High to Chip Enable Low | 50 | | 50 | | 50 | | μs | | t <sub>WHGL</sub> | toeh | Write Enable High to Output Enable Low | 30 | | 30 | | 30 | | ns | | t <sub>PLQ7V</sub> | | RPF Low to Reset Complete During Program/Erase | | 15 | | 15 | | 15 | μs | Note: 1. To be characterized. 477 Figure 11. Flash Write AC Waveforms, Chip Enable Controlled Note: Addresses are latched on the falling edge of $\overline{EF}$ , Data is latched on the rising edge of $\overline{EF}$ . Table 20. Flash Write AC Characteristics, Chip Enable Controlled | | | | | M36DR | 432AD, | M36DR | 432BD | | | |--------------------|------------------|------------------------------------------------|-------------------|-------|--------|-------|-------|-----|------| | Symbol | Alt | Parameter | 8 | 5 | 100 | | 120 | | Unit | | | | | Min | Max | Min | Max | Min | Max | | | t <sub>AVAV</sub> | t <sub>WC</sub> | Address Valid to Next Address Valid | 85 <sup>(1)</sup> | | 100 | | 120 | | ns | | twlel | tws | Write Enable Low to Chip Enable Low | 0 | | 0 | | 0 | | ns | | t <sub>ELEH</sub> | t <sub>CP</sub> | Chip Enable Low to Chip Enable High | 50 <sup>(1)</sup> | | 50 | | 50 | | ns | | t <sub>DVEH</sub> | t <sub>DS</sub> | Input Valid to Chip Enable High | 40 <sup>(1)</sup> | | 50 | | 50 | | ns | | t <sub>EHDX</sub> | t <sub>DH</sub> | Chip Enable High to Input Transition | 0 | | 0 | | 0 | | ns | | tehwh | t <sub>WH</sub> | Chip Enable High to Write Enable High | 0 | | 0 | | 0 | | ns | | tehel | tcph | Chip Enable High to Chip Enable Low | 30 | | 30 | | 30 | | ns | | t <sub>AVEL</sub> | t <sub>AS</sub> | Address Valid to Chip Enable Low | 0 | | 0 | | 0 | | ns | | t <sub>ELAX</sub> | t <sub>AH</sub> | Chip Enable Low to Address Transition | 50 | | 50 | | 50 | | ns | | tGHEL | | Output Enable High Chip Enable Low | 0 | | 0 | | 0 | | ns | | t <sub>VDHWL</sub> | t <sub>VCS</sub> | V <sub>DD</sub> High to Write Enable Low | 50 | | 50 | | 50 | | μs | | tEHGL | toeh | Chip Enable High to Output Enable Low | 30 | | 30 | | 30 | | ns | | t <sub>PLQ7V</sub> | | RPF Low to Reset Complete During Program/Erase | | 15 | | 15 | | 15 | μs | Note: 1. To be characterized Figure 12. Flash Reset/Power-Down AC Waveform Table 21. Flash Reset/Power-Down AC Characteristics | | Alt | Parameter | Test Condition | M36DR432AD, M36DR432BD | | | | | | | |---------------------|-----------------|---------------------------------------------------------|----------------|------------------------|-----|-----|-----|-----|-----|------| | Symbol | | | | 85 | | 100 | | 120 | | Unit | | | | | | Min | Max | Min | Max | Min | Max | | | t <sub>PHQ7V1</sub> | | RPF High to Data Valid (Read Mode) | | | 150 | | 150 | | 150 | ns | | t <sub>PHQ7V2</sub> | | RPF High to Data Valid<br>(Reset/Power-Down<br>enabled) | | | 50 | | 50 | | 50 | μs | | t <sub>PLQ7V</sub> | | RPF Low to Reset<br>Complete | During Program | | 10 | | 10 | | 10 | μs | | | | | During Erase | | 20 | | 20 | | 20 | μs | | t <sub>PLPH</sub> | t <sub>RP</sub> | RPF Pulse Width | | 50 | | 50 | | 50 | | ns | AI07317 — MEMORY —— ARRAY READ CYCLE VALID VALID ADDRESS (WITHIN BLOCKS) DATA POLLING (LAST) CYCLE tazvav 🕂 GNORE DQ7 tGLQV ▲ tELQV tehQ7V tAVQV tWHQ7V -DATA POLLING → READ CYCLES CYCLE OF PROGRAM OR ERASE INSTRUCTION DQ0-DQ6/ DQ8-DQ15\_ A0-A20 DQ7 $|\frac{1}{4}$ 18 Ш Figure 13. Flash Data Polling DQ7 AC Waveforms Figure 14. Flash Data Toggle DQ6, DQ2 AC Waveforms VALID VALID MEMORY ARRAY READ CYCLE tGLQV tELQV VALID tAVQV STOP TOGGLE DATA TOGGLE READ CYCLE IGNORE tehav tWHQV — DATA — TOGGLE READ CYCLE Note: All other timings are as a normal Read cycle. ↑ LAST WRITE ↑ CYCLE OF PROGRAM OF ERASE INSTRUCTION DQ0-DQ1,DQ3-DQ5, DQ7-DQ15 DQ6,DQ2 A0-A20 WF 出 16 Table 22. Flash Data Polling and Toggle Bits AC Characteristics | Symbol | Parameter | M36DR432AD,<br>M36DR432BD | | Unit | |---------------------|-------------------------------------------------------------|---------------------------|-----|------| | | | Min | Max | | | t.v.(10=)/ | Write Enable High to DQ7 Valid (Program, WF Controlled) | 8 | 100 | μs | | t <sub>WHQ7V</sub> | Write Enable High to DQ7 Valid (Block Erase, WF Controlled) | 0.8 | 4 | S | | <b>t-</b> | Chip Enable High to DQ7 Valid (Program, EF Controlled) | 8 | 100 | μs | | tEHQ7V | Chip Enable High to DQ7 Valid (Block Erase, EF Controlled) | 0.8 | 4 | S | | t <sub>Q7</sub> VQV | Q7 Valid to Output Valid (Data Polling) | | 0 | ns | | <b>4</b> | Write Enable High to Output Valid (Program) | | 100 | μs | | twhqv | Write Enable High to Output Valid (Block Erase) | 0.8 | 4 | S | | teuov | Chip Enable High to Output Valid (Program) | 8 | 100 | μs | | <sup>t</sup> EHQV | Chip Enable High to Output Valid (Block Erase) | 0.8 | 4 | s | Note: All other timings are defined in Read AC Characteristics Figure 15. Flash Data Polling Flowchart START READ DQ5 & DQ7 at VALID ADDRESS DQ7 YES DATA NO NO YES READ DQ7 DQ7 YES DATA NO FAIL PASS AI06197 Figure 16. Flash Data Toggle Flowchart Figure 17. SRAM Read Mode AC Waveforms, Address Controlled with $\overline{\text{UBS}} = \overline{\text{LBS}} = V_{\text{IL}}$ Note: $\overline{\mathsf{ES}} = \mathsf{Low}, \overline{\mathsf{GS}} = \mathsf{Low}, \overline{\mathsf{WS}} = \mathsf{High}.$ Figure 18. SRAM Read AC Waveforms, ES or GS Controlled Note: Write Enable $(\overline{WS})$ = High. Figure 19. SRAM Standby AC Waveforms **Table 23. SRAM Read AC Characteristics**) | Symbol Alt | | | SR | AM | | | |--------------------------------|------------------|-----------------------------------------|-----|-----|----|--| | | | Parameter | 7 | 70 | | | | | | | Min | Max | | | | t <sub>AVAV</sub> | t <sub>RC</sub> | Read Cycle Time | 70 | | ns | | | t <sub>AVQV</sub> | t <sub>AA</sub> | Address Valid to Output Valid | | 70 | ns | | | t <sub>AXQX</sub> | toH | Address Transition to Output Transition | 10 | | ns | | | t <sub>BHQZ</sub> | t <sub>BHZ</sub> | UBS, LBS Disable to Hi-Z Output | | 25 | ns | | | t <sub>BLQV</sub> | t <sub>BA</sub> | UBS, LBS Access Time | | 45 | ns | | | t <sub>BLQX</sub> | t <sub>BLZ</sub> | UBS, LBS Enable to Low-Z Output | 5 | | ns | | | t <sub>EHQZ</sub> | t <sub>HZ</sub> | Chip Enable High to Output Hi-Z | | 25 | ns | | | t <sub>ELQV</sub> | tACE | Chip Enable Low to Output Valid | | 70 | ns | | | t <sub>ELQX</sub> | t <sub>LZ</sub> | Chip Enable Low to Output Transition | 5 | | ns | | | tGHQZ | tonz | Output Enable High to Output Hi-Z | | 25 | ns | | | t <sub>GLQV</sub> | t <sub>EO</sub> | Output Enable Low to Output Valid | | 35 | ns | | | tGLQX | toLZ | Output Enable Low to Output Transition | 5 | | ns | | | t <sub>PD</sub> <sup>(1)</sup> | | Chip Enable High to Power Down | | 70 | ns | | | t <sub>PU</sub> <sup>(1)</sup> | | Chip Enable Low to Power Up | 0 | | ns | | Note: 1. Sampled only. Not 100% tested. 47/ Figure 20. SRAM Write AC Waveforms, WS Controlled with GS Low Note: Output Enable $(\overline{GS})$ = Low. Figure 21. SRAM Write AC Waveforms, WS Controlled with GS High Figure 22. SRAM Write Cycle Waveform, UBS and LBS Controlled, G Low Note: Output Enable $(\overline{GS})$ = High. Table 24. SRAM Write AC Characteristics | Symbol Alt | | | SRAM<br>70 | | | | |---------------------|---------------------|-----------------------------------------|------------|-----|------|--| | | | Parameter | | | Unit | | | | | | Min | Max | | | | t <sub>AVAV</sub> | t <sub>WC</sub> | Write Cycle Time | 70 | | ns | | | t <sub>AVEL</sub> | t <sub>AS</sub> (1) | Address Valid to Chip Enable Low | 0 | | ns | | | t <sub>AVWH</sub> | t <sub>AW</sub> | Address Valid to Write Enable High | 60 | | ns | | | t <sub>AVWL</sub> | t <sub>AS</sub> (1) | Address Valid to Write Enable Low | 0 | | ns | | | t <sub>BLWH</sub> | t <sub>BW</sub> | UBS, LBS Valid to End of Write | | 60 | ns | | | t <sub>DVWH</sub> | t <sub>DW</sub> | Input Valid to Write Enable High | 30 | | ns | | | t <sub>EHAX</sub> | t <sub>WR</sub> (2) | Chip Enable High to Address Transition | 0 | | ns | | | t <sub>ELWH</sub> , | t <sub>CW</sub> (3) | Chip Select to End of Write | 60 | | ns | | | t <sub>WHAX</sub> | t <sub>WR</sub> (2) | Write Enable High to Address Transition | 0 | | ns | | | t <sub>WHDX</sub> | t <sub>DH</sub> | Write Enable High to Input Transition | 0 | | ns | | | t <sub>WHQX</sub> | t <sub>OW</sub> | Write Enable High to Output Transition | 10 | | ns | | | t <sub>WLQZ</sub> | t <sub>WHZ</sub> | Write Enable Low to Output Hi-Z | | 25 | ns | | | t <sub>WLWH</sub> | t <sub>WP</sub> (4) | Write Enable Pulse Width | 50 | | ns | | Note: 1. t<sub>AS</sub> is measured from the address valid to the beginning of write. - 2. t<sub>WR</sub> is measured from the end or write to the address change. t<sub>WR</sub> applied in case a write ends as ES or WS goes High. - town is measured from ES going Low end of write. A Write occurs during the overlap (twp) of Low ES and Low WS. A write begins when ES goes Low and WS goes Low with asserting. UBS or LBS for single byte operation or simultaneously asserting UBS and LBS for double byte operation. A write ends at the earliest transition when ES goes High and WS goes High. The two is measured from the beginning of write to the end of write. Figure 24. SRAM Low V<sub>DDS</sub> Data Retention AC Waveforms, ES Controlled Table 25. SRAM Low V<sub>DDS</sub> Data Retention Characteristics <sup>(1, 2)</sup> | Symbol | Parameter | Test Condition | Min | Typical | Max | Unit | |-------------------|-------------------------------------|---------------------------------------------------------------------------------------------|-----------------|---------|-----|------| | I <sub>DDDR</sub> | Supply Current (Data Retention) | $V_{DDS} = 1.0V$ , $\overline{ES} \ge V_{DDS} - 0.2V$<br>no input may exceed $V_{DDS} + 2V$ | | 0.5 | 10 | μA | | V <sub>DR</sub> | Supply Voltage (Data Retention) | $\overline{\text{ES}} \ge V_{\text{DDS}} - 0.2V$ | 1 | | 2.2 | V | | t <sub>CDR</sub> | Chip Disable to Data Retention Time | <u>ES</u> ≥ V <sub>DDS</sub> – 0.2V | 0 | | | ns | | t <sub>R</sub> | Operation Recovery Time | | t <sub>RC</sub> | | | ns | Note: 1. All other Inputs $V_{IH} \le V_{DDS} - 0.2V$ or $V_{IL} \le 0.2V$ . 2. Sampled only. Not 100% tested. ## **PACKAGE MECHANICAL** Figure 25. Stacked LFBGA 12x8mm - 8x8 ball array, 0.8mm pitch, Bottom View Package Outline Note: Drawing is not to scale. Table 26. Stacked LFBGA 12x8mm - 8x8 ball array, 0.8mm pitch, Package Mechanical Data | Cumbal | | millimeters | | inche | | | |--------|--------|-------------|-------|--------|--------|--------| | Symbol | Тур | Min | Max | Тур | Min | Max | | А | | | 1.400 | | | 0.0551 | | A1 | | 0.250 | | | 0.0098 | | | A2 | | | 1.100 | | | 0.0433 | | b | 0.400 | 0.350 | 0.450 | 0.0157 | 0.0138 | 0.0177 | | D | 12.000 | _ | _ | 0.4724 | _ | _ | | D1 | 5.600 | _ | _ | 0.2205 | _ | _ | | D2 | 8.800 | _ | _ | 0.3465 | _ | _ | | ddd | | | 0.100 | | | 0.0039 | | Е | 8.000 | _ | _ | 0.3150 | _ | _ | | E1 | 5.600 | _ | _ | 0.2205 | _ | _ | | е | 0.800 | _ | _ | 0.0315 | _ | _ | | FD | 1.600 | _ | - | 0.0630 | _ | - | | FE | 1.200 | _ | _ | 0.0472 | _ | - | | SD | 0.400 | _ | _ | 0.0157 | _ | _ | | SE | 0.400 | _ | _ | 0.0157 | _ | _ | #### **PART NUMBERING** ### **Table 27. Ordering Information Scheme** T = Tape & Reel packing Devices are shipped from the factory with the memory content bits erased to '1'. For a list of available options (Speed, Package, etc.) or for further information on any aspect of this device, please contact the ST-Microelectronics Sales Office nearest to you. 47/ ## **APPENDIX A. BLOCK ADDRESSES** Table 28. Bank A, Top Boot Block Addresses M36DR432AD | # | Size<br>(KWord) | Address Range | |----|-----------------|-----------------| | 14 | 4 | 1FF000h-1FFFFFh | | 13 | 4 | 1FE000h-1FEFFFh | | 12 | 4 | 1FD000h-1FDFFFh | | 11 | 4 | 1FC000h-1FCFFFh | | 10 | 4 | 1FB000h-1FBFFFh | | 9 | 4 | 1FA000h-1FAFFFh | | 8 | 4 | 1F9000h-1F9FFFh | | 7 | 4 | 1F8000h-1F8FFFh | | 6 | 32 | 1F0000h-1F7FFFh | | 5 | 32 | 1E8000h-1EFFFFh | | 4 | 32 | 1E0000h-1E7FFFh | | 3 | 32 | 1D8000h-1DFFFFh | | 2 | 32 | 1D0000h-1D7FFFh | | 1 | 32 | 1C8000h-1CFFFFh | | 0 | 32 | 1C0000h-1C7FFFh | Table 29. Bank B, Top Boot Block Addresses M36DR432AD | # | Size<br>(KWord) | Address Range | |----|-----------------|-----------------| | 55 | 32 | 1B8000h-1BFFFFh | | 54 | 32 | 1B0000h-1B7FFFh | | 53 | 32 | 1A8000h-1AFFFFh | | 52 | 32 | 1A0000h-1A7FFFh | | 51 | 32 | 198000h-19FFFFh | | 50 | 32 | 190000h-197FFFh | | 49 | 32 | 188000h-18FFFFh | | 48 | 32 | 180000h-187FFFh | | 47 | 32 | 178000h-17FFFFh | | 46 | 32 | 170000h-177FFFh | | 45 | 32 | 168000h-16FFFFh | | 44 | 32 | 160000h-167FFFh | | 43 | 32 | 158000h-15FFFFh | | 42 | 32 | 150000h-157FFFh | | 41 | 32 | 148000h-14FFFFh | | 40 | 32 | 140000h-147FFFh | | 39 | 32 | 138000h-13FFFFh | | 38 | 32 | 130000h-137FFFh | |----|----|-----------------| | 37 | 32 | 128000h-12FFFFh | | 36 | 32 | 120000h-127FFFh | | 35 | 32 | 118000h-11FFFFh | | 34 | 32 | 110000h-117FFFh | | 33 | 32 | 108000h-10FFFFh | | 32 | 32 | 100000h-107FFFh | | 31 | 32 | 0F8000h-0FFFFFh | | 30 | 32 | 0F0000h-0F7FFFh | | 29 | 32 | 0E8000h-0EFFFFh | | 28 | 32 | 0E0000h-0E7FFFh | | 27 | 32 | 0D8000h-0DFFFFh | | 26 | 32 | 0D0000h-0D7FFFh | | 25 | 32 | 0C8000h-0CFFFFh | | 24 | 32 | 0C0000h-0C7FFFh | | 23 | 32 | 0B8000h-0BFFFFh | | 22 | 32 | 0B0000h-0B7FFFh | | 21 | 32 | 0A8000h-0AFFFFh | | 20 | 32 | 0A0000h-0A7FFFh | | 19 | 32 | 098000h-09FFFFh | | 18 | 32 | 090000h-097FFFh | | 17 | 32 | 088000h-08FFFFh | | 16 | 32 | 080000h-087FFFh | | 15 | 32 | 078000h-07FFFFh | | 14 | 32 | 070000h-077FFFh | | 13 | 32 | 068000h-06FFFFh | | 12 | 32 | 060000h-067FFFh | | 11 | 32 | 058000h-05FFFFh | | 10 | 32 | 050000h-057FFFh | | 9 | 32 | 048000h-04FFFFh | | 8 | 32 | 040000h-047FFFh | | 7 | 32 | 038000h-03FFFFh | | 6 | 32 | 030000h-037FFFh | | 5 | 32 | 028000h-02FFFFh | | 4 | 32 | 020000h-027FFFh | | 3 | 32 | 018000h-01FFFFh | | 2 | 32 | 010000h-017FFFh | | 1 | 32 | 008000h-00FFFFh | | 0 | 32 | 000000h-007FFFh | | · | 1 | | 46/52 Table 30. Bank B, Bottom Boot Block Addresses M36DR432BD | 55<br>54 | 32<br>32 | 1F8000h-1FFFFFh | |----------|----------|-----------------| | | 32 | | | | 32 | 1F0000h-1F7FFFh | | 53 | 32 | 1E8000h-1EFFFFh | | 52 | 32 | 1E0000h-1E7FFFh | | 51 | 32 | 1D8000h-1DFFFFh | | 50 | 32 | 1D0000h-1D7FFFh | | 49 | 32 | 1C8000h-1CFFFFh | | 48 | 32 | 1C0000h-1C7FFFh | | 47 | 32 | 1B8000h-1BFFFFh | | 46 | 32 | 1B0000h-1B7FFFh | | 45 | 32 | 1A8000h-1AFFFFh | | 44 | 32 | 1A0000h-1A7FFFh | | 43 | 32 | 198000h-19FFFFh | | 42 | 32 | 190000h-197FFFh | | 41 | 32 | 188000h-18FFFFh | | 40 | 32 | 180000h-187FFFh | | 39 | 32 | 178000h-17FFFFh | | 38 | 32 | 170000h-177FFFh | | 37 | 32 | 168000h-16FFFFh | | 36 | 32 | 160000h-167FFFh | | 35 | 32 | 158000h-15FFFFh | | 34 | 32 | 150000h-157FFFh | | 33 | 32 | 148000h-14FFFFh | | 32 | 32 | 140000h-147FFFh | | 31 | 32 | 138000h-13FFFFh | | 30 | 32 | 130000h-137FFFh | | 29 | 32 | 128000h-12FFFFh | | 28 | 32 | 120000h-127FFFh | | 27 | 32 | 118000h-11FFFFh | | 26 | 32 | 110000h-117FFFh | | 25 | 32 | 108000h-10FFFFh | | 24 | 32 | 100000h-107FFFh | | 23 | 32 | 0F8000h-0FFFFh | | 22 | 32 | 0F0000h-0F7FFFh | | 21 | 32 | 0E8000h-0EFFFFh | | 20 | 32 | 0E0000h-0E7FFFh | | 19 | 32 | 0D8000h-0DFFFFh | | 18 | 32 | 0D0000h-0D7FFFh | |----|----|-----------------| | 17 | 32 | 0C8000h-0CFFFFh | | 16 | 32 | 0C0000h-0C7FFFh | | 15 | 32 | 0B8000h-0BFFFFh | | 14 | 32 | 0B0000h-0B7FFFh | | 13 | 32 | 0A8000h-0AFFFFh | | 12 | 32 | 0A0000h-0A7FFFh | | 11 | 32 | 098000h-09FFFFh | | 10 | 32 | 090000h-097FFFh | | 9 | 32 | 088000h-08FFFFh | | 8 | 32 | 080000h-087FFFh | | 7 | 32 | 078000h-07FFFFh | | 6 | 32 | 070000h-077FFFh | | 5 | 32 | 068000h-06FFFFh | | 4 | 32 | 060000h-067FFFh | | 3 | 32 | 058000h-05FFFFh | | 2 | 32 | 050000h-057FFFh | | 1 | 32 | 048000h-04FFFFh | | 0 | 32 | 040000h-047FFFh | | | | | Table 31. Bank A, Bottom Boot Block Addresses M36DR432BD | # | Size<br>(KWord) | Address Range | |----|-----------------|-----------------| | 14 | 32 | 038000h-03FFFFh | | 13 | 32 | 030000h-037FFFh | | 12 | 32 | 028000h-02FFFFh | | 11 | 32 | 020000h-027FFFh | | 10 | 32 | 018000h-01FFFFh | | 9 | 32 | 010000h-017FFFh | | 8 | 32 | 008000h-00FFFFh | | 7 | 4 | 007000h-007FFFh | | 6 | 4 | 006000h-006FFFh | | 5 | 4 | 005000h-005FFFh | | 4 | 4 | 004000h-004FFFh | | 3 | 4 | 003000h-003FFFh | | 2 | 4 | 002000h-002FFFh | | 1 | 4 | 001000h-001FFFh | | 0 | 4 | 000000h-000FFFh | #### APPENDIX B. COMMON FLASH INTERFACE The Common Flash Interface is a JEDEC approved, standardized data structure that can be read from the Flash memory device. It allows a system software to query the device to determine various electrical and timing parameters, density information and functions supported by the memory. The system can interface easily with the device, enabling the software to upgrade itself when necessary. When the Read CFI Query Command is issued the device enters CFI Query mode and the data structure is read from the memory. Tables 32, 33, 34 and 35 show the address used to retrieve each data. The Query data is always presented on the lowest order data outputs (DQ0-DQ7), the other outputs (DQ8-DQ15) are set to 0. The CFI data structure contains also a security area starting at address 81h. This area can be accessed only in read mode and it is impossible to change after it has been written by ST. Issue a Read command to return to Read mode. **Table 32. Query Structure Overview** | Offset | Sub-section Name | Description | |--------|---------------------------------------------------|-----------------------------------------------------------------------| | 00h | Reserved | Reserved for algorithm-specific information | | 10h | CFI Query Identification String | Command set ID and algorithm data offset | | 1Bh | System Interface Information | Device timing & voltage information | | 27h | Device Geometry Definition | Flash device layout | | Р | Primary Algorithm-specific Extended Query table | Additional information specific to the Primary Algorithm (optional) | | А | Alternate Algorithm-specific Extended Query table | Additional information specific to the Alternate Algorithm (optional) | **Table 33. CFI Query Identification String** | Offset | Data | Description | | |---------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--| | 00h | 0020h | Manufacturer Code | | | 01h | 00A1h - bottom<br>00A0h - top | Device Code | | | 02h-0Fh | reserved | Reserved | | | 10h | 0051h | Query Unique ASCII String "QRY" | | | 11h | 0052h | Query Unique ASCII String "QRY" | | | 12h | 0059h | Query Unique ASCII String "QRY" | | | 13h | 0002h | Primary Algorithm Command Set and Control Interface ID code 16 bit ID code defining a specific algorithm | | | 14h | 0000h | | | | 15h | offset = P = 0040h | Address for Primary Algorithm extended Query table | | | 16h | 0000h | | | | 17h | 0000h | Alternate Vendor Command Set and Control Interface ID Code second vendor - specified algorithm supported (note: 0000h means none exists) | | | 18h | 0000h | | | | 19h | value = A = 0000h | Address for Alternate Algorithm extended Query table note: 0000h means none exists | | | 1Ah | 0000h | | | # Table 34. CFI Query System Interface Information | Offset | Data | Description | |--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1Bh | 0017h | V <sub>DDF</sub> Logic Supply Minimum Program/Erase or Write voltage bit 7 to 4 BCD value in volts bit 3 to 0 BCD value in 100 millivolts | | 1Ch | 0022h | V <sub>DDF</sub> Logic Supply Maximum Program/Erase or Write voltage bit 7 to 4 BCD value in volts bit 3 to 0 BCD value in 100 millivolts | | 1Dh | 0000h | V <sub>PPF</sub> [Programming] Supply Minimum Program/Erase voltage bit 7 to 4 HEX value in volts bit 3 to 0 BCD value in 100 millivolts Note: This value must be 0000h if no V <sub>PPF</sub> pin is present | | 1Eh | 00C0h | V <sub>PPF</sub> [Programming] Supply Maximum Program/Erase voltage bit 7 to 4 HEX value in volts bit 3 to 0 BCD value in 100 millivolts Note: This value must be 0000h if no V <sub>PPF</sub> pin is present | | 1Fh | 0004h | Typical timeout per single byte/word program (multi-byte program count = 1), $2^n$ µs (if supported; $0000h$ = not supported) | | 20h | 0003h | Typical timeout for maximum-size multi-byte program or page write, 2 <sup>n</sup> μs (if supported; 0000h = not supported) | | 21h | 000Ah | Typical timeout per individual block erase, 2 <sup>n</sup> ms (if supported; 0000h = not supported) | | 22h | 0000h | Typical timeout for full chip erase, 2 <sup>n</sup> ms (if supported; 0000h = not supported) | | 23h | 0003h | Maximum timeout for byte/word program, 2 <sup>n</sup> times typical (offset 1Fh) (0000h = not supported) | | 24h | 0004h | Maximum timeout for multi-byte program or page write, 2 <sup>n</sup> times typical (offset 20h) (0000h = not supported) | | 25h | 0002h | Maximum timeout per individual block erase, 2 <sup>n</sup> times typical (offset 21h) (0000h = not supported) | | 26h | 0000h | Maximum timeout for chip erase, 2 <sup>n</sup> times typical (offset 22h) (0000h = not supported) | **Table 35. Device Geometry Definition** | Offset Word<br>Mode | Data | Description | |---------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 27h | 0016h | Device Size = 2 <sup>n</sup> in number of bytes | | 28h | 0001h | Flash Device Interface Code description: Asynchronous x16 | | 29h | 0000h | | | 2Ah | 0000h | <b>.</b> | | 2Bh | 0000h | Maximum number of bytes in multi-byte program or page = 2 <sup>n</sup> | | 2Ch | 0002h | Number of Erase Block Regions within device bit 7 to 0 = x = number of Erase Block Regions | | | | Note:1. x = 0 means no erase blocking, i.e. the device erases at once in "bulk." 2. x specifies the number of regions within the device containing one or more contiguous Erase Blocks of the same size. For example, a 128KB device (1Mb) having blocking of 16KB, 8KB, four 2KB, two 16KB, and one 64KB is considered to have 5 Erase Block Regions. Even though two regions both contain 16KB blocks, the fact that they are not contiguous means they are separate Erase Block Regions. 3. By definition, symmetrically block devices have only one blocking region. | | M36DR432AD | M36DR432AD | Erase Block Region Information | | 2Dh | 003Eh | bit 31 to 16 = z, where the Erase Block(s) within this Region are (z) times 256 bytes | | 2Eh | 0000h | in size. The value $z = 0$ is used for 128 byte block size. | | 2Fh | 0000h | e.g. for 64KB block size, z = 0100h = 256 => 256 * 256 = 64K | | 30h | 0001h | bit 15 to 0 = y, where y+1 = Number of Erase Blocks of identical size within the Erase | | 31h | 0007h | Block Region: | | 32h | 0000h | e.g. y = D15-D0 = FFFFh => y+1 = 64K blocks [maximum number]<br>y = 0 means no blocking (# blocks = y+1 = "1 block") | | 33h | 0020h | Note: $y = 0$ value must be used with number of block regions of one as indicated | | 34h | 0000h | by (x) = 0 | | M36DR432AD | M36DR432AD | | | 2Dh | 0007h | | | 2Eh | 0000h | | | 2Fh | 0020h | | | 30h | 0000h | | | 31h | 003Eh | | | 32h | 0000h | | | 33h | 0000h | | | 34h | 0001h | | ## **REVISION HISTORY** **Table 36. Document Revision History** | Date | Version | Revision Details | |-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15-Jan-2003 | 1.0 | First issue. | | 15-Jan-2003 | 1.1 | Bottom Device Code corrected on page 1. | | 25-Feb-2003 | 2.0 | Document promoted from Preliminary Data to full Datasheet status. | | 28-Feb-2003 | 2.1 | $V_{DDQF}$ signal removed from datasheet. SRAM Input Rise and Fall Times added to, and $V_{DDF}$ and $V_{DDS}$ parameters differentiated in Table 14, Operating and AC Measurement Conditions. $V_{DDS}$ added to the SIGNAL DESCRIPTIONS section. | 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. The ST logo is registered trademark of STMicroelectronics All other names are the property of their respective owners © 2003 STMicroelectronics - All Rights Reserved STMicroelectronics group of companies Australia - Brazil - Canada - China - Finland - France - Germany - Hong Kong India - Israel - Italy - Japan - Malaysia - Malta - Morocco - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States. www.st.com