In this article i will try to cover OCV (On-Chip variations) concepts emphasizing on AOCV (Advanced OCV). You might have used OCV extensively during the timing closure. We have heard about AOCV but a little is known behind the concept of AOCV. Let's explore OCV and AOCV in a way in which one can easily understand.
While fabricating a chip, we take a wafer/die and start our process. Let's start with a question, If you are putting the same chip (design) in different portions of die, will the chip behavior be same (timing wise)? The answer is it can be or can't be but mostly NO, this is the reason where on-chip variations plays a role. Different portions of design may also see different power supply voltage and temperature. It is possible that two regions of the same chip may not encounter the identical PVT conditions. This is due to the fact that environmental and process parameters are not uniform across the die area. Due to these variations MOS characteristics will change.
You can describe on-chip variation using a random and a
deterministic component. The random component of critical parameter
variation occurs from lot to lot, wafer to wafer, and die to die.
Examples are variations in gate-oxide thickness, implant doses, and
metal or dielectric thickness. The deterministic component comprises
variations that you can predict from the location on the wafer or the
nature of surrounding patterns. These variations relate to proximity
effects, density effects, and the relative distance of devices. Examples
are variations in gate length or width and interconnect width. While working in deep-submicron processes, designers can no
longer ignore the variation between devices and interconnect
characteristics on the same die.
Modelling OCV :
Because of the above said variations, these can affect the wire delays and cell delays in different portions of the chip. To account for this local PVT variations one need to incorporate OCV analysis during STA. Since the clock and data paths can be affected differently by the OCV, the timing verification can model the OCV effect by making the PVT conditions for the launch and capture paths to be slightly different. In STA one can model these variations by derating the delays of specific paths i.e by making path slower or faster as per the need. The cell delay as well as net delay can be derated to model OCV.
OCV derating for Setup Check:
While checking for the setup check due to OCV, the worst condition is when the launch clock path and data path OCV condition result into largest delay while the capture clock path has the OCV conditions which results in smallest delays. Here these largest and smallest delays are to account for local PVT variations within die and this case is the most restrictive one for setup check. Following figure will give you an overview about the late/early path for setup check in case of OCV.
Now in order to model these late/early paths we used to provide the following constraint,
set_timing_derate -early 0.9
set_timing_derate -late 1.1
The above constraint will derate the minimum/early paths by -10% (i.e the path will be made more faster) and derate the maximum/late paths by 10% (i.e the paths will be delayed more). As we can see from the above figure that for setup check the launch clock and data path, which is maximum/late path for setup check, will be multiplied by derating factor with -late option. On the other hand capture clock which is minimum/early path for setup check, will be multiplied by derating factor with -early option. If no derating factors applied then derating factor of 1.0 is assumed.
Note: We can also derate only net delay or cell delay depending on the scenario using -net_delay or -cell_delay switch with set_timing_derate.
OCV derating for Hold Check:
While checking for the hold check due to OCV, the worst condition is
when the capture clock path OCV condition result into
largest delay while the launch clock and data path has the OCV conditions which
results in smallest delays. Following figure will give you an
overview about the late/early path for hold check in case of OCV.
Similar to the setup check, if we apply the following constraint then,
set_timing_derate -early 0.9
set_timing_derate -late 1.1
The
above constraint will derate the minimum/early paths by -10% (i.e the
path will be made more faster) and derate the maximum/late paths by 10%
(i.e the paths will be delayed more). As we can see from the above
figure that for hold check the launch clock and data path, which is minimum/early path for hold check, will be multiplied by derating factor
with -early option. On the other hand capture clock which is maximum/late path for hold check, will be multiplied by derating
factor with -late option. If no derating factors applied then derating
factor of 1.0 is assumed.
Note: We can also derate
only net delay or cell delay depending on the scenario using -net_delay
or -cell_delay switch with set_timing_derate.With -cell_check option even we can derate the setup/hold value of a cell.
AOCV:
As we have seen till now the concept of OCV is taken care by applying a fixed derating factor. This is a little bit pessimistic. As the technology node is shrinking and the frequency is increasing, the timing closure is becoming much difficult so we can't afford pessimism in the design. To overcome this pessimism we use the concept of Advanced-OCV. In AOCV we don't apply fixed derating factor, derating factor is decided based on the location and depth of the logic.
Distance based AOCV is used to model global variation effects. It is assumed that different parts of the chip will vary more so that's why as distance increases you see more variations. Let's suppose i have divided a chip into four parts - part1, part2, part3 and part4. Then the variation between part1 and part3 or part1 and part4 or part1 and part2 will be more. so in AOCV derating factor increases as the distance increases.
Depth based AOCV is used to model local variation effects. Local variations tend to cancel out over the course of long path as some delays are little worse, some are little better. so in general we say that as depth increases the derating factor decreases in case of AOCV.
AOCV differs from traditional fixed derates (OCV) in the way that derate tables for each cell are indexed by path depth. The AOCV tables include the information so that a different derate value is chosen for a cell at the begining of a path Vs the same cell near the end of the path.
Let's assume that there are 6 buffers in a data path. Generally in OCV, the cell delays are derated with the same number e.g 10ps. So 10ps is worst delay for each cell. Therefore total worst delay is 10x6=60ps. This value is used for slack calculation in timing analysis. But the fact is that all the cells won't produce 10ps delay as worst delay. Some of the cells can be fast also. so the accumulative delay will be less than 60ps. This probability of less delay (than worst) increases as the depth (no. of cells) increases.
When applied during timing analysis a cell in a short path will use a different derate factor than that same cell found in a long path. By allowing different derate for every cells, in each different path stage based OCV eliminates pessimism in a fixed derate strategy OCV. Stage based OCV derates can be computed using foundry models, LPE netlists and liberty timing libraries. The models and SPICE netlists help to define the cells' sensitivity to variation while the timing libraries can be used to identify timing arcs and desired ranges for input slew and ouput load. Derating tables for individual cells involves statistically simulation of these input conditions and timing arcs and combining the results in to final derate values.
good article
ReplyDeleteThanks a lot.
DeleteI guess .... Derating factor decreases ... As Depth Increases.
ReplyDeletethe same has been mentioned as the depth increases, derating factor decreases due to less probability of local variations with in a small cone, whereas in case of distance based, derating factor increases with distance.
DeleteYes as mentioned in the article derating factor decreases as depth increases.
DeleteWhen you say the derate is 10%. How do you up with the correct 10% number. Why can't I use 5% or 13%. How do we decide what should be the exact value used?
ReplyDeleteThe 10% figure is just for the understanding purpose.The derating factor depends on the technology on which you are working and furthermore the operating conditions which you have in your design. Depending on these the technology cells are characterized for various PVT conditions and based on the different values a table is plotted ans used in the flow accordingly, just like the depth and distance based. You can find these tables in your technology libs file. Hope it clears the point.
DeleteHow do you connect flip-flops to find stage based derates in AOCV circuit setup?
ReplyDeleteSorry for responding late, but its not about the connection of the flip-flops which defines stage based derates, its completely based on the technology and corners in which you are modeling the cells. Its more or less a constraining the timing path to mimick the same scenario which chip would face in real time. If you take reg2reg path then the dept of this path is seen depending on the number of levels you have between the flops. distance based derate is global and the depth based would be taken care by your constraints, when enabled it would apply the proper delay value for a cell from the timing lib.
Deleteconsider Reg to Reg path has 5 stages of inverters then can we consider all five inverters are having depth 5 or first will have depth- 1 then second will have depth-2 , third will have depth-3 and so on??
ReplyDeleteHello Shrikant, Its not about the depth of inverters, its the timing path which has depth of 5. Always we take the start and end point for any timing slack calculations.
DeletePlease tell me,simple meaning of aocv...
ReplyDeleteIf you read the last paragraph you can get feel anyways in simpler term the AOCV removes the pessimism involved in OCV, as OCV is fixed derate strategy and AOCV take depth also in account. while considering the derates AOCV wont use the fixed numbers as compared to the OCV. Hope i m clear.
DeleteWhy we take 1.1 in data path what is meaning of this tel me in simple way
DeleteMy search regarding the chip design. Get me towards your blog and I am happy to see the informative option regarding the topic, but I am going to discuss it with my friends and family, chip design training institutes
ReplyDeleteIs ETM & ILM's are coming to picture in aocv
ReplyDeleteGod damn. Your article help me a lot!!
ReplyDeleteYou are giving such interesting information. It is great and beneficial info for us, I really enjoyed reading it. Thankful to you for sharing an article like this.physical design course
ReplyDelete