Reducing dynamic clock skew and/or slew in an electronic circuit

US9754063B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9754063-B2
Application numberUS-201514941847-A
CountryUS
Kind codeB2
Filing dateNov 16, 2015
Priority dateNov 17, 2014
Publication dateSep 5, 2017
Grant dateSep 5, 2017

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Reducing dynamic clock skew and/or slew in an electronic circuit is provided by: referencing a layout database and/or netlist of a design for the electronic circuit; identifying a set of neighboring buffer pairs with active buffers and adjacent sub-meshes, which are connected by a shorting bar; for each neighboring buffer pair of the set: placing a dummy buffer for each of their active buffers in the adjacent sub-meshes close to the active buffers; routing an input of a first dummy buffer located in a first sub-mesh to an output of an active buffer in a second sub-mesh; routing an input of a second dummy buffer located in the second sub-mesh to an output of an active buffer in the first sub-mesh; and connecting inputs of the first and second dummy buffers to the shorting bar.

First claim

Opening claim text (preview).

What is claimed is: 1. A method of reducing dynamic clock skew and/or slew in a digital electronic circuit caused by varying physical parameters, the method comprising: referencing a layout database and/or a netlist of a design for the digital electronic circuit before its manufacturing, the design comprising a clock mesh having adjacent sub-meshes driven by at least partially disjoint clock trees and connecting outputs of leaf level drivers in the design, the clock trees being driven by a common root tree, wherein clock trees of adjacent sub-meshes are connected at a given level (L(n)) by a shorting bar (SB), and wherein the sub-meshes contain dummy buffers at a level (L(m)) equal or higher than the shorting bar level (L(n)); modifying the digital electronic circuit design to reduce dynamic clock skew and/or slew, including: identifying a set of neighboring buffer pairs (BP(i)) each comprising active buffers in adjacent sub-meshes, which are connected by the shorting bar (SB); for each neighboring buffer pair (BP(i)) of the set: placing a dummy buffer for each of their active buffers in the adjacent sub-meshes close to the active buffers; routing an input of a first dummy buffer located in a first sub-mesh to an output of an active buffer in a second sub-mesh; routing an input of a second dummy buffer located in the second sub-mesh to an output of an active buffer in the first sub-mesh; and connecting inputs of the first and second dummy buffers to the shorting bar (SB). 2. The method of claim 1 , further comprising searching for dummy buffers in the adjacent sub-meshes starting with the shorting bar level (L(n)). 3. The method of claim 2 , wherein in case the level (L(m)) of the found dummy buffers equals the shorting bar level (L(n)), the found dummy buffers are placed close to the active buffers in the adjacent sub-meshes. 4. The method of claim 2 , wherein in case the level (L(m)) of the found dummy buffers is higher than the shorting bar level (L(n)), (L(m)>L(n)), the found dummy buffers are changed to active buffers. 5. The method of claim 4 , wherein in case the level (L(m)) of the found dummy buffers is higher than a certain level (L(n+1)), (L(m)>L(n+1)), additional buffer stages are inserted, placed and routed, wherein additional dummy buffers are added to the shorting bar level (L(n)). 6. The method of claim 5 , wherein in case the level (L(m)) of the found dummy buffers equals the level (L(n+1)), (L(m)=L(n+1)), additional dummy buffers are added to the shorting bar level (L(n)). 7. The method of claim 6 , wherein the additional dummy buffers are placed close to the active buffers in the adjacent sub-meshes. 8. A system to reduce dynamic clock skew and/or slew in a digital electronic circuit caused by varying physical parameters, the system comprising: a memory; and a processing device communicatively coupled to the memory, wherein the system performs a method comprising: referencing a layout database and/or a netlist of a design for the digital electronic circuit before its manufacturing, the design comprising a clock mesh having adjacent sub-meshes driven by at least partially disjoint clock trees and connecting outputs of leaf level drivers in the design, the clock trees being driven by a common root tree, wherein clock trees of adjacent sub-meshes are connected at a given level (L(n)) by a shorting bar (SB), and wherein the sub-meshes contain dummy buffers at a level (L(m)) equal or higher than the shorting bar level (L(n)); modifying the digital electronic circuit design to reduce dynamic clock skew and/or slew, including: identifying a set of neighboring buffer pairs (BP(i)) each comprising active buffers in adjacent sub-meshes, which are connected by the shorting bar (SB); for each neighboring buffer pair (BP(i)) of the set: placing a dummy buffer for each of their active buffers in the adjacent sub-meshes close to the active buffers; routing an input of a first dummy buffer located in a first sub-mesh to an output of an active buffer in a second sub-mesh; routing an input of a second dummy buffer located in the second sub-mesh to an output of an active buffer in the first sub-mesh; and connecting inputs of the first and second dummy buffers to the shorting bar (SB). 9. The system of claim 8 , further comprising searching for dummy buffers in the adjacent sub-meshes starting with the shorting bar level (L(n)). 10. The system of claim 9 , wherein in case the level (L(m)) of the found dummy buffers (D) equals the shorting bar level (L(n)), the found dummy buffers are placed close to the active buffers in the adjacent sub-meshes. 11. The system of claim 9 , wherein in case the level (L(m)) of the found dummy buffers is higher than the shorting bar level (L(n)), (L(m)>L(n)), the found dummy buffers are changed to active buffers. 12. The system of claim 11 , wherein in case the level (L(m)) of the found dummy buffers is higher than a certain level (L(n+1)), (L(m)>L(n+1)), additional buffer stages are inserted, placed and routed, wherein additional dummy buffers are added to the shorting bar level (L(n)). 13. The system of claim 12 , wherein in case the level (L(m)) of the found dummy buffers equals the level (L(n+1)), (L(m)=L(n+1)), additional dummy buffers are added to the shorting bar level (L(n)). 14. The system of claim 13 , wherein the additional dummy buffers are placed close to the active buffers in the adjacent sub-meshes. 15. A computer program product for reducing dynamic clock skew and/or slew in a digital electronic circuit caused by varying physical parameters, the computer program product comprising: a computer readable storage medium having computer readable program instructions embodied therewith, the computer readable program instructions being executable by a processor to perform a method comprising: referencing a layout database and/or a netlist of a design for the digital electronic circuit before its manufacturing, the design comprising a clock mesh having adjacent sub-meshes driven by at least partially disjoint clock trees and connecting outputs of leaf level drivers in the design, the clock trees being driven by a common root tree, wherein clock trees of adjacent sub-meshes are connected at a given level (L(n)) by a shorting bar (SB), and wherein the sub-meshes contain dummy buffers at a level (L(m)) equal or higher than the shorting bar level (L(n)); modifying the digital electronic circuit design to reduce dynamic clock skew and/or slew, including: identifying a set of neighboring buffer pairs (BP(i)) each comprising active buffers in adjacent sub-meshes, which are connected by the shorting bar (SB); for each neighboring buffer pair (BP(i)) of the set: placing a dummy buffer for each of their active buffers in the adjacent sub-meshes close to the active buffers; routing an input of a first dummy buffer located in a first sub-mesh to an output of an active buffer in a second sub-mesh; routing an input of a second dummy buffer located in the second sub-mesh to an output of an active buffer in the first sub-mesh; and connecting inputs of the first and second dummy buffers to the shorting bar (SB). 16. The computer program product of claim 15 , further comprising searching for dummy buffers in the adjacent sub-meshes starting with the shorting bar level (L(n)). 17. The computer program product of claim 16 , wherein in case the level (L(m)) of the found dummy buffers equals the shorting bar level (L(n)), the found dummy buffers are placed close to the active buffers in the adjacent sub-meshes.

Assignees

Inventors

Classifications

  • G06F30/396Primary

    Clock trees · CPC title

  • Circuit design at the physical level (physical level design for reconfigurable circuits G06F30/347) · CPC title

  • Floor-planning or layout, e.g. partitioning or placement · CPC title

  • Routing (G06F30/396 takes precedence) · CPC title

  • G06F1/10Primary

    Distribution of clock signals {, e.g. skew} · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9754063B2 cover?
Reducing dynamic clock skew and/or slew in an electronic circuit is provided by: referencing a layout database and/or netlist of a design for the electronic circuit; identifying a set of neighboring buffer pairs with active buffers and adjacent sub-meshes, which are connected by a shorting bar; for each neighboring buffer pair of the set: placing a dummy buffer for each of their active buffers …
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F30/396. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Sep 05 2017 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).