The present invention relates generally to the semiconductor devices, and more particularly, relates to a method and apparatus for implementing improved timing performance of a signal bus through wire permutation with repowering buffers.
The performance of a signal bus, and the entire chip, often is often limited by the worst-case timing performance of a signal. The timing performance of a signal in a bus is very much related to the timing behavior of the neighboring signals. The Miller effect among the interconnects is a well-known problem for signal repowering designs. The theorem states:
i=c(dv/dt),
Which means that the current that is injected into the victim signal wires is proportional to the voltage differential between the aggressor and the victim, and the coupling capacitance in between.
The use of the repowering buffers that are often needed to meet the performance constraint as chip designs are scaled down may actually amplify the problem. The conventional thinking is that insertion of the repowering buffers will help with the signal waveform in that slew will be improved. In fact, usage of the repowering buffer may amplify the timing problem due to the Miller effect.
Referring to
According to Miller's theorem, the dv/dt between A and B will be maximum and the signal degradation of wires A and B will be at their worst. As a result, slews on A and B will increase and slacks will decrease. The reductions of slack will accumulate along the bus since this transition occurs at each repowering stage labeled REPOWER BUFFER. As a result, the performance penalty due to signal fighting on A and B is proportional to the number of repowering stages on this bus.
Most of the known solutions for this problem are aimed at the reduction of the coupling capacitance, for example, to increase the wire spacing, usage of low-K insulation material between the wires, and the like. Other proposed arrangements include repositioning of repowering buffers or staggered repowering and encoding and decoding of the signals on the bus to avoid the signal fighting; however, such arrangements require availability of specific chip area and efforts for calculated buffer placement and the performance overhead for the signal encoding and decoding is large.
A need exists for a mechanism for implementing repowering buffer designs for implementing improved timing performance of a signal bus through wire permutation.
Principal aspects of the present invention are to provide a method and apparatus for implementing improved timing performance of a signal bus through wire permutation with repowering buffers. Other important aspects of the present invention are to provide such method and apparatus for implementing improved timing performance of a signal bus through wire permutation with repowering buffers substantially without negative effect and that overcome many of the disadvantages of prior art arrangements.
In brief, a method and apparatus are provided for implementing improved timing performance of a signal bus through wire permutation with repowering buffers. A repowering buffer includes a prebuffer and a postbuffer. The prebuffer includes a plurality of inverters, each having an input connected to a predefined bus wiring track. The postbuffer includes a plurality of inverters, each having an output connected to a predefined bus wiring track. A plurality of prebuffers and postbuffers are stored in a design library, each having a set wiring ordered arrangement for selectively providing wire permutation of the signal bus. A wiring order of prebuffer at the beginning of the bus is identical to the wiring order of the postbuffer at the end of bus. The wiring order of the postbuffer driving the beginning of bus wires between adjacent repowering buffers is identical to the wiring order of the prebuffer receiving at the end of the bus wires.
In accordance with features of the invention, a wiring order of a downstream buffer pair of a postbuffer and a prebuffer is chosen so that there is at least one pair of wires separated by another wire or wires in the bus.
In accordance with features of the invention, a method enables reduction of the dv/dt between signal wires using wire permutation with repowering buffers including an algorithm for selecting a sequence of wire permutation patterns to maximize Miller capacitance reduction with minimized overhead including wire crossing and a number of required books.
In accordance with features of the invention, the algorithm defines a permutation pattern width, PW, as the number of signals within a bus to be used for the wire permutation. The algorithm requires the PW to be 2n where n is greater than 1, for example, PW=4, 8, 16, and the like.
In accordance with features of the invention, a wiring order of each sequential downstream buffer pair is selected from the design library for the selected sequence of wire permutation patterns.
The present invention together with the above and other objects and advantages may best be understood from the following detailed description of the preferred embodiments of the invention illustrated in the drawings, wherein:
In accordance with features of the preferred embodiments, a method enables reduction of the dv/dt between signal wires using wire permutation with repowering buffers. Permutation of relative track position of the signal wires to each other is provided between each repowering stage. This enables distributing and amortizing the performance penalty due to the signal fighting and increasing overall slack and timing performance of the signal bus.
Having reference now to the drawings, in
Each of the repowering buffers #1-N, 204 includes a prebuffer 212 and a postbuffer 214. The repowering buffers 204 providing respective inverter pairs into the prebuffer 212 and postbuffer 214, for example as shown in
In accordance with features of the preferred embodiments, the permutation of wiring tracks A, B, C, D, 206 is done within the respective prebuffers 212 and postbuffers 214. This approach optimizes the usage of layout resources and minimizes the performance overhead caused by the wire permutation. Like the existing buffer books, there are a set of prebuffer and postbuffer books 536 that are developed and stored as part of the standard cell library as illustrated and described with respect to
In accordance with features of the preferred embodiments, the wiring order of prebuffer book 212 at the beginning of the bus must be the identical to the wiring order of the postbuffer book at the end of bus, for example, “0123” prebuffer 212 is used to accept the signals from the driver or source 202, and “0123” postbuffer 214 shall be used for driving the repowered signal to the sink 208.
In accordance with features of the preferred embodiments, the wiring order of the postbuffer book 214 driving the beginning of the wires 206 must be identical to the wiring order of the prebuffer book 212 receiving at the end of the wires, for example, “0213” postbuffer 214 of repowering buffer #1, 204 driving wires 206 connecting “0213” prebuffer 212 of repowering buffer #2, This postbuffer 214 and prebuffer 212 at the beginning and the end of the wire 206 define a “buffering pair.”
In accordance with features of the preferred embodiments, the downstream buffer pair is arranged so that there is a pair of wires, or multiple pair of wires depending on the width of the repowering books, separated by other wires in the bus. For example, for example, referring to postbuffer 214 and prebuffer 212 of repowering buffers #1 and #2, 204, with the illustrated wiring order “0123”->“0213,” track 0 and 1 are now separated and isolated by track 2.
In accordance with features of the preferred embodiments, a method enables reduction of the dv/dt between signal wires using wire permutation with repowering buffers with an algorithm for selecting a sequence of wire permutation patterns to maximize Miller capacitance reduction with minimized overhead, such as wire crossing, number of required books, and the like.
In accordance with features of the invention, the repowering buffer wire permutation effectively reduces the Miller capacitance and improves the overall timing performance of the signal bus. The selection of wire permutation pattern at each stage of the bus is provided to enhance efficiency of this technique. A novel algorithm is provided to select the proper sequence of wire permutation patterns which yields maximum Miller capacitance reduction with lowest overhead, for example, wire crossing, number of required books, and the like. The selection of a wire permutation pattern at each stage of the bus is critical to the efficiency of the method of the preferred embodiments. An exemplary novel algorithm of the preferred embodiments is illustrated and described with respect to the flow chart of
Referring now to
As shown in
As shown in
As shown in
As shown in
As shown by
Referring now to
As shown in
Referring now to
As indicated at a block 600, a permutation pattern width, PW, defined as the number of signal within a bus to be used for the wire permutation and a number of repowering stages between a source and sink are identified. The novel algorithm of the invention requires the PW to be 2n and n is greater than 1, for example, PW=4, 8, 16, and the like. Please note that PW does not need to match the width of the bus. This is due to the fact that the delay overhead incurred by internal wire crossing from one track to the other track may be larger than the performance gained by providing the wire permutation. This is especially true for wide buses, for example, for a bus width greater than or equal to 128. This algorithm guarantees that the worst case wire crossing is PW/2, for example if the bus is 8-bit wide, then the wire crossing overhead for doing the wire permutation is 8/2=4 bit wide. The maximum PW for a specific CMOS technology family depends upon a physical library setup, including for example, bit image width, device characterization, including for example, device strength, such as MOSFET's strength for pull-up and pull down, wire properties, including for example, resistivity and dielectric constant, and the like. A critical path analysis is performed to determine the maximum PW.
As indicated at a block 602, a sequence is identified for permutation pattern yielding a maximum miller capacitance reduction and lowest overhead for the repowering stages between the source and sink. For example, after the PW value is determined, the algorithm can proceed with wire permutation pattern for every repowering segment. Starting with the repowering stage, which is next, downstream from the bus signal source to the repowering stage, which is next, upstream from the bus signal receiver. For example, the following exemplary steps are performed for each repowering stage”
Step 1. If the current repowering stage is the last repowering stage of the bus, use a matching or regular wire pattern (i.e., non-permutated) and skip Step 2 and 3. This ensures that the receiver receives the right signal in the proper wiring track. If this is not the last repowering stage of the bus, go to Step 2.
Step 2. Separate the signals from the previous repowering stage into two groups, even and odd, according to the signal's track position at the previous repowering stage. The order of signals' relative track position information within the perspective group is maintained and used in the next step.
Step 3. If the current repowering stage is the even repowering stage of the bus, for example, stage 0, 2, 4, and the like, assign the signals in the even group to the first half of available track positions and then follow by the odd group. If the current repowering stage is the odd repowering stage of the bus, for example, stage 1, 3, 5, and the like, assign the signals in the odd group to the first half of available bit positions in the next repowering segment, followed by the even group.
Step 4. Move onto the next repowering stage and start with Step 1.
As indicated at a block 604, the prebuffer of the first repowering stage at the start of the bus connected to a source must be set identical to the postbuffer at the end of the bus connected to a sink from the repowering stage book circuit library 536. Buffering pair of repowering books are selected from the repowering stage book library 536 for the sequential repowering stages for identified sequence of permutation patterns, as indicated at a block 606.
Referring now to
A sequence of program instructions or a logical assembly of one or more interrelated modules defined by the recorded program means 704, 706, 708, 710, direct the computer system 500 for implementing wire permutation with repowering buffers of the preferred embodiment.
While the present invention has been described with reference to the details of the embodiments of the invention shown in the drawing, these details are not intended to limit the scope of the invention as claimed in the appended claims.