Discussion:
Input Delay and Hold Time
(too old to reply)
Anand P Paralkar
2004-01-16 10:35:01 UTC
Permalink
Hi,

I was looking up the man pages for the synthesis directive
set_input_delay (in Synopsys DC).

The man page says:

Specifies the path delay. The
delay_value must be in units consistent
with the technology library used during
optimization. The delay_value represents
the amount of time the signal is
available after a clock edge. This
usually represents a combinational path
delay from the clock pin of a register.

If input delay is "the amount of time the signal is available after a
clock edge", then:

1. Is "input delay" different from "hold time"?

2. If these are two different parameters, what exactly is the
difference?

Thanks,
Anand
David Jones
2004-01-16 13:08:20 UTC
Permalink
Post by Anand P Paralkar
If input delay is "the amount of time the signal is available after a
1. Is "input delay" different from "hold time"?
2. If these are two different parameters, what exactly is the
difference?
Consider two blocks A and B. An output FOO from A is an input to B.

You are synthesizing block B. You have no control over block A.

The specs for block A state that signal FOO is valid 2.3 ns after
the rising edge of the clock.

When Synopsys does its timing analysis, it needs to know that any
path starting from FOO has already experienced 2.3 ns of delay
from the clock. The set_input_delay statement conveys this
information.

Hold time is different. You usually don't specify this (it
is specified in the cell library, and Synopsys will conform
to the hold time of the devices it chooses).
Richard Iachetta
2004-01-16 16:49:37 UTC
Permalink
Post by Anand P Paralkar
Hi,
I was looking up the man pages for the synthesis directive
set_input_delay (in Synopsys DC).
Specifies the path delay. The
delay_value must be in units consistent
with the technology library used during
optimization. The delay_value represents
the amount of time the signal is
available after a clock edge. This
usually represents a combinational path
delay from the clock pin of a register.
If input delay is "the amount of time the signal is available after a
1. Is "input delay" different from "hold time"?
2. If these are two different parameters, what exactly is the
difference?
Input delay tells DC how long after the clock before an input becomes valid.
Hold time is the amount of time after the clock the value of a signal (usually
an output) does not change.
--
Rich Iachetta
j
2004-01-17 03:54:17 UTC
Permalink
Watch the hold times on the input to CHIP. If no PLL to cancel insertion
delay, this will bite you, if not taken into account.
Post by Richard Iachetta
Post by Anand P Paralkar
Hi,
I was looking up the man pages for the synthesis directive
set_input_delay (in Synopsys DC).
Specifies the path delay. The
delay_value must be in units consistent
with the technology library used during
optimization. The delay_value represents
the amount of time the signal is
available after a clock edge. This
usually represents a combinational path
delay from the clock pin of a register.
If input delay is "the amount of time the signal is available after a
1. Is "input delay" different from "hold time"?
2. If these are two different parameters, what exactly is the
difference?
Input delay tells DC how long after the clock before an input becomes valid.
Hold time is the amount of time after the clock the value of a signal (usually
an output) does not change.
--
Rich Iachetta
Alexander Gnusin
2004-01-20 15:59:15 UTC
Permalink
Post by Anand P Paralkar
Specifies the path delay. The
delay_value must be in units consistent
with the technology library used during
optimization. The delay_value represents
the amount of time the signal is
available after a clock edge. This
usually represents a combinational path
delay from the clock pin of a register.
If input delay is "the amount of time the signal is available after a
1. Is "input delay" different from "hold time"?
Minimum Timing path between 2 FFs is : 1-st FF hold time +
interconnect delay + 2-nd FF setup time.
Minimum Timing path between 2 sequential networks is : 1-st network
output delay + interconnect delay + 2-nd network (clock period - input
delay).

The following picture illustrates it:

--- -----
N1 | | N2
| |
--- -----
Interconnect d
<---|<------------>|----->
---------------------------------
1-st network 2-nd network
output delay (clk period -input delay)
(network "hold") (network "setup")

Synopsys defines input delay to be opposite to network's "setup time".
Assuming that we have 1 clock period for timing path between 2
networks,
input delay is defined as "external to setup" timing, i.e. clock
period - "network setup"


Giving 0 delay for network interconnect, your statement becomes almost
true:

Input delay of network N2 equals to Output delay ("hold") of the
network N1.

2 reasons make your statement "almost true":
1. In reality interconnect delay > 0
2. We are speaking about setup and hold times of 2 different networks.


Regards,
Alexander Gnusin

Loading...