VHDL中attribute string of signal: signal is "NO";

How do I keep Xilinx XST from merging nets from my design?

I'm asking and answering this question so that I can find it again in the future...

How do I keep XST from merging two logically equivalent nets into one (which normally is a good idea to save resources, but may not be a good idea from a timing view)?

I have a design with 2 counters that are driven by the same clk. XST merged the lowest bit of the counters into one counter, but this is a problem, because the counters need to be separated in the design due to IOB placement constraints. I need the counters (specifically the lowest bit of the counter) to be distinct.

 

Answer:

you need to set 2 constraints on the net in your RTL. Check the synthesis report for your net to make sure that XST did what you wanted.

In Verilog

(* equivalent_register_removal="no" *)
(* keep="true" *)
reg  signal_name ;

In VHDL

attribute equivalent_register_removal: string;   
attribute equivalent_register_removal of signal_name : signal is "no";
attribute keep:string;
attribute keep of signal_name :signal is "true";
Your signal_name  : std_logic;

The link: http://stackoverflow.com/questions/11125142/how-do-i-keep-xilinx-xst-from-merging-nets-from-my-design


Made by Tim.

转载于:https://www.cnblogs.com/sundance/archive/2012/11/02/2751018.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值