- Engineering Change Order
Engineering Change Order (ECO) is used for changes in documents such as processes and work instructions. It may also be used for changes in specifications.
ECOs are also called an
Engineering Change Note orEngineering Change Notice (ECN) or just engineering change (EC).In a typical system development cycle, the specification or the implementation is likely to change during engineering development or during integration of the system elements. These last-minute design changes are commonly referred to as engineering change orders (ECOs) and affect the functionality of a design after it has been wholly or partially completed. ECOs can compensate for design errors found during debug or changes that are made to the design specification to compensate for design problems in other areas of the system design.
In chip design, ECO is the process of inserting a logic change directly into the netlist after it has already been processed by an automatic tool. Before the chip masks are made, ECOs are usually done to save time, by avoiding the need for full ASIC
logic synthesis , place, route,layout extraction , and timing verification.Electronic Design Automation tools are often built with incremental modes of operation to facilitate this type of ECO.After masks have been made, ECOs may be done to save money. If a change can be implemented by modifying only a few of the layers (typically metal) then the cost is much less than it would be if the design was re-built from scratch. This is because starting the process from the beginning will almost always require new
photomask s for all layers, and each of the 20 or so masks in a modernsemiconductor fabrication process is quite expensive. A change implemented by modifying only a few layers is typically called a "metal-mask" ECO. Designers often sprinkle a design with unused logic gates, and EDA tools have specialized commands, in order to make this process easier.One of the most common ECOs in ASIC design is the Gate-level netlist ECO. In this flow, engineers manually (and often tediously) hand-edit the gate level netlist, instead of re-running logic synthesis. The netlist files have to be searched for the logic affected by the change, the files need to be edited to implement the changes up and down the hierarchy, and the changes need to be tracked and verified to make sure exactly what needs to change gets changed and nothing more. This is a very time and resource intensive process that is easily subject to errors. Therefore
formal equivalence checking is normally used after ECOs to ensure the revised implementation matches the revised specification.Commercial EDA Products in ASIC ECO
With
Time to market pressures and rising mask costs in theSemiconductor industry , several EDA companies are beginning to bring more automation into the ECO implementation process. Most popular place & route products have some level of built-in ECO Routing to help with implementing physical-level ECOs.Cadence Design Systems has recently announced a product called "Conformal ECO Designer", that automates the creation of Functional ECOs, usually the most tedious process in implementing an ECO. It usesformal equivalence checking andLogic synthesis techniques to produce a Gate-Level ECO netlist based on the changed RTL.Synopsys in the past had a product called "ECO Compiler" that is now defunct.External links
* [http://www.trilobyte.com/pdf/golson_snug04.pdf The Human ECO Compiler]
* [http://www.cs.huji.ac.il/~jarom/vlsi_seminar/2005/papers/ECO%20flow%20using%20Physical%20Compiler.pdf ECO flow using Physical Compiler]
Wikimedia Foundation. 2010.