The present disclosure relates generally to integrated circuit design tools, and, in particular, to hierarchical integrated circuit repartitioning.
In designing integrated circuits using very large scale integration (VLSI), thousands of transistor-based circuits can be integrated into a single package. A VLSI design may be used for developing a variety of integrated circuits, such as application specific integrated circuits (ASICs), microprocessors, microcontrollers, memory devices, and the like. VLSI designs are typically developed using either a flat or hierarchical physical design. In a flat design, where all circuits are routed at the same level, a design tool can layout a circuit interconnection topology faster due to fewer placement constraints as compared with a hierarchical design employing multiple levels. Another approach to VLSI design is to use a flexible hierarchical design that establishes regional constraints for circuit placement and allows for regions to overlap. Denser VLSI designs that incorporate a larger number of circuits within a single chip often require some form of hierarchical design to fit within the physical dimensions of the chip.
Even though a hierarchical design may be desired for the final design of a VLSI chip, an initial VLSI design often treats circuits within the design as existing within the same level of hierarchy (pseudo-flat), in order to simplify analysis. For example, a design may include a parent level (top level) and one or more child levels. Each level may include multiple entities, such as multiple children entities on the same child level, e.g., a modular design. Timing analysis can be performed faster if the design is initially viewed as existing at a common level, e.g., placing the source and sink pins of children at the same location as the driving and receiving circuit pins of the children (also known as “inboard” pins). Using this approach enables timing analysis to be performed early in the design process, before the full hierarchy is designed. By adding interconnecting elements, such as latches, to a single level of the design, the impact of changes is minimized for various aspects of the design and verification process, e.g., simulation, integration, and timing analysis.
As the design matures, interconnecting elements between children are often placed at the parent level, while driving and receiving circuits are incorporated at the child level. This approach maintains the child level design while only modifying the parent level to adjust for timing and signal drive strength constraints for signals routed between child entities. Since the levels of hierarchy are physically stacked over each other, the parent entity may have very little silicon reservation inside of a child as well as limited use of lower level metal where interconnecting elements are placed and routed. When an edge pin implementation is used for a signal on a child, any signals from overlapping parent entities that enter or exit the child can have extra wire introduced to them. In many cases, the extra wire will degrade the timing and wiring solutions, causing performance to diverge from the original design. Accordingly, there is a need in the art for repartitioning between parent and child levels in hierarchical integrated circuit design.
An embodiment of the invention includes a method for hierarchical integrated circuit repartitioning. The method includes receiving parent level placement data for one or more interconnecting elements and designating at least one child to receive a pushdown of the one or more interconnecting elements from the parent level. For each child designated to receive the pushdown of the one or more interconnecting elements, the method further includes determining a physical coverage area of the child, identifying which of the one or more interconnecting elements within the physical coverage area of the child to pushdown into the child, generating an interconnecting element pushdown list for the child, including wiring layer information, and outputting the interconnecting element pushdown list.
An additional embodiment includes a method for hierarchical integrated circuit repartitioning. The method includes receiving parent level placement data for one or more interconnecting elements and designating at least one child to receive a pushdown of the one or more interconnecting elements from the parent level. For each child designated to receive the pushdown of the one or more interconnecting elements, the method further includes determining a physical coverage area of the child and expanding the physical coverage area of the child by a user-defined amount. The method also includes identifying which of the one or more interconnecting elements within the physical coverage area of the child to pushdown into the child via tracing between the child and each interconnecting element within the physical coverage area of the child to verify that the child is the only non-interconnecting element connected to one of an input and an output of each interconnecting element, where the verifying results in interconnecting element identification. The method additionally includes generating an interconnecting element pushdown list for the child, including wiring layer information, determining whether any of the identified one or more interconnecting elements are part of a bus, reporting a partial bus pushdown when fewer than all interconnecting elements of the bus are pushed down into a common child, and outputting the interconnecting element pushdown list.
Another embodiment includes a system for hierarchical integrated circuit repartitioning. The system includes a data storage device holding design data for a hierarchical integrated circuit, and a host system in communication with the data storage device, the host system executing a hierarchical integrated circuit repartitioning tool (HICRT). The HICRT receives parent level placement data for one or more interconnecting elements from the design data and designates at least one child to receive a pushdown of the one or more interconnecting elements from the parent level. For each child designated to receive the pushdown of the one or more interconnecting elements, the HICRT determines a physical coverage area of the child, identifies which of the one or more interconnecting elements within the physical coverage area of the child to pushdown into the child, generates an interconnecting element pushdown list for the child, including wiring layer information, and outputs the interconnecting element pushdown list.
A further embodiment includes a computer program product for hierarchical integrated circuit repartitioning. The computer program product includes a storage medium readable by a processing circuit and storing instructions for execution by the processing circuit for implementing a method. The method includes receiving parent level placement data for one or more interconnecting elements and designating at least one child to receive a pushdown of the one or more interconnecting elements from the parent level. For each child designated to receive the pushdown of the one or more interconnecting elements, the method further includes determining a physical coverage area of the child, identifying which of the one or more interconnecting elements within the physical coverage area of the child to pushdown into the child, generating an interconnecting element pushdown list for the child, including wiring layer information, and outputting the interconnecting element pushdown list.
Other systems, methods, and/or computer program products according to embodiments will be or become apparent to one with skill in the art upon review of the following drawings and detailed description. It is intended that all such additional systems, methods, and/or computer program products be included within this description, be within the scope of the present invention, and be protected by the accompanying claims.
Referring now to the drawings wherein like elements are numbered alike in the several FIGURES:
Exemplary embodiments, as shown and described by the various figures and the accompanying text, provide a method, system and computer program product for hierarchical integrated circuit repartitioning. In designing a hierarchical integrated circuit, including physically distinct parent and child levels, interconnecting elements may be initially added at the parent level to simplify simulation and analysis. Examples of interconnecting elements include latches, buffers, clocking structures, and other such elements. Additional interconnecting elements may be added to the design for storage and/or timing purposes, e.g., to account for reduced signal strength or delays associated with long signal paths. As the design matures, it is advantageous to alter the connectivity model such that interconnecting elements on signals traveling over a given entity's boundaries (and to/from the entity) are contained within the entity itself. When an interconnecting element is contained in the same level of hierarchy as a driving or receiving circuit, there is increased flexibility in both the optimal placement of the interconnecting element and the wiring used to get to/from the interconnecting element. In an exemplary embodiment, interconnecting elements are analyzed at the top level (e.g., parent level) of a physical integrated circuit design hierarchy to determine whether one or more interconnecting elements can be “pushed down” to a lower level (e.g., child level). For example, a latch at the parent level may be pushed down to a specific child entity if the latch is in close proximity to the child entity and other conditions are met, as describer in greater detail herein.
Turning now to the drawings, it will be seen that in
The network 106 may be any type of communications network known in the art. For example, the network 106 may be an intranet, extranet, or an internetwork, such as the Internet, or a combination thereof. The network 106 may include wireless, wired, or fiber optic links.
The data storage device 108 refers to any type of storage and may comprise one or more secondary storage elements, e.g., a hard disk drive or tape storage system that is external to the host system 102. In an alternate exemplary embodiment, the data storage device 108 is internal to the host system 102. Types of data that may be stored in the data storage device 108 include databases and/or files of design data 110, as well as output files 112. It will be understood that the data storage device 108 shown in
In an exemplary embodiment, the host system 102 executes various applications, including a hierarchical integrated circuit repartitioning tool (HICRT) 114. Other applications, e.g., electronic design automation (EDA) software, business applications, a web server, etc., may also be implemented by the host system 102 as dictated by the needs of the enterprise of the host system 102. The HICRT 114 interacts with databases and/or files stored on the data storage device 108, such as the design data 110, and the HICRT 114 generates the output files 112. In an exemplary embodiment, the design data 110 include hierarchical integrated circuit design and modeling data, such as net lists and placement information for multiple design levels. All or a portion of the HICRT 114 may be located on the user systems 104 with processing shared between the user systems 104 and the host system 102, e.g., a distributed computing architecture. In addition, all or a portion of the data utilized by the HICRT 114 may be located on the user systems 104.
In an exemplary embodiment, the user systems 104 access the host system 102 to request hierarchical integrated circuit repartitioning on the design data 110 while designing a hierarchical integrated circuit. The user systems 104 may also access the host system 102 to create or modify the design data 110 using other EDA software (not depicted). In an exemplary embodiment, the HICRT 114 is capable of analyzing the design data 110 to determine whether interconnecting elements in the design should be repartitioned to a different hierarchical level in the design. The HICRT 114 may be implemented as a stand-alone application, a plug-in, a module, or an executable script in a development environment. In an exemplary embodiment, when the host system 102 receives a request to execute the HICRT 114, the design data 110 is read from the data storage device 108. As described in greater detail herein, the HICRT 114 analyzes the design hierarchy and interconnecting element placement options within the design data 110, producing latch repartitioning results for automating latch placement decisions in a multi-level integrated circuit design, and outputs the results to the output files 112.
Turning now to
The physical coverage area of the child B 204 includes latches 212 and 214, as well as macro three 216; however, the latches 212 and 214 are initially physically above the child B 204 at the parent level, and the macro three 216 is below the child B 204 at the grandchild level. The latches 212 and 214 are interconnecting elements that are initially at the parent level and analyzed by the HICRT 114 of
The physical coverage area of the child C 206 includes latches 218 and 220, as well as macro two 222; however, the latches 218 and 220 are initially physically above the child C 206 at the parent level, and the macro two 222 is below the child C 206 at the grandchild level. Similar to the other latches of
In an exemplary embodiment, each child instance A-C (202-206) is designated to receive a pushdown from the parent level to the child level of one or more interconnecting elements, e.g. the latches depicted in
In an exemplary embodiment, the HICRT 114 of
UNIT PIN sd_ztop fx_sd_norm_spare<0> 1 latches (“b1” “b2”) “N15W15S16”
UNIT PIN sd_ztop fx_sd_norm_spare<1> 1 latches (“b1” “b2”) “N15W15S16”
UNIT PIN sd_ztop fx_sd_pwr_save 2 latches (“m4” “b1” “b2”) “N20W20S14”
UNIT PIN sd_ztop fx_sd_srlz_opcode<0> 2 latches (“b1” “b2”) “N15W15S16”
Pushdown information, as provided in the example above, may include particular pin identifiers for net names, a number of interconnecting elements (e.g., latches) to pushdown, and wiring layer information and codes used at the parent level.
Since only a portion of the interconnecting elements for a multi-bit bus may overlap a child in an initial topology, a list can be generated whenever fewer than the full number of bits in a bus is identified to be pushed down to a child. The list can be reviewed, with adjustments made, manually or automatically, so that all or none of the interconnecting elements in the bus are pushed into the child. The output files 112 of
fx_sd_xcond_code<4 TOT: 4 fx_sd_xcond_code<0> fx_sd_xcond_code<3>
if_sd_dial<11 TOT: 63 if_sd_dial<0> if_sd_dial<62>
if_sd_dial_p<1 TOT: 8 if_sd_dial_p<0> if_sd_dial_p<7>
if_sd_excp_tags<10 TOT: 10 if_sd_excp_tags<0> if_sd_excp_tags<9>
In the example above, the output indicates, among other things, the number of bus bits pushed down relative to the number of bits for the bus as “x TOT: y”, where “x” represents the number of bits or interconnecting elements pushed down into a common child and “y” represents the bus width. For example, “4 TOT: 4” indicates that all four bits of a four bit bus have been pushed down, while “11 TOT: 63” indicates that only eleven of sixty-three bits of a bus have been pushed down. The output can be further examined by the HICRT 114 of
Turning now to
In an exemplary embodiment, the HICRT 114 of
Turning now to
At block 402, the HICRT 114 receives parent level placement data for one or more interconnecting elements. At block 404, the HICRT 114 designates at least one child to receive a pushdown of the one or more interconnecting elements from the parent level. The designation may be based on user-defined input targeting specific children.
At block 406, the HICRT 114 performs steps included in blocks 408-414, for each child designated to receive the pushdown of the one or more interconnecting elements. At block 408, the HICRT 114 determines a physical coverage area of the child. The physical coverage area may be expanded by a user-defined amount to include interconnecting elements that partially overlap a child or are in close proximity to the child. The coverage area for each child may overlap each other.
At block 410, the HICRT 114 identifies which of the one or more interconnecting elements within the physical coverage area of the child to pushdown into the child. For each interconnecting element, the HICRT 114 verifies that the child is the only non-interconnecting element connection upon a trace backward from the interconnecting element input or forward from the interconnecting element output to identify the interconnecting element. Using a tracing approach prevents pushing down an interconnecting element that includes multiple input or output connections, which could adversely impact signal integrity and add connections to the child that previously did not exist. For example, if an interconnecting element that receives input from two children is pushed down into one of the two children, the child receiving the pushdown would require in an additional input connection to accommodate the signal from the second child, which may be a less efficient result than keeping the interconnecting element at the parent level.
The HICRT 114 encounters an additional issue when more than one child identifies a common interconnecting element. In an exemplary embodiment, for each common interconnecting element identified with more than one child, the HICRT 114 calculates a furthest distance between the common interconnecting element and the more than one child, retaining the identification for the common interconnecting element with the furthest distance, and removing the identification for all of the common interconnecting elements except for the common interconnecting element with the furthest distance. Thus, the HICRT 114 pushes down the common interconnecting element into only one child, selecting the child that provides the greatest potential benefit through reducing the furthest connection distance. The distance may be calculated as a Manhattan distance using coordinates for the common interconnecting element and each child as derived from the design data 110.
At block 412, the HICRT 114 generates an interconnecting element pushdown list for the child, including wiring layer information. The generating of the pushdown list may include reporting a number of interconnecting elements to pushdown, and determining a connection definition between net names for the parent level and the child level. The connection definition may include wire codes and other routing information. Each connecting pin at the child level may be analyzed to determine changes required for including pushed down interconnecting elements. The wiring layer information may include wiring layer and wiring width data used at the parent level for the one or more interconnecting elements.
At block 414, the HICRT 114 outputs the interconnecting element pushdown list. The output may be formatted as files or data for storage in the data storage device 108 as the output files 112. In an exemplary embodiment, a pushdown list is created for each child that receives at least one pushdown. In an alternative exemplary embodiment, a shared pushdown list is created for all children receiving at least one pushdown. The HICRT 114 may also determine whether any of the identified one or more interconnecting elements are part of a bus, and report a partial bus pushdown when fewer than all interconnecting elements of the bus are pushed down into a common child. The HICRT 114 may block the partial bus pushdown or pushdown all interconnecting elements of the bus into the common child. In an alternate exemplary embodiment, a user makes a determination as to whether the partial bus pushdown should be prevented by moving the pushed down interconnecting elements of the bus back to the parent level, or pushing down all of the interconnecting elements of the bus into the common child. Keeping all of the interconnecting elements of the bus at the parent level or in the common child may simplify simulation and verification tasks, as well as provide more consistent timing for parallel signals.
Technical effects may include repartitioning the location of interconnecting elements between parent and child levels in hierarchical integrated circuit design. An advantage includes flexibility of interconnecting element placement, e.g., a latch can be placed in either the parent level or child level of a hierarchical integrated circuit design. Moving an interconnecting element from the parent level to the child level may improve freedom in choosing both the wiring layers and the path to the edge of its boundary. Since a parent entity may have very little silicon reservation inside of a child entity, as well as limited use of lower level metal where interconnecting elements are placed and routed, the present invention enables more efficient allocation of physical resources within a hierarchical integrated circuit design. Moreover, placing an interconnecting element at the same level as an associated driver or receiver circuit may reduce wire length and improve signal-timing margin.
As described above, embodiments can be embodied in the form of computer-implemented processes and apparatuses for practicing those processes. In an exemplary embodiment, the invention is embodied in computer program code executed by one or more network elements. Embodiments include computer program code containing instructions embodied in tangible media, such as floppy diskettes, CD-ROMs, hard drives, universal serial bus (USB) drives, or any other computer-readable storage medium, wherein, when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing the invention. Embodiments include computer program code, for example, whether stored in a storage medium, loaded into and/or executed by a computer, or transmitted over some transmission medium, such as over electrical wiring or cabling, through fiber optics, or via electromagnetic radiation, wherein, when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing the invention. When implemented on a general-purpose microprocessor, the computer program code segments configure the microprocessor to create specific logic circuits.
While the invention has been described with reference to exemplary embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted for elements thereof without departing from the scope of the invention. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the invention without departing from the essential scope thereof. Therefore, it is intended that the invention not be limited to the particular embodiment disclosed as the best mode contemplated for carrying out this invention, but that the invention will include all embodiments falling within the scope of the appended claims. Moreover, the use of the terms first, second, etc. do not denote any order or importance, but rather the terms first, second, etc. are used to distinguish one element from another. Furthermore, the use of the terms a, an, etc. do not denote a limitation of quantity, but rather denote the presence of at least one of the referenced item.
Number | Name | Date | Kind |
---|---|---|---|
6832362 | Nuber | Dec 2004 | B2 |
7103863 | Riepe et al. | Sep 2006 | B2 |
7137097 | Aji et al. | Nov 2006 | B1 |
7143367 | Eng | Nov 2006 | B2 |
20040078767 | Burks et al. | Apr 2004 | A1 |
20050183054 | Wein et al. | Aug 2005 | A1 |
20050251775 | Wood | Nov 2005 | A1 |
20050257178 | Daems et al. | Nov 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20080301607 A1 | Dec 2008 | US |