Author Topic: Xilinx timing constraints: How to describe stationary inputs?  (Read 1420 times)

0 Members and 1 Guest are viewing this topic.

Offline ebastlerTopic starter

  • Super Contributor
  • ***
  • Posts: 6845
  • Country: de
Let me be frank: Amateur here... I have done a few projects using Xilinx' old ISE environment, Spartan-3 and Spartan-6 FPGAs, but am only beginning to familiarize myself with timing constraints. So please be kind if this is a stupid question...

So far, I always got away with just specifying the clock timing and letting ISE optimize the placement & routing to get the design to meet timing. But I am working on a project where FPGA timing is tight. Minor changes to the VHDL make it a hit-or-miss experiment whether or not PAR comes up with a solution that meets timing. So I hope that providing some guidance via timing constraints will provide better and more robust results.

One specific thing I was wondering about: I have a few DIP switches or jumpers which are read by the FPGA, so the end user can select some configuration options. These inputs are meant to never change at runtime. I understand that I should let the synthesis/place&route know about this, so it can relax the timing on all dependent signals inside the FPGA. What is the best way to specify this?

Thanks for your help!
 

Offline OwO

  • Super Contributor
  • ***
  • Posts: 1250
  • Country: cn
  • RF Engineer.
Re: Xilinx timing constraints: How to describe stationary inputs?
« Reply #1 on: May 17, 2020, 08:15:55 am »
False paths.
Email: OwOwOwOwO123@outlook.com
 
The following users thanked this post: ebastler

Offline ebastlerTopic starter

  • Super Contributor
  • ***
  • Posts: 6845
  • Country: de
Re: Xilinx timing constraints: How to describe stationary inputs?
« Reply #2 on: May 17, 2020, 09:53:49 am »
Thanks OwO! That gave me the right term to look for.
Great signal-to-noise ratio in your reply!  :-+
 

Online Someone

  • Super Contributor
  • ***
  • Posts: 4849
  • Country: au
    • send complaints here
Re: Xilinx timing constraints: How to describe stationary inputs?
« Reply #3 on: May 17, 2020, 10:57:43 am »
Thanks OwO! That gave me the right term to look for.
Great signal-to-noise ratio in your reply!  :-+
Its a little more complex, as you only want the false path up to the register before those signals become part of timed paths. Accidentally pushing false paths onto all the paths from those pins may not be what you intended.

External IO without constraints are basically ignored for timing constraints anyway, and get reported as derived "datasheet" conditions for the design:
https://www.xilinx.com/support/answers/24221.html

If latency is insensitive (as you hint at with config at boot) adding a few stages of registers onto the path is low risk. It likely won't fix the timing problems, you'll need to look at the paths that are actually failing.
 

Offline Fred27

  • Supporter
  • ****
  • Posts: 727
  • Country: gb
    • Fred's blog
Re: Xilinx timing constraints: How to describe stationary inputs?
« Reply #4 on: May 17, 2020, 11:13:28 am »
I tried using the 90MHz clock as a clock input and got routing errors - probably due the reasons conmega specified. (I'm new at those so it could also have been a mistake on my part.)
 

Offline ebastlerTopic starter

  • Super Contributor
  • ***
  • Posts: 6845
  • Country: de
Re: Xilinx timing constraints: How to describe stationary inputs?
« Reply #5 on: May 17, 2020, 11:47:15 am »
Thanks for your comments, Someone. Could I ask two follow-up questions please?

Its a little more complex, as you only want the false path up to the register before those signals become part of timed paths. Accidentally pushing false paths onto all the paths from those pins may not be what you intended.

So, say I have implemented an internal address decoder in the FPGA, to select some address ranges with special functions. I provide a few external DIP switches to choose between different memory maps, i.e. the switches configure the way the address decoder operates.

I would declare the path from the external DIP switches to the address decoder output a "false path", but of course the path from the currently active internal address to the address decoder output remains critical and is not declared "false". Correct? (Whether or not that helps in routing a faster design is another matter...)

Quote
External IO without constraints are basically ignored for timing constraints anyway, and get reported as derived "datasheet" conditions for the design:
https://www.xilinx.com/support/answers/24221.html

Hmm, that doesn't seem to match what I see. In fact, the only I/Os mentioned in the "data sheet" section of the timing report are (a) the clock input, and (b) the DIP switch inputs which I just declared to be the starting point of a false path. None of the other I/Os, for which I have not specified any constraints, are mentioned.  What gives? ???
« Last Edit: May 17, 2020, 11:48:55 am by ebastler »
 

Online Someone

  • Super Contributor
  • ***
  • Posts: 4849
  • Country: au
    • send complaints here
Re: Xilinx timing constraints: How to describe stationary inputs?
« Reply #6 on: May 17, 2020, 10:46:51 pm »
Quote
External IO without constraints are basically ignored for timing constraints anyway, and get reported as derived "datasheet" conditions for the design:
https://www.xilinx.com/support/answers/24221.html
Hmm, that doesn't seem to match what I see. In fact, the only I/Os mentioned in the "data sheet" section of the timing report are (a) the clock input, and (b) the DIP switch inputs which I just declared to be the starting point of a false path. None of the other I/Os, for which I have not specified any constraints, are mentioned.  What gives? ???
Its not always obvious how things are included/excluded from reporting unless its manually specified. The easiest way to be sure is adding appropriate constraints on everything.

Constraints and timing closure are topics larger than HDL, and tool/vendor specific.
 
The following users thanked this post: ebastler


Share me

Digg  Facebook  SlashDot  Delicious  Technorati  Twitter  Google  Yahoo
Smf