**Calhoun: The NPS Institutional Archive** **DSpace Repository** Theses and Dissertations Thesis and Dissertation Collection 1994-03 # A VLSI interface for the NM24CF04 serial-access ferroelectric memory Dickerson, James H. Monterey, California. Naval Postgraduate School http://hdl.handle.net/10945/30897 Downloaded from NPS Archive: Calhoun Calhoun is a project of the Dudley Knox Library at NPS, furthering the precepts and goals of open government and government transparency. All information contained herein has been approved for release by the NPS Public Affairs Officer. Dudley Knox Library / Naval Postgraduate School 411 Dyer Road / 1 University Circle Monterey, California USA 93943 # NAVAL POSTGRADUATE SCHOOL Monterey, California ### THESIS A VLSI INTERFACE FOR THE NM24CF04 SERIAL-ACCESS FERROELECTRIC MEMORY by James H. Dickerson March, 1994 Thesis Advisor: Douglas J. Fouts Approved for public release, distribution is unlimited. DUDLEY KNOX LIBRARY NAVAL POSTGRADUATE SCHOO! MONTEREY CA 93943-5101 #### REPORT DOCUMENTATION PAGE Form Approved CMB No. 1996 Date approxymate for the collection of internation is encounted to entrage. Livey are request, mining a fact on the contrage of the contrage and con | 1 | AUENCY USE ONLY (Leave Mans) | 2 REPORT DATE 1 | | GT IVPE AND DATES COVERED OF 'S THOSES | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------|--------------------------------------------------|--| | 3 | DITLE AND SUBTITUE A VLSI (<br>SERIAL - ACCESS FERROEL) | | 24CF04 | FUNDING NUMBERS | | | 6 | AUTHOR(5) James H. Dickerson | | | | | | 7 | PERFORMING ORGANIZATION NAMES (AND ADDRESS/ES) Navai Postgraduate School Muntzrey CA 93943-5000 | | | PERFORMING<br>ORGANIZATION<br>KEYOKT NOMBER | | | 9 | SPONSORING/MONITORING AGENCY NAME(S) AND ADDRESSIES) | | | 10 SPONSORING/MONITORING<br>AUDICY REPORT MUMBER | | | 11 | SUPPLEMENTARY NOTES. The views expressed in this thesis are those of the author and do not reflex<br>the official policy or position of the Department of Defense or the U.S. Government | | | | | | 1230 | DISTRIBUTION/A VALLABILITY ST<br>Approved for public release, dis | | 12H DISTRIBUTION CODE. | | | | 14. | VINCEN AND THE PARTY OF PAR | | | | | 15 ABSTRACT (morrimum Jill works) The goal of this restarch project was to design a VLSI implementation of the required digital circuity, to utilize ferrollecture memory as a position of main microprocessor memory. An interface between National Semiconductor's NM24CF04, a nonvolatile, serial-access, ferrocleric memory desice, and large's 3066, microprocessor was designed and implemented using SSI/MSI technology in a previous study. This thesis discusses the redesign of the previously designed circuit for VLSI implementation. The layout was accomplished using the Magic graphical layout editor and tested using the Esim event driven logic-devel simulation. 14 SUBJECT TERMS Ferroelectric memory, FERRAM, NM24CF04, nonvolutile STIMBER DE PAGES 114 memory.VLSI PRICE COOP 17 SECURITY CLASSIFI-SECURITY CLASSIES 19 SECURITY CLASSIES LIMITATION OF CATION OF REPORT CATION OF THIS PAGE CATION OF ABSTRACT ABSTRACT Unclassified Unclassified Unclassified NSN 7540-01-280-3500 #### Approved for public release; distribution is unlimited. A VLSI Interface for the NM24CF04 Serial-Access Ferroelectric Memory by James H. Dickerson Lieutenant, United States Navy B.S., University of Mississippi, 1988 Submitted in partial fulfillment of the requirements for the degree of #### MASTER OF SCIENCE IN ELECTRICAL ENGINEERING from the March 1994 #### ABSTRACT The goal of this research project was to design a VLSI implementation of the required digital circuitry to utilize ferroelectric memory as a portion of main microprocessor memory. An interface between National Semiconductor's NM24CF04, a nonvolatile, serial-access, ferroelectric memory device, and Intel's 3086 microprocessor was designed and implemented using SSUMSI technology in a previous study. This thesis discusses the redesign of the previously designed circuit for VLSI implementation. The layout was accomplished using the Magic graphical layout editor and tested using the Esim event driven logic-level simulator. #### TABLE OF CONTENTS | I. | IM | TRODUCTION | 1 | |-----|----|--------------------------------------|----| | | A. | BACKGROUND | 1 | | | | 1. FECM Theory of Operation | 1 | | | | 2. National Semiconductor's NM24CF04 | 2 | | | | 3. Microprocessor System | 4 | | | | a. Write Bus Cycle | € | | | | b. Read Bus Cycle | 8 | | | з. | OVERVIEW OF SYSTEM DESIGN | 9 | | | | 1. Address and Data Bus Structure | 9 | | | | 2. Data Flow Overview | 11 | | | С. | RESEARCH GOALS | 12 | | | D. | REQUIRED HARDWARE AND SOFTWARE TOOLS | 15 | | | | 1. Sun SPARCstation | 15 | | | | 2. Magic | 15 | | | | 3. Peg | 16 | | | | 4. SPICE3C1 | 17 | | | | 5. Esim | 17 | | | E. | THESIS STRUCTURE | 13 | | | | | | | II. | DE | SIGN CONSIDERATIONS | 19 | | | Α. | MAIN FINITE STATE MACHINE (MFSM) | 19 | | | в. | COUNTER FINITE STATE MACHINE (CFSM) | 20 | ## DUDLEY KNOX LIBRARY NAVAL POSTGRADUATE SCHOOL MONTEREY CA 93943-5101 | | C. | HIGH/LOW BYTE MOX/SHIFTER | 2C | |-----|----------------------|--------------------------------------------------|----------------------------------------| | | Ď. | :/0 BUS CONTROL | : | | | Ε. | INTERFACE DEVICE OVERALL CHIP LAYOUT 2 | 22 | | | | | | | | . 12 | MPLEMENTATION | 4 | | | Α. | CELL CONVERSION | 14 | | | В. | MAIN/COUNTER FINITE STATE MACHINES (MFSM/OFSM) 2 | 4 | | | c. | HIGH/LOW BYTE MUX/SHIFTER | .9 | | | D. | I/O BUS CONTROL | 8 | | | Ξ. | POWER ESTIMATES | 8 | | | | 1. Static Power Dissipation | 29 | | | | 2. Dynamic Power Dissipation | 30 | | | F. | MICROINTERFACE PHYSICAL IMPLEMENTATION | 3 1 | | | | | | | | | | | | IV. | TES | SZING 3 | 32 | | IV. | TES | STING | _ | | IV. | Α. | MAIN FINITE STATE MACHINE | _ | | IV. | А. | MAIN FINITE STATE MACHINE | 32<br>32 | | IV. | А. | MAIN FINITE STATE MACHINE | 32<br>32<br>33 | | IV. | А.<br>Э.<br>С. | MAIN FINITE STATE MACHINE | 32<br>32<br>33 | | IV. | А.<br>Э.<br>С. | MAIN FINITE STATE MACHINE | 32<br>32<br>33 | | IV. | A.<br>B.<br>C.<br>D. | MAIN FINITE STATE MACHINE | 32<br>32<br>33 | | | A.<br>B.<br>C.<br>D. | MAIN FINITE STATE MACHINE | 32<br>32<br>33<br>33<br>33 | | | A. G. E. CONG | MAIN FINITE STATE MACHINE | 32<br>32<br>33<br>33<br>33 | | | A. G. E. CONG | MAIN FINITE STATE MACHINE | 32<br>32<br>33<br>33<br>33<br>33<br>35 | | Α. | MAIN FINITE STATE MACHINE INPUT | <br>3 | |----------|-----------------------------------------|---------| | з. | MAIN FINITE STATE MACHINE OUTPUT | <br>3 | | с. | COUNTER FINITE STATE MACHINE INPUT | <br>40 | | D. | COUNTER FINITE STATE MACHINE OUTPUT | <br>4 | | | | | | APPENDI: | IX B: MAGIC CELL LAYOUTS | <br>41 | | | | | | APPENDI | IX C: SIMULATION DATA | <br>8. | | Α. | MAIN FINITE STATE MACHINE SIMULATION | <br>8. | | В. | COUNTER FINITE STATE MACHINE SIMULATION | <br>85 | | С. | ACK_EN SIMULATION | <br>93 | | ٥. | LSSEN SIMULATION | <br>8.5 | | Ξ. | HSSEN SIMULATION | <br>8 | | F. | HISRSHIF SIMULATION | <br>81 | | G. | LOSRSHIF SIMULATION | <br>8 | | н. | HISRLOAD SIMULATION | <br>9: | | ı. | LOSRLOAD SIMULATION | <br>9 | | J. | LOCLKDIS SIMULATION | <br>9 | | ĸ. | HIGH/LOW BYTE MUX/SHIFTER SIMULATION | <br>9. | | L. | SRBUSEN SIMULATION | <br>9. | | M. | PAD-TO-PAD VERIFICATION | <br>9 | | | 1. Read Cycle Simulation | <br>9 | | | 2. Write Cycle Simulation | <br>9 | | | | | | APPENDI | IX D: CIRCUIT SCHEMATICS | <br>9 | | Ł | MICEGINTERFACE WITHOUT TIME DRIVERS | Q. | | 3. MICROINTERPACE WITH SOA BUS LINE DRIVERS | • | | 98 | |---------------------------------------------|---|-----|----| | APPENDIX B: PRELIMINARY DATA SHEET | | | 99 | | LIST OF REFERENCES | | . 1 | 60 | | INITIAL DISTRIBUTION LIST | | . 1 | 01 | #### LIST OF TABLES | Table | Ι | STATIC POWER DISSIPATION | 29 | |-------|----|---------------------------|----| | Table | :: | DYNAMIC FOWER DISSIPATION | 30 | #### LIST OF FIGURES | Figure | 1 | Ferroelectric Capacitor Device, [Ref.2] | 2 | |--------|----|-----------------------------------------------|------------| | Figure | 2 | NM24CF04 Pin Biagram, [Ref. 4] | 2 | | Figure | 3 | 8086 Minimum Mode System, [Ref. 5] | 5 | | Figure | 4 | Typical BIU Bus Cycle, [Ref. 1] | $\epsilon$ | | Figure | 5 | 8086 Write Bus Cycle, [Ref. 1] | 7 | | Figure | 6 | Wait State Insertion, [Ref. 1] | 8 | | Figure | 7 | 8086 Read Bus Cycle, [Ref. 1] | 9 | | Figure | 8 | System Bus Structure, [Ref. 1] , | 10 | | Figure | 9 | Functional Block Diagram of Interface Device. | 12 | | Figure | 10 | Microinterface Proposed Pin Diagram , . , | 13 | | Figure | 11 | Byte Formats | 21 | | Figure | 12 | Microinterface Floor Plan | 23 | | Figure | 13 | StateO Logical Schematic | 26 | | Figure | 14 | StateO Magic Layout | 27 | | Figure | 15 | Magic Cell Material Legend | 4.2 | | Figure | 16 | Two Input NAND Gate Cell Layout | 43 | | Figure | 17 | Three Input NAND Gate Cell Layout | 44 | | Figure | 18 | Four Input NAND Gate Cell Layout | 45 | | Figure | 19 | Five Input NAND Gate Cell Layout | 4€ | | Figure | 20 | Six Input NAND Gate Cell Layout | 47 | | Figure | 21 | Seven Input NAND Gate Cell Layout | 48 | | Figure | 22 | Eight Input NAND Gate Cell Layout | 43 | | Figure | 23 | Ten Input NAND Gate Cell Layout | 50 | | Figure 24 | Two Input NOR Gate Cell Layout | 51 | |-----------|---------------------------------------------|-----| | Figure 25 | Three Input NOR Gate Cell Layout | 52 | | Figure 26 | Four Input NOR Gate Cell Layout | 53 | | Figure 27 | Five Input NOR Gate Cell Layout , | 54 | | Figure 28 | INVL Cell Layout | 55 | | Figure 29 | INV4 Cell Layout | 56 | | Figure 30 | Buff Cell Layout | 57 | | Figure 31 | Two Input XOR Cell Layout | 59 | | Figure 32 | abod Cell Layout (MFSM) | 59 | | Figure 33 | efgh Cell Layout (MFSM) | 60 | | Figure 34 | ijkl Cell Layout (MFSM) | 61 | | Figure 35 | mnc Cell Layout (MFSM) | 62 | | Figure 36 | StateO Cell Layout (MFSM) | 63 | | Figure 37 | Statel Cell Layout (MFSM) | 64 | | Figure 38 | State2 Cell Layout (MFSM) | 65 | | Figure 39 | State3 Cell Layout (MFSM) | 66 | | Figure 40 | sl Cell Layout (MFSM) | 67 | | Figure 41 | s0 Cell Layout (CFSM) | 68 | | Figure 42 | muxa_fsm Cell Layout (MFSM) | 69 | | Figure 43 | muxb_fsm Cell Layout (MFSM) | 7.0 | | Figure 44 | cfsmckt Cell Layout (CFSM) | 71 | | Figure 45 | ACK_EN Cell Layout (I/O BUS CONTROL) | 72 | | Figure 46 | LSSEN Cell Layout (I/O BUS CONTROL) | 73 | | Figure 47 | HSSEN Cell Layout (I/O BUS CONTROL) | 74 | | Figure 48 | cntr7con Cell Layout (MFSM) | 75 | | Figure 49 | Gatel Cell Layout (General Gating Circuit). | 78 | | Figure | 50 | hisrshif Cell Layout (I/O BUS CONTROL) | 77 | |--------|----|---------------------------------------------|-----| | Figure | 51 | loseshif Cell Layout (1/0 BUS CONTROL) | 7.8 | | Figure | 52 | hisrhoad Cell Layout (I/O BUS CONTPOL) | 7.9 | | Figure | 53 | lockhdis Cell Layout (I/C BUS CONTROL), , , | 90 | | Figure | 54 | losrload Cell Layout (5/0 BUS CONTROL) | 81 | | Figure | 55 | High/Low Byte Mux/Shifter , . , . | 92 | | Figure | 56 | srbusen Cell Layout (I/O BUS CONTROL) | 83 | | Figure | 57 | Microinterface Without Line Drivers | 97 | | Figure | 58 | Microinterface With Line Drivers , . , . | 99 | | Figure | 59 | Preliminary Pinout | 99 | #### I. INTRODUCTION #### A BACKGROUND Ferroelectric capacitor memory (FECM) cells are incorporated in the National Semiconductor NMAGCF04 4096-65t 510 x 8, CXOS Serial Nonvolatile Memory. These memory chips provide the possibility of implementing non-volatile computer main memory. Recent studies [Ref. 1] have demonstrated the feasibility of directly interfacing FECM to a microprocessor memory bus. #### 1. FECM Theory of Operation FECM are constructed using a modified silicon CMOS semiconductor process. Figure 1 shows a typical structure for a simple ferroelectric capacitor [Ref. 2]. A commonly used ferroelectric material is lead zirconate titanate (PZT). The PZT dielectric is deposited between two electrode layers, forming a capacitor. The capacitor is charged when written to and the charge is retained for greater than ten years in the case of the NM24CF04 FECM. The cell is read by applying a voltage across the capacitor and observing the current pulse generated. A small current pulse indicates a 'l' is stored in the cell while a large current pulse indicates a '0' is stored in the cell. It should be noted that the read operation is a "destructive read" and the data must be written back to the device. Figure 1 Ferroelectric Capacitor Device, [Ref.2]. Current technology has demonstrated several advantages and favorable characteristics of FECM (Ref. 3], including: 1) non-volatility, 2) long retention (>10 years § 25°C), 3) endurance (10°0 write cycles), and 4) radiation hardness (>10°0 RADs(Si/sec)). Therefore, FECM's are ideal for many military and space based systems. #### 2. National Semiconductor's NM24CF04 The NM24CFO4 is fabricated with advanced CMOS ferroelectric technology [Ref. 4]. The device provides a 4096-bit nonvolatile memory, internally organized as two 256 x % stbit pages. It uses a serial interface on a two-wire bus with practically unlimited erase/write cycles and supports a bidirectional bus oriented protocol. When power is removed, the data remains stored in the ferroelectric cells. Figure 3 shows a connection diagram for the device. Figure 2 NM24CF04 Pin Diagram, [Ref. 4]. Serial Data (SDA): SDA is a bidirectional pin used to transfer data into and out of the device. It is an open-drain output and may be wire ORed with any number of open-drain or open-collector outputs. A pull-up resistor is required. Serial Clock (SCL): The SCL input is used to clock all data into and out of the device. Data states on the SDA line can change only during SCL LOW. SDA state changes during SCL HIGH are reserved for indicating start and stop conditions. $\mbox{Address $A0$}: \mbox{ A0 is unused by the NM24CF04, however,} \\ \mbox{it must be tied to GND to insure proper device operation.} \\$ Address (A1,A2): The Address inputs are used to set the least significant two bits of the six bit slave address. These inputs can be driven with logic or tied high or low. The four most significant bits of the slave address are tied to $V_{\rm st}$ or GND to form the "Device Type Identifier" nibble '1010'. Pins Al and A2 connected to +5 volts or ground to establish a hardwired address for the device. Two bits allow four different devices to be addressed. #### Microprocessor System The most commonly used 16-bit microprocessors today are the Intel 8026 series and the Motorola 68000. Previous studies [Ref. 1] used the Intel 8086 in the minimum mode. The thrust of this thesis research is centered around the Intel 8086 [Ref. 5], although the monitored signals could easily be converted to allow the use of the Motorola 68000 chip. The Minimum Mode System configuration is shown in Figure 3. In the minimum mode, the CPU emits the bus control signals for memory. In the maximum mode, an 8288 Bus Controller assumes the responsibility of controlling all devices on the system bus. The CPU incorporates two separate processing units. These are the Execution Unit (EU) and the Bus Interface Unit (BIU). The EU executes instructions and the BIU fetches instructions, reads operands, and writes results. The two units operate independent of one another and are able, under most circumstances, to extensively overlap instruction fetch with execution. The 8086's instruction stream queue can store up to six instruction bytes. When two or more bytes of the 6-byte instruction queue are empty and the EU does not require the BIU to perform a bus cycle, the BIU executes instruction fetch cycles to refill the queue. The BIU normally fetches two bytes unless the fetch is from the odd address. Figure 3 8086 Minimum Mode System, [Ref. 5]. where the BIU only fetches the byte from the odd address. The BIU is responsible for executing all external bus cycles to read data from memory or write data to memory. All bus cycles consist of a minimum of four clock cycles or "T-states" know as $T_1$ , $T_2$ , $T_3$ , and $T_4$ . Figure 3 shows a typical BIU bus cycle. A bus cycle consists of a chain of events in which the address of memory location is output, then a read or write control signal is presented, followed by the data in a write operation. The addressed device accepts the data on a write cycle or places data on the bus during a read operation. For slow devices, such as the NM24CF04, wait states must be inserted between $T_1$ and $T_4$ . During a wait state, the data on the bus remains unchanged. Upon completion of the cycle, memory latches data written or the BIU removes data read. Figure 4 Typical BIU Bus Cycle, [Ref. 1]. #### a. Write Bus Cycle Figure 4 illustrates the basic write bus cycle. The CPU places the write address on the multiplexed address/data bus during T<sub>1</sub>. During state T<sub>1</sub>, Address Latch Enable (ALE) is asserted high to latch the write address into a register. The register contents can be decoded by combinational logic to generate the necessary chip select for memory. During state T2, the CPU places the write data on the multiplexed bus (AD15 - AD0), and WR is asserted low to indicate to memory that a write operation is requested. The READY signal is used to force the CPU to insert wait states into the bus cycle. To insert a wait state, READY must be low prior to the end of state T;. Figure 5 shows the timing relationship required to generate a wait state. Signal READY Figure 5 8086 Write Bus Cycle, [Ref. 1]. is produced by an 8284 Clock Generator and Driver shown in Figure 3. Signal RDY is produced by combinational logic in the interface device. Signal Data Transmit/Receive (DT/R) controls the flow of data through banks of 8286 octal bus transceivers when operating in the minimum mode configuration. With the signal high, data can flow from the 8086 microprocessor onto the data bus and into the appropriate memory location. Data Enable (DEN) is provided as an output enable for the data transceivers. Figure 6 Wait State Insertion, [Ref. 1]. #### b. Read Bus Cycle Figure 6 illustrates the 8086 Read Bus Cycle. The read cycle is very similar to the write cycle. The CPU places the read address on the multiplexed address/data bus during T. Again, during state T<sub>1</sub>, ALE is asserted high to latch the write address into a register. The register contents is decoded to generate the necessary chip select for memory. Upon completion of T<sub>1</sub>, the CPU floats the address/data bus in preparation for data to be received from memory. During state T<sub>1</sub>, RD is asserted low to indicate to memory that a read operation is requested. Again, if reading from a slow memory device, the user is responsible for adding logic to control Figure 7 8086 Read Bus Cycle, [Ref. 1]. READY and generate wait states prior to state T,. Signal DT/R is asserted low to configure transceivers in the receive mode. Signal DEN is asserted low to enable the transceivers to pass the received data to the CPU. #### B. OVERVIEW OF SYSTEM DESIGN Figure 8 shows an overview of the system bus structure implemented in previous thesis research [Ref. 1]. #### 1. Address and Data Bus Structure Although the 8086 has the ability to address one megabyte of memory, the system described here employs 4K bytes of ferroelectric RAK (FERRO), 8K of ROM, and 8K of static RAX. The section of memory designated as FERRO is split into two Figure 8 System Bus Structure, [Ref. 1]. banks of 2K-bytes each. One bank connects the lower half of the data bus (D7-D0) and corresponds to even addresses (A0 = 0). The remaining bank connects the upper half of the data bus (D15-D8), and corresponds to odd addresses (A0 = 1). Address lines A1-A11 specify the particular byte in each bank. To perform a byte transfer to an even address, the 8086 specifies an address with A0 low and signals Bus High Enable (BHE) high. With BHE high, the upper bank of memory, or the odd byte of the word address, is disabled. To perform a byte transfer to an odd address, the 8086 asserts BHE low and AO high. This allows access to the upper bank while disabling any memory access of the lower bank or even byte. To perform a word transfer of 16 bits, the 8086 asserts both BHE and AO low. This enables both memory banks and allows transfer of the entire data bus D15-D0 during one bus cycle. #### 2. Data Flow Overview The objective of the design was to configure the MM24CF04 as a functional block of main memory without requiring any special actions on the part of the 8096 microprocessor. The NM24CF04 operates at a frequency of 100 NHz, thus requiring the wait states to be inserted whenever the ferroelectric memory was addressed. The CONTROL logic of Figure 8 monitors five sets of signals: RD, WR, BHE, A0-A11, and D0-D15. When the 1036 requests a read operation from ferroelectric memory, it places the read address on the address bus and indicates a read request by asserting RD low. The CONTROL logic block takes over by initiating microprocessor wait states and performing the required tasks to retrieve information from the appropriate bank of ferroelectric memory. Control tasks performed include identifying and selecting the correct chip, converting the parallel address to a serial address, transmitting the address to memory serially, receiving the data from memory serially and transferring the received information into parallel form, latching the data, and releasing control to the microprocessor. Writing to ferroelectric memory is very similar. When the microprocessor writes data to ferroelectric memory, the write address is placed on the address bus, data on the data bus, and a write operation is indicated by asserting WR low. Again, the CONTROL block intercedes to perform data translations and input/output functions necessary to store data into the appropriate address. #### C. RESEARCH GOALS To extract a portion of a previously designed SSI/MSI interface [Ref. 1] and incorporate it in a single chip design using CMOS VLSI. Keeping the implementation as general as possible is a primary consideration. Figure 9 shows a block diagram of the extracted circuity. The Main Finite State Figure 9 Functional Block Diagram of Interface Device. Machine (MFSM) monitors signals WR, RD, FERRO, and ACK. Signals WR, and RD were described in Section A. of this chapter. Signal FERRO is a chip select generated by external combinational logic. Signal ACK is generated by the I/O BUS CONTROL by monitoring the Serial Data Bus Low (SDAL) and Serial Data Bus High (SDAH) for the Acknowledge (ACK) | HI (CATA) IN<br>HI (CATA) IN<br>LO (CATA) IN<br>LO (CATA) IN | Micro | | |--------------------------------------------------------------|-------|--| | | | | Figure 10 Microinterface Proposed Pin Diagram. generated by the NM24CF04. The Counter Finite State Machine (CFSM) maintains a count to control the number of shift operations performed by the shift registers contained in the LOW and HIGH BYTE MUX/SHIFTERS. The I/O BUS CONTROL generates clock and control for both internal and external bus control. LOW and HIGH BYTE MUX/SHIFTERS provide serial and parallel I/O to the address, parallel, and serial data busses. Figure 10 shows the proposed chip pin diagram. Signals not yet discussed Address (A0-All): Address bus lines from 74LS373 octal latches in Figure 8. Al0 and All select the desired chip within a bank. A9 selects the desired page within a chip. Al-A5 selects the specific byte within the page. Clock (CLE): A 100KHz clock is used to clock the "Microinterface" chip circuitry and generate SCLL and SCLH to clock the ferroelectric memory chips. Serial Data Bus High/Low Out (SDAH\_OUT/SDAL\_OUT): These pins are used if an external SDA bus driver is used. They can be used to enable data onto a serial data bus with a 74LS241 Line Driver, as shown in Figure 57. High/Low Data Bus Out (HI/LO\_DATA\_OUT): These pins are used if an external data bus driver is used. They can be used to enable data onto a parallel data bus with a tri-state Line Driver. Serial Clock High/Low (SCLH/SCLH): The clock output that connects to the SCL pin of the respective NM24CF04 memory chip. Ready (RDY): The output pin that connects to the RDY pin of the 8284 Clock Generator shown in Figure 3, to generate READY. Serial Data Bus High/Low In (SDAH\_IN/SDAL\_IN): Used to enable a tri-state Line Driver if the circuit is Configured with external drivers as shown in Figure 57. Data Lines (DO-D15): These pins connect to the data bus from the Transceivers shown in Figure 8. #### D. REQUIRED HARDWARE AND SOFTWARE TOOLS The design and layout of the Microinterface chip was done on the Naval Postgraduate School's Sun SPARCstations using the VESI CAD tool package created by the University of California at Berkeley. #### 1. Sun SPARCstation The Sun Microsystems SPARCstation II is a desktop workstation that offers high-speed color graphics. Operating at 40-MHz, the system is equipped with 32 MB of RAM, 424 MB of internal fixed disk storage, and mounts several large file systems from a remote server. #### 2. Magic Magic is an interactive editor for creation of Very Large Scale Integration (VLSI) circuit layouts. This program runs on many UNIX based systems, for example, the Sun SPARCStation with an integrated color display. Using Magic, the designer can create basic cell layouts and combine them into larger structures, or even complete integrated circuit layouts. This program has a built in design rule checker that constantly checks layouts during creation to ensure that layout rules are obeyed for the particular technology being used. To allow a means of interfacing with other programs, Magic allows the user to extract the created circuits for use by other programs. Magic only permits Manhattan designs, which are designs with horizontal or vertical edges, no diagonal or curved structures are allowed. The further attributes of Magic are numerous, and reference to the user's manual is recommended for additional descriptions of its abilities [Ref. 6]. #### 3. Peg The PLA Equation Generator compiles finite state machines to generate a working PLA. It takes a high level description of a finite state machine and translates it into the logic equations required to implement a specific design. Peg generates logic equations that follow the Moore model of a finite state machine. This implies that the outputs generated by the finite state machine depend only on the current state of the machine. Inputs can be provided to cause transitions to specific states. The Peg command used was: #### peg infile > outfile This allowed for the infiles, which in this case were mfsm.peg and cfsm.peg, to be processed into the equations required to design the heart of the extracted circuit. Included in Appendix A, are copies of the peg input and output files (Ref. $6^{\circ}$ . #### 4. SPICE3C1 spiceSot is an updated version of SFICE which is a general purpose circuit simulation program. It can porform do analysis, as smell-signal analysis, and transient analysis. SPICE can also be used to provide extensive plotting of circuit parameters and circuit behavior using its plot command. SPICE is a tremendously powerful tool in observing how circuits are acting, but it has a limitation in that large circuits take an extremely long time to process. SPICE was used mainly for power estimations and transient behavior [Ref. 7]. #### 5. Esim Esim is an event-driven switch-level simulator for NMOS and CMOS circuits. It can be entered after the circuit has been extracted from Magic. Esim is used to watch various nodes, to set or reset nodes, and to simulate the logical operation of the circuit. The watched nodes can then be inspected and the circuit evaluated. There are numerous commands and options that may be employed in the simulation and the reader is directed to the reference material for further clarification [Ref. 6]. #### E THESIS STRUCTURE Chapter I introduces the need for ferroelectrics, the NM24CF04, the 8086 microprocessor, and details of previous research. System timing considerations are discussed. Chapter II contains a description of circuit extraction considerations that were necessary to develop the design of the interface between the NM24CF04 and the 8086 microprocessor. VLSI layout considerations are described. Chapter III describes basic design method used to for each major section of the chip. An estimation of static and dynamic power dissipation is made. Chapter IV discussion of testing objectives, procedure, and results. Chapter V summarizes the study and includes further recommendations. #### II DESIGN CONSIDERATIONS The general interface device design began with careful consideration of the system bus structure shown in Figure 2. The functional blocks shown in Figure 9 described the implementation of the single chip design. These blocks were chosen to incorporate as much circuitry as possible from the previous SSI/MSI interface implementation [Ref. 1], and still maintain versatility for future adaptation to other microprocessor applications. The Magic layout editor requires that a filename be used for cell creation. The name "Microinterface" is selected to describe this chip. Further references to the entire chip are made using this name. #### A. MAIN FINITE STATE MACHINE (MFSM) The MFSM generates 15 different states that are decoded to provide control signals to the multiplexers and shift registers in the LOW and HIGH BYTE MUX/SHIFTER blocks. Outputs include states a - o, shift register function controls s0 and s1, multiplexer byte selectors muxa and muxb, and counter control signals counter\_clr and counter\_en. The design was extracted directly from the SSI/MSI design [Ref. 1], and a detailed description of the operation may be found in that reference. #### R COUNTER FINITE STATE MACHINE (CFSM) The OFSX monitors the output states and counter control signals from the MFSM, and counts from zero to seven when enabled. While the OFSM is counting, the MFSM is dormant and is reactivated when the OFSM output signal ontr7 is assorted. #### C. BIGE/LOW BYTE MUX/SHIFTER The LOW and HIGH BYTE MUX/SHIFTERS are identical functional blocks. Each block consists of a 4-to-1 byte multiplexer and shift register. The most important function performed by this block is the parallel to serial convertion of information and vice versa. The high and low bits of the shift register connect to the output and input of the appropriate Serial Data Bus (SDA). The LOW BYTE MUX/SHIFTER connect to the Serial Data Bus Low (SDAL), and the RIGH BYTE MUX/SHIFTER connects to the Serial Data Bus Low (SDAL). Four possible bytes may be selected by the multiplexer. Figure 11 shows the byte formats. For simplicity, only the low-byte format is shown. The high-byte format only differs in byte 2 and would be D8-D15 vice D0-D7. Byte 0 selects a particular chip in a bank. Byte 1 addresses one of 512 memory locations on a specific chip. Byte 2 is the data to be written if the operation is a write. Byte 3 is only used during the read operation and is called a "dummy read". Bit R/W of Byte 0 indicates the desired operation to the NM24CF04. When set to one, a read operation is selected, when set to zero, a write Figure 11 Byte Formats. operation is selected. The R/W position is hard wired to a one in Byte 3. As discussed in Chapter I, the high tibble '1910' forms the "Device Type Identifier". #### D. I/O BUS CONTROL The I/O Bus Control Block is a catch all group of circuits that generates the remaining required signals. These signals include the required shift register clocks, SDA/DATA enables, NM24CF04 Start/Stop signals, and the Acknowledge enable used to capture ACK. #### E INTERFACE DEVICE OVERALL CHIP LAYOUT Figure 12 is a floor plan of the "Microinterface" IC showing the overall layout of the major cells. For simplicity, the required cell interconnects, and chip pads are omitted. Reducing the space required for cell interconnects is a major consideration when planning a chip layout. This particular layout structure allowed for minimum distance between cells for greater compactness and less wasted chip space. The resultant chip is nearly square measuring four millimeters on a side. Detailed Magic cell layouts are provided in Appendix B. #### III. IMPLEMENTATION The basic logic design of each of the cells used in the "Microinterface" interface device are shown. This will provide insight into the design characteristics of each of the cells. The basic cell layouts are included in Appendix 3 so that the reader can see how the cell descriptions given appear in a Magic Layout. ## A. CELL CONVERSION The cell plots in the appendix were created using the Magic function cif, which creates a file cell.cif [Ref. 6]. The .cif file is then converted by the routine cif2ps. In order to include these files in the thesis, further conversion to a .pcx file was needed. The following conversion is available on alioth at the computer center as follows: pstoppm filename.ps | imconv -ppm - -pcx filename.pcx Note: This is a general conversion utility. To convert to some other standard format, replace pcx with the extension of the type of graphics you want to convert to, i.e. tiff, gif, eps, etc. ### B. MAIN/COUNTER FINITE STATE MACRINES (MFSM/CFSM) The MFSM and CFSM were developed from the original Peg programs used in the SSI/MSI design [Ref. 1]. The programs may be seen in Appendix A. Peg generates equations in a minterm fashion. The equations are expressed as the sum of products and are easily converted using DeXorgan's theorem. The resultant equations can be directly implemented using two stage NAND-NAND logic. As an example of the method used, the combinational logic development for StateO is detailed starting with the Peg output equation: Step 1: Feg equation ``` Outs-0:= "BESS"& Inst0:4 Inst1:4(Inst2:)( "BESS"& Inst0:4(Inst1:4 Inst2:)( "BESS"& Inst0:4(Inst1:4 Inst2:)( "BESST6 Inst0:4(Inst1:4 Inst2:4 Inst3:)( "BESST6 Inst0:4 Inst1:4 Inst2:4 Inst3:)( "BESST6:Inst0:4 Inst1:4 Inst1:4(Inst3:)( "BESST6:Inst0:4 Inst1:4(Inst1:4(Inst3:4))( "BESST6:Inst3:"( "BESST6:Inst0:4 Inst1:4(Inst1:4(Inst3:4)) The symbols '(', 't', and '4' represent 0k, NOT, and AND ``` The symbols '|', '!', and '&' represent Ox, NOT, and AND operations, respectively. Converting the equation to a more manageable format: ``` StateO = (\underbrace{RESET'QO'Q1'Q2}) + (\underbrace{RESET'QO'Q1'Q2}) + (\underbrace{RESET'QO'Q1'Q2'Q3}) + (\underbrace{RESET'Q1'Q2'Q3}) + (\underbrace{RESET'Q1'Q2'Q3}) + (\underbrace{RESET'Q1'Q2'Q3}) ``` Step 3: Apply DeMorgan's theorem The equation is now in the NAND-NAND form and can be directly implemented with one seven input, two five input, and three four input NAND gates. ## Step 3: Logical schematic The logical schematic for StateO is shown in Figure 13. Figure 13 StateO Logical Schematic. The logical schematic can now be used as a guide for constructing the Magic layout. # Step 4: Magain Layout A mollection of elementary Magic rells were designed for age us a mierarchial design of the larger cells. The Mague Layout if State() with inverters added in shown in Figure 10. Detailed Magic Layouts two be seen in Appendix B. Figure 14 StateO Magic Layout. #### C. HIGH/LOW BYTE MUX/SHIFTER The HIGH/LOW BYTE MUX/SHIFTERs consist of two cells each. A 4-to-1 byte multiplexer (MUX) and an 8-bit shift register. The 4-to-1 byte MUX consists of a bank of eight 4-to-1 bit multiplexers. Bytes are selected by muxa and muxb as discussed in Chapter 2. The shift register is a bidirectional, parallelin, serial-out, serial-in, parallel-out, general purpose shift register. Both the MUX and shift register can be found in all basic digital design books. ## D. I/O BUS CONTROL The I/O BUS CONTROL was extracted from the EPLD programs used in the SSI/MSI implementation [Ref. 1]. The design method paralleled that used in the MFSM design. Extracted equations accompany the respective cell layouts found in Appendix 3. ### E. POWER ESTIMATES Electromigration is the transport of metal ions through a conductor that results from excessive current density in the conductor. In order to determine the minimum size of power and ground conductors, an estimate of current density must be made. If the maximum current density, for a specific size conductor, is exceeded, the conductor may weaken and eventually blow like a fuse [Ref. 8]. SPICE3C1 was used for dc and ac analyses to determine power consumption of each circuit. ## 1. Static Power Dissipation The static power consumption is defined as worst-case leakage current multiplied by Vdd in any specific device. The results for each of the elementary cells used in the Microinterface device are shown in Table I. Table I STATIC POWER DISSIPATION. | CELL | CELL POWER | No. of CELLS | TOTAL | |--------|------------|--------------|---------| | BUFF | 5.50 µW | 25 | 138 µW | | INVl | 146 nW | 122 | 17.8 µW | | INV4 | 5.60 uW | 83 | 465 uW | | NAND2 | 495 nW | 143 | 70.8 µW | | NAND3 | 854 กพ | 91 | 77.7 μW | | NAND4 | 861 nW | 38 | 32.7 µW | | NAND5 | 890 nW | 14 | 12.5 µW | | NAND6 | 253 n.W | 16 | 4.05 µW | | NAND? | 404 nW | 3 | 1.21 uW | | NAND8 | 202 nW | 1 | 202 nW | | NAND10 | 1.04 µW | 1 | 1.04 cW | | NOR2 | 356 pW | 4 | 1.42 nW | | NOR3 | 369 pW | 2_ | 738 pW | | NOR4 | 0.585 pW | 2 | 1.17 pW | | NCR5 | 0.585 pW | 2 | 1.17 pW | | XOR2 | 55.5 nW | 8 | 444 nW | | TOTALS | 16.3 µW | 555 | 821 µW | ## 2. Dynamic Power Dissipation The dynamic power dissipation is defined as the current drawn by the cell during transition multiplied by Vdd. The total power dissipation for the device is then calculated by multiplying by the number of devices used of each type. The results may be seen in Table II. Table II DYNAMIC POWER DISSIPATION. | CELL | CELL POWER | No. of CELLS | TOTAL | |--------|------------|--------------|---------| | BUFF | 9.25 mW | 25 | 231 mW | | INV1 | 2.57 mW | 122 | 314 mW | | INV4 | 3.81 mW | 83 | 316 mW | | NAND2 | 2.45 mW | 143 | 350 mW | | NAND3 | 2.46 mW | 91 | 224 mW | | NAND4 | 2.48 mW | 38 | 94.2 mW | | NAND5 | 2.54 mW | 14 | 35.6 mW | | NAND6 | 2.52 mW | 16 | 40.3 mW | | NAND7 | 2.35 mW | 3 | 7.05 mW | | NAND8 | 2.40 mW | 1 | 2.40 mW | | NAND10 | 2.40 mW | 1 | 2.40 mW | | NOR2 | 1.10 mw | 4 | 4.40 mW | | NOR3 | 1.18 mW | 2 | 2,36 mW | | NOR4 | 1.18 mW | 2 | 2.36 mW | | NOR5 | 735 µW | 2 | 1.47 mW | | XOR2 | 994 µW | 8 | 7.95 mW | | TOTALS | 40.mW | 555 | 1.64 W | #### F MICROINTERFACE PHYSICAL IMPLEMENTATION After the actual chip is constructed, physical wire-up of a test circuit will be required. Possible circuits can be seen in Appendix C. Two implementations are shown, and both show only the memory side of the circuit, the reader should refer to the microprocessor user's manual [Ref. 5] for circuit configuration in the minimum mode. First, Figure 56 shows the interface device connected in the most elementary manner. The chip is intended to connect directly to the STA, Tata, and Address busses with no external line drivers. If desired, the user may incorporate external line drivers and connect the circuit as shown in Figure 57. The device provides enable lines for each bus. In each case a chip select circuit must be provided by the user to select the main memory address where the ferroelectric memory is installed. ## IV. TESTING All magic cells were tested with the Esim simulator discussed in Chapter I. Each major block of the hierarchy was, in turn, tested with Esim. The elementary cells were tested with SPICE to observe transient behavior. The operation of the chip may be fully verified by testing the MFSM, CFSM, High/Low Byte Mux/Shifter, larger cells of the I/O Bus Control, and a pad-to-pad check of the entire chip. Waim outputs of each of these may be seen in Appendix C. #### A. MAIN FINITE STATE MACHINE The MFSM inputs include a clock (CLK), flip-flop preset (PR), flip-flop clear (CLR), read high/write low (wr), count to seven (cntr?), SDA acknowledge [ack], and chip select (!ferro). The outputs are states (a-o) and multiplexer inputs (muxa, muxb, s0, and s1). The circuit was stepped through all states and all outputs verified correct. After verifying proper operation of PR and CLR, they were tied to Vdd as they were used only for testing. ## B. COUNTER FINITE STATE MACHINE The CFSM inputs are counter\_clr and counter\_en. The signal counter\_clr occurs in states b, d, f, k, and m to clear the counter. The signal counter\_en occurs in states c, e, g, l, and n to enable the counter. The state outputs of CFS% are available for use with the bus timing circuitry. In particular, state 1 is used to clear the ack capture circuit in the I/O Bus Control. The signal cntr7 is output when the CFSM cycle is complete. ## C. HIGH/LOW BYTE MUX/SHIFTER The High/Low Byte Mun/Shifter monitors muxa, muxb, st, and st control signals to perform the loading and shifting operations of the four bytes discussed in Chapter II. Correct operation with a representative bus cycle is shown in Appendix 5. ## D. I/O BUS CONTROL The I/O Bus Control section covers all remaining signals used to manipulate the Serial Clocks, Start/Stop condition, ack capture, RDY, and the enable lines for the external line drivers. Complete computer simulation using Esim may be seen in Adpendix C. ## E. PAD-TO-PAD VERIFICATION The pad-to-pad verification is the result of several iterations of testing of each major subcell. During this phase of testing, many problems were discovered. Some problems were easily rectified. However, the acknowledge enable (ACK\_EN) would not function using a bidirectional SDAL pin configuration. Redesign of the ACK\_EN capture circuit was required. Proper operation was finally achieved. Another significant problem encountered was the numbering order of the address/data bus into the shift register. The NMM24CF04 manufacturer's documentation [Ref. 4] is not clear as to which bit should be shifted into the device first. The final design used the bit order determined in the previous MSI/SSI study. The most significant bit of the respective address or data byte is shifted into the NM24CF04 first. Referring to Appendix C, Section M, a typical read cycle can be seen. Ferroelectric memory address FF., is addressed in both the low and high banks. The MFSM states are monitored for clarity of operation. Control bytes 0 and 3 can be seen on the SDAL/H bus during states c and 1. The address FF., is on the bus during state e. The NM24CF04 responses with the data bytes 01010101, for D0-D7 and 10101010, for D8-D15 during state o. The typical write cycle is verified in a similar manner. The pad-to-pad verification required careful consideration of the operation of the bidirectional pins. It should be noted that the SDAL/H bus pins were only driven when the NM24CF04 would be expected to respond. Otherwise, a 'don't care' condition was applied to allow monitoring of the Microinterface output. #### V CONCLUSIONS AND RECOMMENDATIONS ## A. CONCLUSIONS The "Microinterface" interface dirouit has been designed for implementation on a single chip. Although "Microinterface" was designed for a standard CMSS process, the single chip implementation without EFID's and the shear reduction of sine is a new contribution to microprocessor memory system technology. The original SSI/MSI implementation required 55 chips while implementation using the "Microinterface" chip would require chly 26 chips. This research project provides the necessary follow-on study for VLSI implementation of the required digital circuitry to utilize ferroelectric memory as a portica of main microprocessor memory. The use of ferroelectric technology would provide a radiation hardened and nonvolatile, yet modifiable, area of memory where mission parameters or new programs could be stored. This VLSI implementation would more easily allow the incorporation of the NM24CF04 memory device in a microprocessor based system. The use of ferroelectric memory in any system would combine the strengths of current technologies; the flexibility of RAM and the nonvolatility of ROM. The ferroelectric memory device is inherently slow due to the serial-access design. Conversion of the address/data from parallel to serial format requires the microprocessor to wait an inordinate amount of time for memory access. As the ferroelectric technology evolves, what is really needed is a ferroelectric integrated circuit that is accessed by means compatible with current RAM accessing techniques. The availability of a parallel accessed ferroelectric memory would vastly improve read and write cycle times. ## B. RECOMMENDATIONS - Fabricate chip and test in a circuit similar to the original SSI/MSI circuit. - Design and implement circuitry required for use with the Motorola 68000 microprocessor. #### APPENDIX A: PEG PROGRAMS #### A MAIN FINITE STATE MACHINE INPUT INPUTS: RESET ferro cntr7 ack wr; CUTPUTS: sls3 muma mumb a b c d e f q h i f k l m n o; our pois: siso muna muno a o o de i g n i g k i m n o start: ASSERT a; IF NOT ferro THEN stateb ELSE LCOP: stateb: ASSERT b s1 s0; GOTO statec; statec: ASSERT c s0; IF cntr7 THEN stated ELSE LCCP; stated: ASSERT d muxa s0 s1; IF ack THEN statee ELSE LCOP; statef: ASSERT f s0 s1 muxb; IF ack THEN stateg ELSE LCOP; stateg: ASSERT g s0; IF cntr? THEN stateh ELSE LOOP; stateh: ASSERT h; GOTO statei; statei: ASSERT i; GOTO start: statej: ASSERT j s0 s1 muxa muxb; IF ack THEN statek ELSE LOOP; statek: ASSERT k s0 s1 muxa muxb; GOTO statel; statel: ASSERT 1 s0; IF ontr? THEN statem ELSE LOOP; statem: ASSERT m s0; IF ack THEN staten ELSE LOOP; staten: ASSERT n s0; IF cntr7 THEN stateo ELSE LOOP; stateo: ASSERT o; Stateo: ASSERT 0; GOTO start; ### B. MAIN FINITE STATE MACHINE OUTPUT ``` INORDER- RESET ferro cntr7 ack wr InSt0* InStl* InSt2* InSt3*; OUTORDER= OutSt3* OutSt2* OutStl* OutSt0* sl s0 muxa muxb а b Ċ d e £ g i j k m n 0; OutSt3*= (!RESET&!cntr7& InSt0*& InSt1*&!InSt2*& InSt3*)( ``` ``` :!RESET& ack& InStO*& InStl*&!InSt2*&:InSt3*;; (!RESET&!ontr7& InSt0*&!InSt1*& InSt2*& InSt3*) (!RESET& InStO*&!InSt1*& InSt2*&!InSt3*:| (!RESET&!ack& InSt0*&!InSt1*&!InSt2*& InSt3*) (!RESET& cntr7&!InSt0*& InSt2*&!InSt3*)| (!RESET&!ack&!InStO*& InSt1*&!InSt2*& InSt3*)) :'RESET& ontr7a!IoSt0*& IoSt1*&!IoSt2*&!InSt3*;; ::F:S17&!ack&!InSt0*&!InSt1*& InSt2*& InSt3*) (!RESET&!ferro&!InSt0*&!InSt1*&!InSt2*&!InSt3*); 3utSt2*= !!RESETs cntr7& InSt0*& InSt1*&!InSt2*& InSt3*!! (!RESET&!ontr7& InSt0*&!InSt1*& InSt2*& InSt3*) (!RESET&!InStl*& InSt2*&!InSt3*) (!RESET& ack& InStO+&!InStI+&!InSt2+& InSt3+) (!RESET&!InSt0*& InSt1*& InSt2*&!InSt3*) (!RESET& ack&!InSt0*& InSt1*&!InSt2*& InSt3*) | (!PESET&!ack&!InSt0*&!InSt1*& InSt2*& InSt3*)! (!RESET&!InStO+&!InSt1+&!InSt2+& InSt3+); OutSti*= (!RESET& InSt0*& InSt1*&!InSt2*)| (!RESET& cntr7& InStC*&!InStl*& InSt2*& InSt3*) (!RESET&!InSt0*& InSt1*& InSt2*&!InSt3*) !!RESET&!InSt0*& InSt1*&!InSt2*& InSt3*) !!RESET& cntr7&!wr&!InSt0*& InSt1*&!InSt2*&!InSt3*); (!RESET&!cntr7&!InSt0*& InSt1*&!InSt2*&!InSt3*)| (!RESET& ack&!InStO*&!InSt1*& InSt2*& InSt3*); OutSt0*= (!RESET& InSt0*& InSt1*&!InSt2*)| (!RESET& InStO*&!InStl*& InSt2*)| (IRESET& InSt0*&!InSt1*&!InSt2*& InSt3*); (!RESET&!InSt0*& InStl*& InSt2*& InSt3*)| !!RESET& cntr7& wr&!InSt0*& InSt1*&!InSt2*&!InSt3*); s1 = i InSt0*&!InSt1*& InSt2*&!InSt3*)| (!InStl*6!InSt2*6 InSt3*)! (!InSt0*& InSt1*&!InSt2*& InSt3*)| !!In5t0*&!InSt1*& InSt2*& InSt3*); s0= ! InSt0*6 InSt1*6!InSt2*; | (!InStl*& InSt2*)| (!InSt1*&!InSt2*& InSt3*!| !!InSt0*& InSt1*&!InSt3*) | (!InSt0*& InSt1*&!InSt2*& InSt3*); muxa= / Institutionstitution institutionstitutionstitutionstitution : Inst0*&!Inst1*&!Inst2*& Inst3*)| (!InSt0*&!InSt1*& InSt2*& InSt3*); muxb= { InSt0*&!InSt1*& InSt2*&!InSt3*)| | InSt0*6!InStl*&!InSt2*& InSt3*)| (!InSt0*& InStl*&!InSt2*& InSt3*); ``` ``` a= (!InStfl*&!InSt^*&!InSt?*&!InSt3*): b= (!InSt0*&!InSt1*&!InSt2*& InSt3*); !!InSt0*&!InSt1*& InSt2*&!InSt3*!; d= :!Ir.St0*&!InSt1*& InSt2*& InSt3*); e= :!InSt0*& InSt1*&!InSt2*&!InSt3*); (!InSt0*& InSt1*&!InSt2*& InSt3*); g- (!InSt0*& InSt1*& InSt2*&!InSt3*); (!InSt0*& InSt1*& InSt2*& InSt3*); 1= [ InSt0*&!InSt1*&!InSt2*&!InSt3*); ! InSt0*&!InSt1*&!InSt2*& InSt3*); k= : InStO+&!InSt1+& InSt2+&!InSt3+); 1= ( InSt3*&!InSt1*& InSt2*& InSt3*): ( InStC*& InSt1*&!InSt2*&!InSt3*); n= ( InSt0*& InSt1*&!InSt2*& InSt3*); \alpha = { InSt0*& InSt1*& InSt2*&!InSt3*); ``` #### . COUNTER FINITE STATE MACBINE INPUT ## D. COUNTER FINITE STATE MACHINE OUTPUT ``` INORDER= RESET InSt0* InSt2*; OUTORDER- OutSt2* OutSt0* cntr7; (!RESET&!InSt2*); OutSt1*= (!RESET& InSt1*&!InSt2*)| (!RESET&!Insti*& Inst2*); OutSt0 *= (!RESET& InSt0*&!InSt2*)| (!RESET& InSt0+&!InSt1+& InSt2+)| (!RESET&!InStC*& InSt1*& InSt2*); cntr?= ( InSt0*& InSt1*& InSt2*); ``` ## APPENDIR B: MAGIC CELL LAYOUTS Figure 15 Magic Cell Material Legend. Figure 17 Three Input NAND Gate Cell Layout. Figure 18 Four Input MAND Gate Cell Layout, Figure 19 Five Input MAND Gate Cell Layout. Figure 20 Six Input NAND Gate Cell Layout. Figure 21 Seven Input NAND Gate Cell Layout. Figure 22 Eight Input NAMD Gate Cell Layout. Figure 23 Ten Input NAND Gate Cell Layout. Figure 24 Two Input NOR Gate Cell Layout ### 101-72N2+ZN2+IN3 Figure 25 Three Input NOR Gate Cell Layout. Pigure 26 Four Input NOR Gate Cell Layout. Figure 27 Five Input NOR Gate Cell Layout. Figure 30 Buff Cell Layout. Figure 31 Two Input XOP Cell Layout. Figure 32 abod Cell Layout (MFSM). 62 Sen Appendix A. Ses implementation equation for classes stated. 63 See Appendix A. for implementation equation for circuit State. Figure 37 Statel Cell Layout (MFSM) . See Appendix A. for implementation equation for circuit state2. Figure 38 State2 Cell Layout (MFSM) . See Appendix A. for implementation equation for circuit State3. Figure 40 sl Cell Layou: (MFSM) . See Appendix A. for implementation equation for circuit muxa fam (muxa). Figure 42 must iss Cell Layout (MFSM). See Appendix A. for implementation equation for circuit mixb\_fsm (mixib). Figure 43 muxb fsm Cell Layout (MFSM) . see appendix A. for implementation equation for discuscismekt. Figure 44 of smoke Cell Layout (CFSM) . Figure 45 ACK\_EN Cell Layout (I/O BUS CONTROL). # LSBEN AD THACLE - (MCLEY-CHCLE) Figure 46 LSSEN Cell Layout (1/0 BUS CONTROL) # HOODE BUE TO THE WORLD STORY Figure 47 RSSEN Call Layout 11/0 805 CONTROLS. #### COUNTER EN-creageles COUNTER CLR-b-u-1-k-m Figure 48 chtr7com Cell Layout iMPUM) Figure 49 Gatel Tell Layout (Seneral Gating Circuit) Pigure 50 misrshif Tell Layout (1/0 BUS TONTROL). Figure 51 losrshif Cell Layout (I/O BUS CONTROL). # HI SH LOAD CLY-BHETTE (BAGEFAR) Figure 52 hisrload Cell Layout (I/c aus CONTROL . # 20 CLR DISABLE-RO-(3-1-0) un'Clr-(3-Clr) RECORTECTO HI CLR DISABLE-SHE (3-1-0) un'Clr (3/Clr) (bestive R) STOP STAR SET (1-0-Clr) Pigure 53 locindis Cell Layent (I/D BUS CONTROL). Figure 54 | loszload Cell Layout 01/0 BUS CONTROL). io se sus sur TO (11) bent rOTA | discent rATA | existent rOTA | side sent rATA | (TA 10 discent rATA | existent rOTA | (TA 10 discent rATA ) Figure 56 Erbusen Cell Layout (1/0 BUE CONTROL). # APPENDIX C: SIMULATION DATA # A. MAIN FINITE STATE MACHINE SIMULATION | SIM (V3.5 03/27/91) | |------------------------------------------------| | nitialization took 595 steps | | nitialization took O stapa | | > 01010101010101010101010101010101010101 | | > 111111111111111111111111111111111111 | | > 111111111111111111111111111111111111 | | > 111111111111111111111111111111111111 | | > \$1111\$11\$000011\$1111\$11111111111111111 | | > 11111111111111111111111110000111111111 | | > DOQO 1 1 1 1 1 1 1 1 1 | | > 111110000000000000000000000000011000000 | | > 000001 100000000000000000000000011 000000 | | > 0000000111111000000000000000000001100000 | | > 000000000000001100000000000000000000110000 | | > 0000000000000011000000000000000000000 | | > 000000000000000000000000000000000000 | | > 000000000000000000000000000000000000 | | > aanaadaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | | > DOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOO | | > aqaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa | | > 0000000000000000000011000000000000000 | | > 000B0D0000000AH0D000001100000000000000000000 | | > 00000000000000000000000011110000000000 | | > NDAONAONOOQOAQNQOQQQQQQQQQQQQQQQQQQQQQQQ | | > 000000000000000000000000000000000000 | | > 00000000000001100111100000000000000110000 | | > 0.000.000.000.000.000.000.000.000.000. | | > 000001111111111111111111111111100B0111111 | | > 00000110000001100111100000000000110011 | | 982 transistors, 505 nodes (O culled un) | #### B. COUNTER FINITE STATE MACHINE SIMULATION ESIM (V3.5 G32/791) initialization took 143 steps initialization took 0 steps > oronoron 196 transistors, 104 codes (0 nulled up) ## C. ACK EN SIMULATION ESIM (V3.5 03)27/91) initialization took 28 stags initialization took 0 stags > 010001000:c > 111110000:entr7 > 0000000000:CtK > 000010001:e > 0000100010:a > 001000100:1 > 011110000:OUT 34 transistors, 25 nodes (0 pulled up) # D. LSSEN SIMULATION ESIM (V3.5 03/27/91) #### E ESSEN SIMILATION # ESIM (V3.5 03/27/91) initialization took 28 steps initialization took D steps > contrata de la del contrata de la contrata del contrata de la del la contrata de del la contrata de la contrata de la contrata de la contrata de la contrata de la contrata del la contrata del la contrata del la contrata del la contrata dela contrata del la contrata del la contrata del la contrata del la > 000011110900111100001111000011119000111100001111000011110000111100001111 IFT CLK 36 transistors, 28 nodes (0 pulled up) ESIM (V3.5 03/27/91) initialization took 28 steps initialization took 0 stens IFT\_CLK 36 transistors, 29 nodes (0 pulled up) ## F. HISRSHIF SIMULATION | ESIM (V3.5 03/27/91) | |--------------------------------------------| | initialization took 28 steps | | initialization took 0 steps | | > 111111111111111111111111111111111111 | | > 111111111111111111111111111111111111 | | > 01010101010101010101010101010101010101 | | > 00110011001100110011001100110011001100 | | > 00000000000000111111111111111000000000 | | > 0000000000000000000000000000000000000 | | > 0000111100001111000011110000111100001111 | | > 0000000011111111100000000111111111000000 | | >0111011101110111111111111111111111111 | | IFT CLK | 36 transistors, 28 nodes (6 pulled up) ESIM (V3.5 03/27/91) initialization took 28 steps initialization took 0 steps 36 transistors, 28 nodes (6 pulled up) | ESIM (V3.5 03/27/91) | |-----------------------------------------------------------------------------------------------------------------------------| | initialization took 28 steps | | initialization took 0 steps | | > 111111111111111111111111111111111111 | | > 000000000000000000000000000000000000 | | > 01010101010101010101010101010101010101 | | > 801100110011001100110011001100110011001 | | > 0000000000000000111111111111111111111 | | > 0000000000000000000000000000000000000 | | > 000011110000111100001111100001111100001111 | | > 000000001111111110000000061111111111000000 | | > 000000000000000000000000000000000000 | | IFT_CLK | | 38 transistors, 28 nodes (0 pulled up) | | | | | | ESIM (V3.5 03/27/91) | | ESIM (V3.5 03(27/91)<br>initialization took 26 steps | | | | initialization took 2B steps | | initialization took 28 steps<br>initialization took 0 steps | | initializatien toek 26 steps<br>Initialization toek 0 steps<br>> 000000000000000000000000000000000000 | | initialization took 28 steps<br>initialization took 0 steps<br>> 000000000000000000000000000000000000 | | Initialization took 28 steps initialization took 0 steps initialization took 0 steps > 010000000000000000000000000000000000 | | initialization took 28 steps initialization took 0 steps > 000000000000000000000000000000000000 | | $\label{limitation} \begin{array}{llllllllllllllllllllllllllllllllllll$ | | initialization took 28 steps initialization took 0 steps > 000000000000000000000000000000000000 | IFT\_CLK 36 transistors, 28 nodes (0 pulled up) #### G. LOSRSHIF SIMULATION ESIM (V3.5 03/27/91) initialization took 28 steps | INITIESIZATION TOOK U STEPS | | |---------------------------------------------|--| | > 111111111111111111111111111111111111 | | | > 000000000000000000000000000000000000 | | | > 01010101010101010101010101010101010101 | | | > 00110011001100110011001100110011001100 | | | > 00001111000011110000111100001111100001111 | | | > 000000001111111100000000111111111000000 | | | > 00B00000000000001111111111111111111111 | | | > B000B00000000000000000000000000000000 | | | > DADQDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD | | | HIFT CLK | | | 36 transistors, 28 nodes (0 pulled up) | | | ESIM (V3.5 03/27/91) | | | initialization took 28 steps | | | initialization took 0 steps | | | > 111111111111111111111111111111111111 | | | > 1181118111111111111111111111111111111 | | | > 01010101010101010101010101010101010101 | | | > 0.0110011001100110011001100110011001100 | | HIFT\_CLK 36 transistors, 28 nodes (0 pulled up) #### H. HISRLOAD SIMULATION FSIM (V3.5 03/27/91) AD CIK 18 transistors, 17 nodes (0 pulled up) # initialization took 15 steps initialization took 0 staps AD CLK 18 transistors, 17 nodes (0 pulled up) LOSRLOAD SIMULATION ESIM (V3.5 03/27/91) initialization took 15 steps initialization took 0 steps #### J LOCKEDIS SIMILATION | ESIM (V3.5 03/27/91) | |----------------------------------------------| | initialization took 41 steps | | initialization took 0 steps | | > 111000000000011100000000000:n | | > 1000000000000100000000000000000000000 | | > 0001100000000001100000000:e | | > 00000110000000000011000060:i | | > 0000000110000000000110000:h | | > 000000001100000000001100; | | > 0000000000011000000000011:0 | | > 1010101010101101101010101011CLK | | > 11111111111111000000000000000:!A0 | | > 0000000000000111111111111111111 | | > 00000000000000001111101011:HI_CLK_DISABLE | | > 000111110101100000000000000:LO CLK 03SABLE | > 00000110000100000011000010:STOP\_START\_SET 54 transistors, 39 nodes (0 pulled up) ĸ HIGE/LOW BYTE MUX/SHIFTER SIMULATION FSIM (V3.5 D3/27/91) initialization took 740 steps initialization took 0 steps ``` 944 transistors, 515 nodes (0 pulled up) ``` ## L. SRBUSEN SIMULATION 114 transistors, 67 nodes (0 pulled up) ESIM (V3.5 03/27/91) initialization took 103 steps initialization took 0 stans > 101181010100000011111011101010000001111:CIK > 000000000000010001000000000000000010001000-6 # N. PAD-TO-PAD VERIFICATION # 1. Read Cycle Simulation | mitalization look \$787 afrosa | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | minispation may 2702 store | | | miletremer teat 3040 etaps | | | INTERNAL TANK PAR ATMEN | | | officialities that All Plays | | | militarina had differen | | | INTERNAL DARK & STOPE | | | methoda hal I step | | | . Commencial en an anna fin et en an artistat en an an anna an anna an anna an anna an an | DIGIGIOUS.E | | # 11/11/ ( HEARING HE CONTROL OF THE PROPERTY | DOMESTIC STATE | | | CHILD THE STATE OF | | > Decembración de acomposições | TA 910000 | | > 1111111000000000000000000000000000000 | 0000011 ATT | | > 0000000001001100110111111111111111111 | TOSTATI SEA | | > DESCRIPTION OF THE OFFICE AND ADDRESS OF THE OFFICE AND ADDRESS OF THE OFFICE ADDRESS OF THE OFFICE AND ADDRESS OF THE OFFICE AND ADDRESS OF THE OFFICE AND ADDRESS OF THE OFFICE ADDRESS OF THE OFFICE AND ADDRESS OF THE OFFICE | CHICKENSON | | > 1111111161813181618181818181818181818181 | HEIETT SEL | | >11111111616161616161616161616161616161 | HETEITE SEL | | > 111/1111 redinaced/accessoracedecessoracedecessoracedecessoracedecessoracedecessoracedeces | * \$000000 | | > 5 9480 00 81 1 5 1 5 0 5 0 5 0 5 0 5 0 5 0 5 0 5 0 | | | > 250000000001111111111111111100000000000 | ***** | | - B DOCUMENT OF BUILDING STATES OF THE STATE | 0.202020 | | > documentation accusto accusto accusto accust 111111111111111111111111111111111111 | | | | | | - Caraba proper primitario de la della primitario della primita | | | > 1 ministration of the language of the management of the language lang | -9900000 | | | | | > 0100001000000000000000000000000000000 | | | > 1 c 0 0 0 1 C 0 0 0 1 C 0 0 0 0 0 0 0 0 0 0 | | | > ecoepactoros compagnes propagnes p | | | > 100004504045000550004500045000406000040600040600004060000060600001116004560000 | | | - 300988000000000000000000000000000000000 | | | - 10/004000304040404040404040400044400040404000404000404 | | | - 100494049944449860020000000000000000000000000000000000 | | | - 10000400004004040000000000000000000000 | | | - x0-excens arene occossocossocossocomens conscions acquisite cons | | | - tc4ste004000400000000000000000000000000000 | | | > 0000004C000000000000000000000000000000 | | | > 0.00000000000000000000000000000000000 | | | > 00000000940000440000440000000000000000 | | | > 4304003444544040003444044040404040404040 | | | > 400400424440404040404044044044044444440404040404 | | | > #45400456404364055606366063660635600638406665600033860036056060636600038656660256 | | | - EDGEOGRAPHICONDENSITY OF THE PROPERTY | | | > CENTRE DE COMPRESSE DE LA COMPRESSE DE COM | | | > LTMOTIFECON SCRIPT AND ADMINISTRATION ADMINISTRATION ADMINISTRATION AND ADMINISTRATION ADMINISTRATION ADMINISTRATION ADMINISTRATION AND ADMINISTRATION ADMINISTRATION ADMINISTRATION AND ADMINISTRATION ADMINISTRATION AND A | | | > Processing and the second se | | | > 1000000 March 1000000000000000000000000000000000000 | | | > Management of the second sec | | | > | | | > 1000000000000000000000000000000000000 | | | | | | Santonianianianianianianiani | | | | | | >40100000000000000000000000000000000000 | | | 5 | HITTINIA. | #### Write Cycle Simulation COMM OFF & MINERAL PROPERTY. initialization took 8978 stees initialization took 2682 stupe initialization took 3440 steps initialization took 764 eteos initialization took \$5 erecu initialization took 49 stage initialization took & stone initialization took 0 stens > noneen mennennennennennennennen 1 nanonnennennennen ander andere ander > management and an appropriate the second and a > one aco operación de description de la construcción construcci ``` > CONTROL BUT ON THE PROPERTY OF > CONDOCUMENTATION OF THE PROPERTY PROP > ITTITUTE OF THE PROPERTY ``` # APPENDIX D: CIRCUIT SCHEMATICS # A. MICROINTERFACE WITHOUT LINE DRIVERS Figure 57 Microinterface Without Line Drivers. # B. MICROINTERFACE WITE SDA BUS LINE DRIVERS Figure 58 Microinterface With Line Drivers. ## APPENDIX E: PRELIMINARY DATA SHEET Component Name: Microinterface Chip General Description: Microinterface is an interface between National Semiconductor's NM34CF04, honvolatile, serial-access, ferroelectric memory device, and Intel's 8086 microprocessor. A pin diagram is shown in Figure 59. ## Fin description: A0-A11 - Address input pins DO-D15 - Bidirectional parallel data bus pins SDAH/L - Bidirectional serial data bus pins RD/WR - Read/Write request input (active low) BHE - Bus High Enable (active low) FERRO - Chip select input (active low) CLK - 100 KHz clock signal input SDAH/L OUT, SDAH/L\_IN, HI/LO DATA OUT - External driver enables (active low) SCLN/b - Serial Clock outputs to NM24CF04 chips RDY - READY output (active low) RESET - Input to reset Main Finite State Machine Static Power Dissipation (no input): 821 µW Dynamic Power Dissipation (worst case) : 1.64 W Figure 59 Frellminary Pinout. ## LIST OF REFERENCES - T.C. Gonter, "A Microprocessor Interface for the NM24CF04 Serial-Access Ferroelectric Memory," Masters Thesis, Naval Postgraduate School, Monterey, CA, Dec 1991. - D.A. Carver, "A Ferroelectric Material Development Test Chip," Proceedings of The Second Symposium on Integrated Ferroelectrics, pp. 125-134, Mar 1909. - R.L. Wiker, "Ferroelectric Memories for Military Applications," Proceedings of the Second Symposium on Integrated Ferroelectrics, pp. 163-174, Monterey, CA, Mar 1990. - National Semiconductor, NM24CF04, 4096-Bit (512x8) CMOS Serial Nonvolatile Memory, November 1990. - Intel Corporation, iAPX 86/88, 186/188 User's Manual Hardware Reference, 1985. - 6. Computer Science Division, University of California at Berkeley, Berkeley Cad Tools User's Manual, University of California at Berkeley, 1986. - Department of Electrical Engineering and Computer Sciences, University of California at Berkeley, SPICE3C1 User's Guide, by T. Quarles, and others 27 April 1987. - 8. Weste, N. H., and Eshraghian, K., Principles of CMOS VLSI Design, Addison-Wesley Publishing Co., 1988. # INITIAL DISTRIBUTION LIST | 1. | Defense Technical Information Center | No. | Copies 2 | |----|-------------------------------------------------------------------------------------------------------------------------------------|-------------|----------| | | Cameron Station<br>Alexandria VA 22304-6145 | | | | 2. | Library, Code 52<br>Naval Postgraduate School<br>Monterey CA 93943-5101 | | 2 | | 3. | Department Chairman, Code EC<br>Department of Electrical and Computer<br>Naval Postgraduate School<br>Monterey CA 93943-5121 | Engineering | 1 | | 4. | Professor Douglas Fouts, Code EC/Fs<br>Department of Electrical and Computer<br>Naval Postgraduate School<br>Monterey CA 93943-5121 | Engineering | 2 | | 5. | Professor Chi-Hwa Lee, Code EC/Le<br>Department of Electrical and Computer<br>Naval Postgraduate School<br>Monterey CA 93943-5121 | Engineering | 1 | | 6. | LT James H. Dickerson<br>Portsmouth Naval Shipyard<br>Portsmouth NH 03804 | | 2 | DUDLEY KNOX LIBRARY NAVAL POSTGRADUATE SCHOOL MONTEREY CA 93943-5101