Integrated circuits typically include thousands of components having complex interrelationships. These circuits are generally designed using highly automated processes known as electronic design automation (EDA). EDA begins from a functional specification provided in a hardware description language (HDL) and continues through the specification of a circuit design including the specification of elementary circuit components called cells, the physical arrangement of the cells, and the wiring that interconnects the cells. The cells implement logic or other electronic functions using a particular integrated circuit technology.
EDA can be divided into a series of stages such as synthesis, placement, routing, etc. Each of these steps can involve selecting cells from a library of cells. Typically, a very large number of different circuit designs using various cell combinations can meet a functional specification for a circuit. For example, flip-flops are fundamental building blocks of digital circuits and thus are often included in standard cell libraries. A flip-flop is a circuit that has two stable states and can be used to store state information. Flip-flops have one or two outputs and can be made to change state by signals applied to one or more control inputs.
Aspects of the present disclosure are best understood from the following detailed description when read with the accompanying figures. It is noted that, in accordance with the standard practice in the industry, various features are not drawn to scale. In fact, the dimensions of the various features may be arbitrarily increased or reduced for clarity of discussion.
The following disclosure provides many different embodiments, or examples, for implementing different features of the provided subject matter. Specific examples of components and arrangements are described below to simplify the present disclosure. These are, of course, merely examples and are not intended to be limiting. For example, the formation of a first feature over or on a second feature in the description that follows may include embodiments in which the first and second features are formed in direct contact, and may also include embodiments in which additional features may be formed between the first and second features, such that the first and second features may not be in direct contact. In addition, the present disclosure may repeat reference numerals and/or letters in the various examples. This repetition is for the purpose of simplicity and clarity and does not in itself dictate a relationship between the various embodiments and/or configurations discussed.
Further, spatially relative terms, such as “beneath,” “below,” “lower,” “above,” “upper” and the like, may be used herein for ease of description to describe one element or feature's relationship to another element(s) or feature(s) as illustrated in the figures. The spatially relative terms are intended to encompass different orientations of the device in use or operation in addition to the orientation depicted in the figures. The apparatus may be otherwise oriented (rotated 90 degrees or at other orientations) and the spatially relative descriptors used herein may likewise be interpreted accordingly.
Electronic Design Automation (EDA) tools and methods facilitate the design, partition, and placement of microelectronic integrated circuits on a semiconductor substrate. This process typically includes turning a behavioral description of the circuit into a functional description, which is then decomposed into logic functions and mapped into cells using a standard cell library. Once mapped, a synthesis is performed to turn the structural design into a physical layout, a clock tree is built to synchronize the structural elements, and the design is optimized post layout.
The bus 130 may be one or more of any type of several bus architectures including a memory bus or memory controller, a peripheral bus, or video bus. The CPU 120 may comprise any type of electronic data processor, and the memory 122 may comprise any type of system memory, such as static random access memory (SRAM), dynamic random access memory (DRAM), or read-only memory (ROM).
The mass storage device 124 may comprise any type of storage device configured to store data, programs, and other information and to make the data, programs, and other information accessible via the bus 130. The mass storage device 124 may comprise, for example, one or more of a hard disk drive, a magnetic disk drive, an optical disk drive, flash memory, or the like.
The term computer readable media as used herein may include computer storage media such as the system memory and storage devices mentioned above. Computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, or program modules. The memory 122 and mass storage device 124 are computer storage media examples (e.g., memory storage). The mass storage device may further store a library of standard cells, as will be discussed further herein below.
Computer storage media may include RAM, ROM, electrically erasable read-only memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other article of manufacture which can be used to store information and which can be accessed by the processing device 100. Any such computer storage media may be part of the processing device 100. Computer storage media does not include a carrier wave or other propagated or modulated data signal.
Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term “modulated data signal” may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
The video adapter 126 and the I/O interface 128 provide interfaces to couple external input and output devices to the processing unit 110. As illustrated in
Embodiments of the processing system 100 may include other components. For example, the processing system 100 may include power supplies, cables, a motherboard, removable storage media, cases, and the like. These other components, although not shown, are considered part of the processing system 100.
In some examples, software code is executed by the CPU 120 to analyze a user design to create a physical integrated circuit layout. The software code may be accessed by the CPU 120 via the bus 130 from the memory 122, mass storage device 124, or the like, or remotely through the network interface 140. Further, in some examples, the physical integrated circuit layout is created based on a functional integrated circuit design, which may be received though the I/O interface 128 and/or stored in the memory 122 or 124 in accordance with various methods and processes implemented by the software code.
A standard cell can include an entire device, such as a transistor, diode, capacitor, resistor, or inductor, or can include a group of several devices arranged to achieve some particular function, such as an inverter, a flip-flop, a memory cell, or an amplifier, among others. In addition to making functional design easier to conceptualize, the use of standard cells can reduce verification time for design rule checking (DRC) of the layout features within the IC, because a standard cell that is repeated throughout the layout can be checked a single time in DRC rather than each instantiation being checked individually. Based on the received functional circuit description, the system 100 is configured to select standard cells from the cell library.
As noted above, flip-flop circuits may be included in a standard cell library. A flip-flop is a circuit that has two stable states and thereby is capable of serving as one bit of memory. A flip-flop is usually controlled by one or two control signals and a clock signal. The output often includes the complement as well as the normal output. Flip-flops can be either simple (transparent) or clocked (or non-transparent). Clocked flip-flops are specially designed for synchronous (time-discrete) systems and typically implemented as master-slave devices. Flip-flops can be further divided into types: the RS (“set-reset”), D (“data” or “delay”), T (“toggle”), and JK types are common ones. The D flip-flop is known as a delay flip-flop (as its output Q looks like a delay of input D) or data latch. The behavior of a particular type flip-flop can be described by what is termed the characteristic equation, which derives the “present state” output in terms of the input signal(s) and/or the “previous state” signal of the flip-flops.
The D flip-flop captures the value of the D-input at a definite portion of the clock cycle (such as the rising edge of the clock). That captured value becomes the Q output. At other times, the output Q does not change. The D flip-flop can be viewed as a memory cell, a zero-order hold, or a delay line.
Disclosed embodiments thus include various implementations of a single bit flip-flop with the ability to share a common clock signal.
Additionally, the flip-flop 300 includes a clock input terminal 320 that is positioned so as to extend to one of the borders 310, 312, 314, 316. In the example of
Proceeding to operation 404, standard cells are selected from a cell library to design the device based on the received functional design. As noted above, the cell library is comprised of a listing of pre-designed components, or cells, each of which may perform a discreet logic function. The cells are stored in the cell library as information comprising internal circuit elements, the various connections to these circuit elements, a pre-designed physical layout pattern that includes the unit height of each cell along with the cell's designed power rails, dopant implants, wells, etc. Additionally the stored cell may also comprise a shape of the cell, terminal positions for external connections, delay characteristics, power consumption, etc. In some examples, the functional design is initially synthesized and an initial netlist is generated containing individual, single bit flip-flops, and cell placement of these single bit flip-flops is initially performed. The standard library includes flip-flops with input and output terminals allowing for a shared clock signal as discussed above. At operation 406, the single bit flip-flops are merged and replaced with flip-flop cells that are abutted adjacent to one another to form multi-bit flip-flops. In some examples, the processing system 100 is configured to determine the number of abutted flip-flop cells 300 abutted to one another to make up the multi-bit flip-flops based on design parameters and power, performance and area (PPA) requirements, which may also be stored in the memory 122 or mass storage device 124 of the processing system 100.
At operation 408 a final synthesis is performed on the design, in which the cell placement and routing is completed using the multibit flip-flops made up of the abutted flip-flop cells 300, and the behavior and/or functions desired from the design are transformed to a functionally equivalent logic gate-level netlist including the merged flip-flop cells.
At operation 410 a photolithographic mask is generated. With the photo mask created, the process proceeds to operation 412 where the integrated circuit is fabricated based on the photo mask.
Additionally, the flip-flop 301 includes an amplifier 330 having an input connected to the clock input terminal 320 and an output connected to the clock output terminal 322. The clock input 320 and output 322 terminals extend to the first and second border respectively to allow for a shared clock signal to be propagated. The amplifier 330 is configured to amplify the clock pulse received at the clock input terminal 320 to propagate the clock pulse to the clock input terminals receiver flip-flops, which as discussed below, does not necessarily include an amplifier.
In accordance with further disclosed embodiments,
The flip-flop 302 shown in
The various examples of the flip-flops disclosed herein thus provide for a variety of possible configurations.
In accordance with further disclosed embodiments,
In accordance with still further disclosed embodiments,
The first clock output terminal 322a of the first flip-flop 303 is electrically connected to the first clock input terminal 320a of the second flip-flop 302a positioned below the first flip-flop 303. Additionally the second clock output terminal 322b of the first flip-flop 303 is electrically connected to the second clock input terminal 320b of the third flip-flop 302b positioned to the right of the first flip-flop 303. The second clock output terminal 322b of the second flip-flop 303a is electrically connected to the second clock input terminal 320b of the fourth flip-flop 302c, while the first clock output terminal 322a of the third flip-flop 302b is electrically connected to the second clock input terminal 320b of the fourth flip-flop 302c.
The disclosed flip-flop cells allow for additional variability in multi-bit flip-flop design. With prior multi-bit flip-flop cells, the cell types are pre-defined based on a variety of factors, such as bit count, leakage voltage type, gate length, etc. To vary from the pre-defined multi-bit flip-flop cell designs could be complicated and expensive. The disclosed modular multi-bit flip-flop provides additional flexibility. For instance, if a multi-bit flip-flop having varying voltage threshold types is desired for different bits of the flip-flop, flip-flop cells having the desired voltage thresholds may be selected and assembled into the desired multi-bit flip-flop.
Proceeding to operation 606, a third flip-flop having a clock input terminal and a clock output terminal is positioned adjacent to the second flip-flop such that the second flip-flop directly abuts the third flip-flop. Additionally the clock output terminal of the second flip-flop electrically connects with the clock input terminal of the third flip-flop.
Thus, aspects of the present disclosure provide a multi-bit flip-flop formed from a plurality of single bit flip-flop cells that each include clock input and output terminals, such that a common clock pulse drives each bit the multi-bit flip-flop. Disclosed embodiments thus include an integrated circuit that includes a semiconductor substrate with a plurality of circuit elements in or on the substrate. The circuit elements are defined by standard layout cells selected from a cell library. The circuit elements include a plurality of flip-flops, where each flip-flop has a data input terminal, a data output terminal, a clock input terminal, and a clock output terminal. The plurality of flip-flops include a first flip-flop and a second flip-flop adjacent the first flip-flop. The first flip-flop directly abuts the second flip-flop such that the clock output terminal of the first flip-flop electrically connects with the clock input terminal of the second flip-flop.
In accordance with further disclosed embodiments, a flip-flop structure includes a substrate defining an outer periphery. The outer periphery has a first border and a second border. The flip-flop structure has a data input terminal, a data output terminal, a clock input terminal positioned so as to extend to the first border, and a clock output terminal positioned so as to extend to the second border.
In accordance with still further disclosed embodiments, a method for providing a multibit flip-flop circuit includes providing a first flip-flop having a clock input terminal and a clock output terminal. A second flip-flop is positioned adjacent the first flip-flop. The second flip-flop has a clock input terminal and a clock output terminal. The first and second flip-flops are positioned such that the first flip-flop directly abuts the second flip-flop and the clock output terminal of the first flip-flop electrically connects with the clock input terminal of the second flip-flop.
The foregoing outlines features of several embodiments so that those skilled in the art may better understand the aspects of the present disclosure. Those skilled in the art should appreciate that they may readily use the present disclosure as a basis for designing or modifying other processes and structures for carrying out the same purposes and/or achieving the same advantages of the embodiments introduced herein. Those skilled in the art should also realize that such equivalent constructions do not depart from the spirit and scope of the present disclosure, and that they may make various changes, substitutions, and alterations herein without departing from the spirit and scope of the present disclosure.
This application is a Continuation of U.S. patent application Ser. No. 16/536,933, filed Aug. 9, 2019, and titled “Flip-Flop Cell,” now U.S. Pat. No. 11,095,272, which claims the benefit of U.S. Provisional Application No. 62/734,589, filed Sep. 21, 2018, and titled “Flip-Flop Cell,” the entire disclosures of which are hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5013942 | Nishimura et al. | May 1991 | A |
5029279 | Sasaki et al. | Jul 1991 | A |
5208764 | Rusu et al. | May 1993 | A |
6781435 | Gupta | Aug 2004 | B1 |
8076965 | Djaja et al. | Dec 2011 | B2 |
8595668 | Soni | Nov 2013 | B1 |
11095272 | Wang | Aug 2021 | B2 |
20070293160 | Gupta et al. | Dec 2007 | A1 |
20080218235 | Sekine et al. | Sep 2008 | A1 |
20160233853 | Kamal | Aug 2016 | A1 |
20160283427 | Chaudhari et al. | Sep 2016 | A1 |
20160299524 | Rajagopal | Oct 2016 | A1 |
20180367128 | Vezyrtzis | Dec 2018 | A1 |
Number | Date | Country | |
---|---|---|---|
20210376819 A1 | Dec 2021 | US |
Number | Date | Country | |
---|---|---|---|
62734589 | Sep 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16536933 | Aug 2019 | US |
Child | 17403126 | US |